node.js - AWS EC2,pm2 : Cannot see pm2 running list

标签 node.js linux amazon-web-services amazon-ec2 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

这是我通过自己的 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

因此,当我使用上述配置启动新的 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

但我看不到正在运行的 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

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

最佳答案

我更改了 EC2 用户数据中的几个命令,例如

#!/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

我现在可以看到 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 │
└──────────┴────┴──────┴──────┴────────┴─────────┴────────┴─────┴───────────┴──────┴──────────┘

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

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

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

谢谢。

关于node.js - AWS EC2,pm2 : Cannot see pm2 running list,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45994535/

相关文章:

javascript - 正则表达式查找大写单词和小写单词

javascript - 删除 tslib 作为生产依赖项

linux - 安装哪个jpeg delegate,CentOS的安装步骤是什么?

java - 切换 AWSCredentialsProvider 的最佳方式是什么?

amazon-web-services - 为什么无法从浏览器访问我的 EC2 站点?

amazon-web-services - 使用 HTTPS 终端节点时从 Amazon SNS 获取 "SSLPeerUnverifiedException"

node.js - Gatsby 中的缓存破坏 page-data.json 文件

node.js - 本地安装时,“Protractor ”不被识别为内部或外部命令

linux - 如何仅显示来自 aws s3 ls 命令的文件?

linux - Kubernetes Pod 报告的内存使用量多于实际进程消耗量