【发布时间】:2021-02-20 20:41:43
【问题描述】:
我有一个在 AWS Lightsail 实例上运行的 Node/Express 服务器,PM2 作为流程管理器。服务器当前正在侦听端口 4000。实例的 IP 地址附加到具有有效 SSL 证书并自动从 HTTP 重定向到 HTTPS 的子域。目前访问https://example.com 会显示“恭喜!您现在正在云端运行 Bitnami Node.js 12.18.3。”页面。
目前,所有 Express 端点只能通过 http://example.com:4000/endpoint 访问,但我希望 Express 应用程序在端口 443 上运行,以便可以立即通过 https://example.com/endpoint 访问端点。
我读到 PM2 能够监听端口 80 和 443 并尝试了documentation 中提到的方法,但是每当我将 .env 文件中的端口号更改为 443 并使用 pm2 reload app 重新加载应用程序时,我收到以下错误:
0|app | Error: listen EADDRINUSE: address already in use :::443
0|app | at Server.setupListenHandle [as _listen2] (net.js:1313:16)
0|app | at listenInCluster (net.js:1361:12)
0|app | at Server.listen (net.js:1447:7)
0|app | at Function.listen (/opt/bitnami/apache/htdocs/node_modules/express/lib/application.js:618:24)
0|app | at Object.<anonymous> (/opt/bitnami/apache/htdocs/app.js:44:5)
0|app | at Module._compile (internal/modules/cjs/loader.js:1137:30)
0|app | at Object.Module._extensions..js (internal/modules/cjs/loader.js:1157:10)
0|app | at Module.load (internal/modules/cjs/loader.js:985:32)
0|app | at Function.Module._load (internal/modules/cjs/loader.js:878:14)
0|app | at Object.<anonymous> (/opt/bitnami/node/lib/node_modules/pm2/lib/ProcessContainerFork.js:33:23) {
0|app | code: 'EADDRINUSE',
0|app | errno: 'EADDRINUSE',
0|app | syscall: 'listen',
0|app | address: '::',
0|app | port: 443
0|app | }
App.js
const express = require('express');
const dotenv = require('dotenv');
const app = express();
app.use(express.json()); // for parsing POST bodies
dotenv.config();
app.get("/hello", (req, res) => res.send("Hello World!"));
app.listen(process.env.PORT, () => {
console.log(`???? App listening on port ${process.env.PORT}!`);
});
.env
PORT=443
【问题讨论】:
-
pm2 status输出是什么? -
还有
$ fuser 443/tcp -
您好@SaeidAlidadi,我更新了问题以包含 pm2 状态的输出。应用程序状态为“错误”。运行
fuser 443/tcp不会返回任何内容。