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)
有谁知道这个问题和解决方案???谢谢。
我在 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
希望对遇到此类问题的人有所帮助。
谢谢。
| 归档时间: |
|
| 查看次数: |
2389 次 |
| 最近记录: |