为什么 PM2 没有启动我的 Node 进程?

新手上路,请多包涵

以前我已经成功实施了 PM2,但目前还没有。

如果我手动启动我的节点应用程序 ,它确实 运行得很好,但我没有做任何事情让它通过 PM2 运行,即使 PM2 似乎 正在启动它。这就是我的意思:

如果我运行 pm2 start server/index.js,终端中的响应为:

 $ pm2 start server/index.js
[PM2] Spawning PM2 daemon with pm2_home=c:\pm2_system\.pm2
[PM2] PM2 Successfully daemonized
[PM2] Starting D:\Program Files\nodeApps\service-management-api\server\index.js in fork_mode (1 instance)
[PM2] Done.*

然后终端打印出一个带有 App 信息的表格。它看起来不太贴在这里,所以我将其列出:

 App Name: index
id: 0
version: 1.0.0
mode: fork
pid: 8984
status: online
restart: 0
update 0s
cpu: 0%
mem: 26.0 MB
user: ME
watching: disabled

看来节点进程应该正在运行。但是如果我立即输入 pm2 list 它显示没有进程正在运行。如果我输入 pm2 停止索引,它会显示:

 $ pm2 stop index
[PM2] Spawning PM2 daemon with pm2_home=c:\pm2_system\.pm2
[PM2] PM2 Successfully daemonized
[PM2][ERROR] Process index not found

或者,如果我尝试在命令中使用生态系统.config.js,我会得到类似的结果。以下是尝试过的命令:

 pm2 reload ecosystem.config.js
pm2 start ecosystem.config.js

运行这些命令的示例结果:

 $ pm2 start ecosystem.config.js
[PM2] Spawning PM2 daemon with pm2_home=c:\pm2_system\.pm2
[PM2] PM2 Successfully daemonized
[PM2][WARN] Applications sm_api not running, starting...
[PM2] App [sm_api] launched (2 instances)

CLI 打印表格,显示两个实例,状态为“在线”并观看“启用”。然而,应用程序没有运行(从浏览器测试时)并且“pm2 show”返回:

 [PM2] Spawning PM2 daemon with pm2_home=c:\pm2_system\.pm2
[PM2] PM2 Successfully daemonized
[PM2][WARN] <app name> doesn't exist

任何线索我的 pm2 出了什么问题?

这是我的生态系统.config.js 文件:

 module.exports = {
  apps : [{
    name: 'sm_api',
    script: 'server/index.js',
    "log_date_format"  : "YYYY-MM-DD HH:mm Z",

    // Options reference: https://pm2.io/doc/en/runtime/reference/ecosystem-file/
    args: 'one two',
    instances: 'max',
    error_file : "C:\\pm2_system\\.pm2\\logs\\sm-api-error",
    out_file: "C:\\pm2_system\\.pm2\\logs\\sm-api-out",
    autorestart: true,
    watch: "../",
    max_restarts: 10,
    max_memory_restart: '1G',
    env: {
      NODE_ENV: 'development'
    },
    env_production: {
      NODE_ENV: 'production'
    },
    exec_mode: 'cluster'
  }],
};

在 Windows Server 2012 环境中运行。请注意,我打算在 pm2 工作后添加 pm2-windows-service 包。

原文由 208_man 发布,翻译遵循 CC BY-SA 4.0 许可协议

阅读 1.7k
2 个回答

好的,在将问题发布到 pm2 github 问题页面后,我得到了答案。

在这里分享它以防其他人发现自己处于这种情况:

https://github.com/Unitech/pm2/issues/4113

(基本上 pm2 3.2.5 在 Windows 中引入了一个导致此问题的错误。我的开发安装是 3.2.4。通过在生产中恢复到 3.2.4 解决了这个问题。简单的过程,请参阅上面链接中的说明。)

原文由 208_man 发布,翻译遵循 CC BY-SA 4.0 许可协议

对于那些说要在 no-daemon 模式下运行它的人来说,请注意,( pm2 start --no-daemon ),如果你试图诊断运行时的原因,你应该使用这种模式守护进程,你的脚本失败了。

几乎总是,这是因为你告诉 PM2 在构建时监视 dist 文件夹或类似文件夹,所以 PM2 不断重启直到达到其限制(因为文件正在以相当快的速度重新生成)然后输出“错误”状态.

绝对不建议在生产中运行 no-daemon 。确保 PM2 作为守护进程运行,这样它就可以自己重启,这样它就可以作为一个进程本身来重启你的进程。如果你终止了你的终端会话或者它们在你的主机上自动超时,你会很快发现你的服务在这种情况下终止了。

所以,简而言之……以正确的方式去做并找出问题所在,而不是懒惰并将 PM2 变成 node 二进制文件的美化包装器。

原文由 user-12410035 发布,翻译遵循 CC BY-SA 4.0 许可协议

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题