当前位置: 首页 > 知识库问答 >
问题:

机器重启后PM2托管进程处于错误状态

西门安民
2023-03-14

我使用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

于是我运行了< code>pm2保存:

$ 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停止回声

错误日志(~/.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)

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


共有1个答案

韩博简
2023-03-14
匿名用户

ENOENT代表没有这样的目录条目

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/本地/共享/配置/纱线/全局/node_modules/pm2/bin/pm2

剩余的第一个参数指定要调用的程序名;根据“路径”环境变量搜索。

2) 辩论通过了

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

传递给 pm2 cli 命令参数启动系统 -u kramer65 --hp /家/克莱默 65.

  • 启动命令将简单地将pm2设置为在启动时启动(启动Cli命令)
  • 系统化命令用于受支持的初始化系统 Ubuntu =

3) 用于执行程序的环境

通过使用name=value和name2=value指定的环境变量和值扩展当前环境形成的环境。

正如pm2文档一样,文档应该是/主页/克莱默/.nvm/版本/节点/v4.3/bin中的文件夹

PATH=$PATH:/home/unitech/.nvm/versions/node/v4.3/bin

当您使用<code>home

PATH=$PATH:/usr/bin

4) 用户权限

您正在将< code >-user Kramer 65-home-path/home/Kramer 65 传递给< code>pm2 cli命令。

-u <user> --hp <home-path>

启动挂钩会自动加载您之前保存的进程列表。使用以下内容保存您的流程列表:

pm2 save

如何复制:您的计算机上有两个版本的nodejs。一个是安装在/usr/bin/node中的旧版本,另一个是位于中的最新版本。/nodejs/node。我通过调用./nodejs/nodemyManager.js以编程方式启动我的pm2管理器,它将调用pm2.connect(),它将尝试生成PM2守护程序。

实际情况是,将使用来自< code>/usr/bin/node的旧节点二进制文件启动PM2守护程序,而不是运行myManager.js脚本的最新节点二进制文件(位于< code >)。/nodejs/node)。

这是在当前目录中查找节点二进制文件,然后默认为路径中的节点二进制文件。但是运行当前代码的节点二进制文件在< code >中。/nodejs/node。要使用与当前进程相同的节点二进制文件启动PM2守护进程,您需要使用process.execPath

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

 类似资料:
  • 我发现了这个,结果是windows 10上的pm2问题。 那篇文章末尾建议的变通办法似乎很管用。 基本上,首先安装node-cmd,然后创建一个startscript.js:

  • 我试图在Ubuntu18.04中设置一个进程,以便定期检查的状态,并在必要时重新启动它。因为我更熟悉JavaScript,所以我决定让crontab进程运行一个节点文件,该文件从pm2获得JSON读数,以检查pm2中每个应用程序的状态。如果检测到任何问题,JS文件将使用执行另一个脚本。事情是这样的: null 但是,当我从JS文件执行此操作时,我会得到以下来自Bcrypt的错误: 很离奇。如果我从

  • 我正在学习本教程 使用Compose和Machine对烧瓶进行文档化-从Localhost到云 尝试使用以下命令创建虚拟框时 我有以下错误 创建计算机时出错:计算机创建过程中驱动程序出错。此计算机未启用 VT-X/AMD。在 BIOS 中启用它是强制性的 (附录:我在虚拟机器上运行ubuntu映像。物理主机是一台windows机器。在bios和virtualbox中都启用了VT 。) 到处阅读,这

  • 我创建了一个jsp web应用程序。真正的任务是我必须使用WINSCP在大学服务器上托管我的项目。但是当我使用大学域名测试这个项目时,我得到了这个错误 类型异常报告 消息无法为JSP编译类: 说明服务器遇到内部错误,无法满足此请求。 异常org.apache.jasper.JasperExctive:无法为JSP编译类:在生成的java文件中的行:[15]处发生错误:[C:\tomcat\work

  • 我正在开发我的第一个Apache波束管道,以处理来自AWS Kinesis的数据流。我熟悉Kafka如何处理消费者偏移/状态的概念,并在实施apacheStorm/火花处理方面拥有经验。 通过留档后,我成功地使用KinesiIO创建了一个工作波束管道JavaSDK监听AWS Kinesis数据流以转换和打印消息。但是,想知道任何关于如何在apache波束w. r. t中处理以下区域的参考实现或指针