node + Swagger behind nginx proxy_pass



我正在尝试让node和swagger与nginx动态工作

server_name ~^backend(?<PORTSERVER>[^.]+).domain.com$;
location /swagger
{
proxy_pass http://127.0.0.1:$PORTSERVER/swagger/;
}
location /api
{
proxy_pass http://127.0.0.1:$PORTSERVER/api;
}

这是一个虚拟主机的例子,PORTSERVER变量是从gitlab-ci中获取的,它需要合并请求的id号+ 2000

当我把端口直接放在$PORTSEVER的位置时,一切都在正常工作

任何建议都很感激,谢谢

这是index.js文件

"use strict";
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
return new (P || (P = Promise))(function (resolve, reject) {
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
step((generator = generator.apply(thisArg, _arguments || [])).next());
});
};
Object.defineProperty(exports, "__esModule", { value: true });
require("reflect-metadata");
const typeorm_1 = require("typeorm");
const express = require("express");
// var router = express.Router();
const fileUpload = require("express-fileupload");
const bodyParser = require("body-parser");
const routes_1 = require("./routes");
const cors = require("cors");
const typeorm_pagination_1 = require("typeorm-pagination");
const swaggerUi = require('swagger-ui-express');
const swaggerDocument = require('../../swagger.json');
var path = require('path');
typeorm_1.createConnection()
.then((connection) => __awaiter(void 0, void 0, void 0, function* () {
// create express app
const app = express();
app.use(bodyParser.json());
app.use(bodyParser.urlencoded());
app.use(fileUpload());
app.use(express.static(path.join(__dirname, '..', 'public')));
console.log(path.join(__dirname, '..', 'public'));
// register express routes from defined application routes
routes_1.Routes.forEach((route) => {
app[route.method]('/api' + route.route, (req, res, next) => {
const result = new route.controller()[route.action](req, res, next);
res.header('Access-Control-Allow-Origin', '*');
if (result instanceof Promise) {
result.then((result) => (result !== null && result !== undefined ? res.send(result) : undefined));
}
else if (result !== null && result !== undefined) {
res.json(result);
}
});
});
// setup express app here
// ...
app.use('/swagger', swaggerUi.serve, swaggerUi.setup(swaggerDocument));
app.use(express.json());
app.use(cors());
app.use(typeorm_pagination_1.pagination); // Register the pagination middleware
// start express server
//   app.listen(process.env.SERVER_Port);
app.listen(process.env.PORTSERVER);
console.log('Express server has started on port ' + process.env.PORTSERVER);
}))
.catch((error) => console.log(error));
//# sourceMappingURL=index.js.map

关键是他的句子是"当我把端口直接放在$PORTSEVER的位置上时,一切都在正常工作">

根据你的描述,我认为gitlabci没有生成端口号,或者没有理解语法。gitlabci和nginx都使用$VAR语法。也可能是第一行正则表达式的错误解释…

另外,我认为你需要检查js文件中使用的process.env.PORTSERVERa的内容。它可以和nginx有不同的端口…

对于这个问题,我会通过防止作业重新启动nginx来解决这个问题,以免导致其他vhost的停机时间。部署一个损坏的配置,然后从服务器上运行nginx -t和/或diff -u一个工作配置和一个损坏的配置。

真相的第一个来源将是nginx -t和nginx日志。如果nginx管理启动,它返回的HTTP代码可以显示更多的路径。

你忘记分享的一件事是你的gitlabci YML的内容。这也可以帮助识别问题。

最新更新