AWS EC2、pm2:看不到 pm2 运行列表

geo*_*ong 5 linux amazon-ec2 amazon-web-services node.js pm2

我使用的是 Amazon Linux AMI 2017.03.1 (HVM),SSD 卷类型。

我通过下面这样的方式安装了 node.js、npm,因为我想全局安装,如果我不全局安装 pm2,当我配置 EC2 引导启动 pm2 命令时它不起作用。

之后,我创建了自己的 AMI 映像。

### node.js, npm install ###
  $ sudo su
  $ curl --silent --location https://rpm.nodesource.com/setup_6.x | bash -
  $ yum -y install nodejs
### pm2 install ###
   $ npm install pm2 -g
Run Code Online (Sandbox Code Playgroud)

这是我通过自己的 AMI 创建新 EC2 实例时“高级详细信息”中的用户数据文本。

### user-data ###
 #!/bin/bash
 cd /home/ec2-user/Node.js-Test
 sudo git pull origin master
 export PM2_HOME=/home/ec2-user/
 sudo env PATH=$PATH:/usr/bin/ pm2 startup systemv -u ec2-user --hp /home/ec2-user
 su ec2-user
 pm2 start /home/ec2-user/Node.js-Test/app.js
 pm2 save
Run Code Online (Sandbox Code Playgroud)

因此,当我使用上述配置启动新的 EC2 实例时,pm2 命令正在运行,但我看不到正在运行的 pm2 列表。

当我检查日志文件/var/log/cloud-init-output.log 时,它有运行 pm2 应用程序的信息!

### /var/log/cloud-init-output.log ###
 [PM2] Spawning PM2 daemon with pm2_home=/home/ec2-user/
 [PM2] PM2 Successfully daemonized
 [PM2] Starting /home/ec2-user/Node.js-Test/app.js in fork_mode (1 instance)
 [PM2] Done.
 ???????????????????????????????????????????????????????????????????????????????????????????????
 ? App name ? id ? mode ? pid  ? status ? restart ? uptime ? cpu ? mem        ? user ? watching ?
 ???????????????????????????????????????????????????????????????????????????????????????????????
 ? app       ? 0  ? fork ? 2677 ? online ? 0        ? 0s      ? 99% ? 15.4 MB   ? root ? disabled ?
 ???????????????????????????????????????????????????????????????????????????????????????????????
  Use 'pm2 show <id|name>' to get more details about an app
Run Code Online (Sandbox Code Playgroud)

但我看不到正在运行的 pm2 list @ec2-user, @root

### in terminal EC2 instance ###
 [ec2-user@ip-172-31-10-85 ~]$ pm2 list
 ????????????????????????????????????????????????????????????????????????????????????????
 ? App name ? id ? mode ? pid ? status ? restart ? uptime ? cpu ? mem ? user ? watching ?
 ????????????????????????????????????????????????????????????????????????????????????????
 Use 'pm2 show <id|name>' to get more details about an app
 [ec2-user@ip-172-31-10-85 ~]$ sudo su
 [root@ip-172-31-10-85 ec2-user]# pm2 list
 ????????????????????????????????????????????????????????????????????????????????????????
 ? App name ? id ? mode ? pid ? status ? restart ? uptime ? cpu ? mem ? user ? watching ?
 ????????????????????????????????????????????????????????????????????????????????????????
  Use 'pm2 show <id|name>' to get more details about an app
Run Code Online (Sandbox Code Playgroud)

有谁知道这个问题和解决方案???谢谢。

geo*_*ong 6

我在 EC2 User-Data 中更改了几个命令,例如

#!/bin/bash
cd /home/ec2-user/Node.js-Test
sudo git pull origin master
sudo pkill -f PM2
sudo pm2 start /home/ec2-user/Node.js-Test/app.js
sudo pm2 startup
sudo pm2 save
Run Code Online (Sandbox Code Playgroud)

我现在可以看到 pm2 list 正在输入sudo -i pm2 list. 并在我刚刚输入时显示空列表pm2 list

[ec2-user@ip-172-31-14-68 .pm2]$ sudo pm2 list
???????????????????????????????????????????????????????????????????????????????????????????????
? App name ? id ? mode ? pid  ? status ? restart ? uptime ? cpu ? mem       ? user ? watching ?
???????????????????????????????????????????????????????????????????????????????????????????????
? app      ? 0  ? fork ? 2458 ? online ? 0       ? 11m    ? 0%  ? 29.3 MB   ? root ? disabled ?
???????????????????????????????????????????????????????????????????????????????????????????????
Run Code Online (Sandbox Code Playgroud)

这是 的上下文/root/.pm2/dump.pm2

https://github.com/geoseong/Node.js-Test/blob/master/pm2/dump_pm2_sudo_170904

希望对遇到此类问题的人有所帮助。

谢谢。