【问题标题】:PM2 listening on port 443 shows EADDRINUSE: address already in use :::443PM2 监听 443 端口显示 EADDRINUSE: address already in use :::443
【发布时间】: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 output

【问题讨论】:

  • pm2 status 输出是什么?
  • 还有$ fuser 443/tcp
  • 您好@SaeidAlidadi,我更新了问题以包含 pm2 状态的输出。应用程序状态为“错误”。运行 fuser 443/tcp 不会返回任何内容。

标签: node.js express pm2


【解决方案1】:

不幸的是,我无法使用 Nginx,而是使用 Apache 的虚拟主机配置将所有流量从端口 443 重定向到 4000。更多信息here

【讨论】:

    【解决方案2】:

    您的控制台错误统计端口已被使用,尝试更改 PORT=8282 并查看是否解决,但是,如果问题仍然存在,请将您的 dotenv 配置移至顶部 require('dotenv').config()

    【讨论】: