我正在使用Amazon Linux AMI 2017.03.1(HVM),SSD卷类型。
我通过以下方式安装了node.js,npm,因为我想 全局安装,如果我没有全局安装pm2,它什么时候不起作用 我配置EC2 bootstrapping启动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列表@ 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
有谁知道这个问题和解决方案??? 感谢。
答案 0 :(得分:3)
我在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
我现在可以看到输入sudo -i pm2 list
的pm2列表。
当我输入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
希望对那些遇到这样问题的人有帮助。
感谢。