javascript - 机器重启后 pm2 托管进程处于错误状态
问题描述
我正在使用pm2 (version 3.4.1) 来管理Laravel Echo websocket server。它运行完美,但我试图让它在机器重启后自动启动(运行 Ubuntu 16.04)。为此,我按照以下说明进行操作:
$ pm2 startup
[PM2] Init System found: systemd
[PM2] To setup the Startup Script, copy/paste the following command:
sudo env PATH=$PATH:/usr/bin /usr/local/share/.config/yarn/global/node_modules/pm2/bin/pm2 startup systemd -u kramer65 --hp /home/kramer65
$ sudo env PATH=$PATH:/usr/bin /usr/local/share/.config/yarn/global/node_modules/pm2/bin/pm2 startup systemd -u kramer65 --hp /home/kramer65
[sudo] password for kramer65:
[PM2] Init System found: systemd
Platform systemd
Template
[Unit]
Description=PM2 process manager
Documentation=https://pm2.keymetrics.io/
After=network.target
[Service]
Type=forking
User=kramer65
LimitNOFILE=infinity
LimitNPROC=infinity
LimitCORE=infinity
Environment=PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:/usr/games:/usr/local/games:/usr/bin:/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin
Environment=PM2_HOME=/home/kramer65/.pm2
PIDFile=/home/kramer65/.pm2/pm2.pid
ExecStart=/usr/local/share/.config/yarn/global/node_modules/pm2/bin/pm2 resurrect
ExecReload=/usr/local/share/.config/yarn/global/node_modules/pm2/bin/pm2 reload all
ExecStop=/usr/local/share/.config/yarn/global/node_modules/pm2/bin/pm2 kill
[Install]
WantedBy=multi-user.target
Target path
/etc/systemd/system/pm2-kramer65.service
Command list
[ 'systemctl enable pm2-kramer65' ]
[PM2] Writing init configuration in /etc/systemd/system/pm2-kramer65.service
[PM2] Making script booting at startup...
[PM2] [-] Executing: systemctl enable pm2-kramer65...
[PM2] [v] Command successfully executed.
+---------------------------------------+
[PM2] Freeze a process list on reboot via: $ pm2 save
[PM2] Remove init script via: $ pm2 unstartup systemd
所以我跑了pm2 save
:
$ pm2 save
[PM2] Saving current process list...
[PM2] Successfully saved in /home/kramer65/.pm2/dump.pm2
在此之后,我重新启动机器,重新 ssh 并检查 pm2 进程:
$ pm2 status
┌──────────┬────┬─────────┬──────┬─────┬─────────┬─────────┬────────┬─────┬────────┬────────┬──────────┐
│ App name │ id │ version │ mode │ pid │ status │ restart │ uptime │ cpu │ mem │ user │ watching │
├──────────┼────┼─────────┼──────┼─────┼─────────┼─────────┼────────┼─────┼────────┼────────┼──────────┤
│ echo │ 0 │ N/A │ fork │ N/A │ errored │ 0 │ 0 │ 0% │ 0 B │ kramer65 │ disabled │
└──────────┴────┴─────────┴──────┴─────┴─────────┴─────────┴────────┴─────┴────────┴────────┴──────────┘
Use `pm2 show <id|name>` to get more details about an app
如您所见,状态为错误。如果我停止并启动进程 ( pm2 stop echo && pm2 start echo
),进程会再次运行。
错误日志 (~/.pm2/pm2.log) 告诉我:
2019-05-14T11:56:36: PM2 log: ===============================================================================
2019-05-14T11:56:36: PM2 log: --- New PM2 Daemon started ----------------------------------------------------
2019-05-14T11:56:36: PM2 log: Time : Tue May 14 2019 11:56:36 GMT+0200 (CEST)
2019-05-14T11:56:36: PM2 log: PM2 version : 3.4.1
2019-05-14T11:56:36: PM2 log: Node.js version : 8.15.1
2019-05-14T11:56:36: PM2 log: Current arch : x64
2019-05-14T11:56:36: PM2 log: PM2 home : /home/kramer65/.pm2
2019-05-14T11:56:36: PM2 log: PM2 PID file : /home/kramer65/.pm2/pm2.pid
2019-05-14T11:56:36: PM2 log: RPC socket file : /home/kramer65/.pm2/rpc.sock
2019-05-14T11:56:36: PM2 log: BUS socket file : /home/kramer65/.pm2/pub.sock
2019-05-14T11:56:36: PM2 log: Application log path : /home/kramer65/.pm2/logs
2019-05-14T11:56:36: PM2 log: Process dump file : /home/kramer65/.pm2/dump.pm2
2019-05-14T11:56:36: PM2 log: Concurrent actions : 2
2019-05-14T11:56:36: PM2 log: SIGTERM timeout : 1600
2019-05-14T11:56:36: PM2 log: ===============================================================================
2019-05-14T11:56:36: PM2 log: App [echo:0] starting in -fork mode-
2019-05-14T11:56:36: PM2 log: App [echo:0] online
2019-05-14T11:56:36: PM2 error: Error: spawn node ENOENT
at Process.ChildProcess._handle.onexit (internal/child_process.js:190:19)
at onErrorNT (internal/child_process.js:362:16)
at _combinedTickCallback (internal/process/next_tick.js:139:11)
at process._tickDomainCallback (internal/process/next_tick.js:219:9)
有人知道这里出了什么问题吗?
解决方案
ENOENT
代表没有这样的目录条目
在env <command>
做什么?(克里斯·约翰森)
该env
命令用于在自定义环境中运行另一个程序而不修改当前程序。
sudo env PATH=$PATH:/usr/bin \
/usr/local/share/.config/yarn/global/node_modules/pm2/bin/pm2 \
startup systemd -u kramer65 --hp /home/kramer65
pm2 文档中的安装说明 要检测机器上可用的 init 系统并生成配置,请使用:
pm2 startup
$ [PM2] You have to run this command as root. Execute the following command:
$ sudo su -c env PATH=$PATH:/home/unitech/.nvm/versions/node/v4.3/bin pm2 startup <distribution> -u <user> --hp <home-path>
我将按如下方式分解命令
sudo env name=value name2=value2 program and args
1)程序
运行命令程序 /usr/local/share/.config/yarn/global/node_modules/pm2/bin/pm2
剩下的第一个参数指定要调用的程序名称;它是根据 `PATH' 环境变量搜索的。
2)通过的参数
任何剩余的参数都作为参数传递给该程序。
args
传递给pm2
cli 命令的是startup systemd -u kramer65 --hp /home/kramer65
.
- 该
startups
命令将简单地设置pm2
为在启动时启动(启动 Cli 命令) - 该
systemd
命令用于支持的 init 系统Ubuntu => 16, CenOS >=7, Arch, Debian >=7
(启动挂钩兼容性),并且应该按照platform
包含的文档更改为正确的。
3)用于执行程序的环境
通过使用 name=value 和 name2=value2 指定的环境变量和值扩展当前环境形成的环境。
按照pm2
文档应该是里面的文件夹/home/kramer/.nvm/versions/node/v4.3/bin
PATH=$PATH:/home/unitech/.nvm/versions/node/v4.3/bin
当您使用目录之外的文件夹时,home
因为您正在运行旧版本nodejs
(请参阅上一章Nodejs 安装在 usr/bin/node 中)。
PATH=$PATH:/usr/bin
4)用户权限
您正在传递--user kramer65 --home-path /home/kramer65
给pm2
cli 命令。
-u <user> --hp <home-path>
保存您的流程
启动挂钩会自动加载您之前保存的进程列表。保存您的进程列表:
pm2 save
Nodejs
安装在usr/bin/node
(错误:在 Ubuntu 14.04 上生成 ENOENT)
如何重现:您的计算机上有两个版本的 nodejs。一个是安装在的旧版本,
/usr/bin/node
另一个是位于./nodejs/node
. 我通过调用以编程方式启动我的 pm2 管理器./nodejs/node myManager.js
,这将调用 pm2.connect(),它将尝试生成 PM2 守护进程。发生的情况是 PM2 守护程序将使用旧节点二进制文件
/usr/bin/node
而不是运行我的 myManager.js 脚本(位于./nodejs/node
)的最新节点二进制文件启动。这样做是在当前目录中查找节点二进制文件,然后默认为路径中的节点二进制文件。但是运行当前代码的节点二进制文件位于
./nodejs/node
. 要使用与当前进程相同的节点二进制文件启动 PM2 守护进程,您需要使用 process.execPath
推荐阅读
- php - 如何在php中重命名和保存文件
- python - 我正在尝试使用 openCV 和 python 构建运动检测器,但是当我终止程序时显示窗口没有响应
- azure-devops - 如何从 Azure DevOps 导出报告
- javascript - this.setState() 在 this.setState() 的回调中
- c - 制作并应用 apue.h
- awk - 使用 awk 从两个文件中获取数据
- swift - Swift、自动布局和堆栈视图的问题
- azure - 执行存储过程时 Cosmos DB 内存不足异常
- excel - VBA 数据透视表错误“无效的过程调用或参数”
- apache-kafka - Kafka 消费者阅读速度太慢