PM2(Node.js)没有侦听指定的端口

时间:2014-06-12 19:58:36

标签: javascript node.js pm2

我正在尝试在PM2上启动并运行Node / Express应用程序。我可以使用此命令启动应用程序:npm start

这会在端口3000上启动应用程序。

如果我尝试使用pm2 start app.js启动应用程序,我会在日志中获得以下内容:

{ online: true, success: true, pid: 10714, pm2_version: '0.8.15' }
2014-06-12T19:52:06.789Z : [[[[ PM2/God daemon launched ]]]]
2014-06-12T19:52:06.800Z : RPC interface [READY] on 6666:localhost
2014-06-12T19:52:06.801Z : BUS system [READY] on  6667:localhost
2014-06-12T19:52:06.978Z : Entering in node wrap logic (cluster_mode) for script     /home/user/test/app.js
2014-06-12T19:52:07.115Z : /home/user/test/app.js - id0 worker online

在我的bin / www文件中,我有以下内容指定端口:

app.set('port', process.env.PORT || 3000);

我也尝试过运行export PORT=3000

以及bin / www中的以下内容:

app.set('port', 3000);

如果我运行netstat -an | grep 3000,我什么也得不回来。

5 个答案:

答案 0 :(得分:34)

对于使用Express的任何人来说,答案是运行此命令:

pm2 start ./bin/www

我一直在运行pm2 start app.js,但无效。

答案 1 :(得分:2)

您的app.set('port'...来电并不直接相关。 app.set只是存储键/值设置的地方,但它本身提供零功能。您要查看的是调用app.listen的位置,因为该函数接受端口作为参数。

答案 2 :(得分:1)

我遇到了类似的问题,将nginx配置为代理服务器我无法看到PM2运行的Express应用程序。当我删除我的~/.pm2文件夹时,它就有效了。

答案 3 :(得分:0)

我用这个

pm2.json

[
{
  "exec_mode": "fork_mode",
  "cwd" : "/opt/acme_service",
  "script": "acme_service.js",
  "name": "acme_service",
  "restart_delay":"9000",
  "port"       : 8081,
  "node_args": [ "--acme" ],
  "error_file": "/var/log/acme_service.err.log",
  "out_file": "/var/log/acme_service.out.log"
}
]

“端口”:8081-接受端口连接。在应用中相同

var server = app.listen(8081 , '0.0.0.0');

答案 4 :(得分:0)

在我的情况下,它正在侦听特定端口,但由于某种原因,我的界面找不到主机/端口,因此我安装了NGINX并将 /etc/nginx/sites-enabled/的默认值设置为:

server {
        listen 80 default_server;
        listen [::]:80 default_server;

        root /var/www/html;

        server_name _;

        location / {
            proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
            proxy_set_header Host $http_host;
            proxy_set_header X-NginX-Proxy true;
            proxy_http_version 1.1;
            proxy_set_header Upgrade $http_upgrade;
            proxy_set_header Connection “upgrade”;
            proxy_max_temp_file_size 0;
            proxy_pass ip:port/; <<<<<<<<< Change the IP and port >>>>>>>>>
            proxy_redirect off;
            proxy_read_timeout 240s;
        }

}

检查最后几行。反向代理有效。

obs:/etc/nginx/sites-enabled/default包含在/etc/nginx/nginx.conf中,然后用作NGINX的配置