机器重新启动后,pm2受管进程处于错误状态

kra*_*r65 20 javascript process-management pm2 laravel-echo

我正在使用pm2(版本3.4.1)来管理Laravel Echo Websocket服务器。它运行完美,但是我试图让它在计算机重启(运行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
Run Code Online (Sandbox Code Playgroud)

所以我跑了pm2 save

$ pm2 save
[PM2] Saving current process list...
[PM2] Successfully saved in /home/kramer65/.pm2/dump.pm2
Run Code Online (Sandbox Code Playgroud)

之后,我重新启动计算机,重新启动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
Run Code Online (Sandbox Code Playgroud)

如您所见,状态是错误的。如果我停止并启动过程(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)
Run Code Online (Sandbox Code Playgroud)

有人知道这里出了什么问题吗?

Fab*_*lio 7

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
Run Code Online (Sandbox Code Playgroud)

pm2文档中的安装说明 要检测机器上可用的初始化系统并生成配置,请使用:

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>
Run Code Online (Sandbox Code Playgroud)

我将分解如下命令

sudo env name=value name2=value2 program and args
Run Code Online (Sandbox Code Playgroud)

1)程序

运行命令程序 /usr/local/share/.config/yarn/global/node_modules/pm2/bin/pm2

剩下的第一个参数指定要调用的程序名称;根据“ PATH”环境变量进行搜索。

2)传递的论点

任何剩余的参数将作为参数传递给该程序。

args传递给pm2CLI命令的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
Run Code Online (Sandbox Code Playgroud)

当您使用目录之外的文件夹时,home因为您正在运行旧版本nodejs(请参见上一章usr / bin / node中安装的Nodejs)。

PATH=$PATH:/usr/bin
Run Code Online (Sandbox Code Playgroud)

4)用户权限

您正在传递--user kramer65 --home-path /home/kramer65pm2cli命令。

-u <user> --hp <home-path>
Run Code Online (Sandbox Code Playgroud)

保存过程

启动挂钩自动加载您之前保存的进程列表。使用以下命令保存您的进程列表:

pm2 save
Run Code Online (Sandbox Code Playgroud)

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

您可以相关讨论中阅读更多信息