据我所知: supervisor 能够实现修改命令后重启应用,可是关闭控制台以后,整个进程就挂了。 pm2 则能够后台运行,关闭控制台以后也不影响进程运行,并且有以下众多功能,且听我娓娓道来。node
首先是 pm2 的安装npm
npm install pm2 -g
复制代码
启动应用:json
pm2 start app.js --name myapp
复制代码
中止应用:api
pm2 stop myapp
复制代码
查看当前启动应用:bash
pm2 list
复制代码
查看当前全部启动应用的 log:app
pm2 logs
复制代码
查看某一应用的 log :微服务
pm2 logs <app_name|app_id> --> 例:pm2 logs myapp
复制代码
基础用法 plusui
如下是 pm2 安装好后的数据目录spa
$HOME/.pm2 --> will contain all PM2 related files
$HOME/.pm2/logs --> will contain all applications logs
$HOME/.pm2/pids --> will contain all applications pids
$HOME/.pm2/pm2.log --> PM2 logs
$HOME/.pm2/pm2.pid --> PM2 pid
$HOME/.pm2/rpc.sock --> Socket file for remote commands
$HOME/.pm2/pub.sock --> Socket file for publishable events
$HOME/.pm2/conf.js --> PM2 Configuration
复制代码
咱们的 log 数据会持久化到 $HOME/.pm2/logs 目录下,如须要查找相关 log 则找到相应的 log 文件便可。debug
命名应用:
pm2 start app.js --name myapp
复制代码
文件修改后,自动重启
pm2 start app.js --watch --name myapp
复制代码
注意: 若是使用了 --watch 参数,
pm2 stop myapp --> 将不会中止监控
pm2 stop --watch myapp --> 将会中止监控
复制代码
设置日志时间:(其中 Z 为时区)
pm2 start app.js --log-date-format="YYYY-MM-DD HH:mm Z"
复制代码
传参给 node v8:
pm2 start app.js --node-args="--debug=7001"
复制代码
内存超过上限自动重启:
pm2 start app.js --max-memory-restart 1024M
复制代码
以当前可用 cpu 数量来开启 node 进程数量
pm2 start app.js -i 0
pm2 start app.js -i max
复制代码
pm2 list # 展现进程状态
pm2 jlist # 以原生 json 数据打印进程清单
pm2 prettylist # 以格式化 json 数据打印进程清单
pm2 describe 0 # Display all informations about a specific process
pm2 monit # 监控全部进程
复制代码
pm2 logs [--raw] # 以流的方式显示全部日志
pm2 flush # 清空全部 log 文件
pm2 reloadLogs # 重载全部 log
复制代码
pm2 stop all # 中止全部进程
pm2 restart all # 重启全部进程
pm2 reload all # Will 0s downtime reload (for NETWORKED apps)
pm2 stop 0 # 经过进程 ID 来中止某个应用
pm2 restart 0 # 经过进程 ID 来重启某个应用
pm2 delete 0 # 经过进程 ID 来删除某个应用
pm2 delete all # 删除全部应用
复制代码
pm2 reset <process> # Reset meta data (restarted time...)
pm2 updatePM2 # Update in memory pm2
pm2 ping # Ensure pm2 daemon has been launched
pm2 sendSignal SIGUSR2 my-app # Send system signal to script
pm2 start app.js --no-daemon
pm2 start app.js --no-vizion
pm2 start app.js --no-autorestart
复制代码
配置文件有 json 和 .yml 文件两种格式。配置文件其实跟普通命令同样,只是将命令写进文件当中,咱们能够将参数,环境变量,logs file 写进文件当中。而配置文件对微服务有很好的支持。 json 文件格式:(文件名须要以 .config.js 结尾)
module.exports = {
apps : [{
name : "worker",
script : "./worker.js",
output: './work/logs/out.log',//指定输出 console.log 的位置
error: './work/logs/error.log',//指定输出 console.error 的位置
log: './work/logs/combined.outerr.log',
log_date_format: "YYYY-MM-DD HH:mm Z",
watch : true,
env: {
"NODE_ENV": "development",
},
env_production : {
"NODE_ENV": "production"
}
},{
name : "api-app",
script : "./api.js",
instances : 4,
exec_mode : "cluster"
}]
}
复制代码
.yml 文件格式:
apps:
- script : ./api.js
name : 'api-app'
instances: 4
exec_mode: cluster
- script : ./worker.js
name : 'worker'
watch : true
env :
NODE_ENV: development
env_production:
NODE_ENV: production
复制代码
配置文件修改以后,须要 pm2 delete app 以后,再从新启动,修改的配置才能生效
# 开启配置文件内的全部应用
pm2 start ecosystem.config.js
# 开启配置文件内的全部应用,并配置环境变量 production
pm2 start ecosystem.config.js --env production
# 只启动应用名为:myapp 的应用
pm2 start ecosystem.config.js --only api-app
# 中止配置文件内的全部应用
pm2 stop ecosystem.config.js
# 重启配置文件内的全部应用
pm2 start ecosystem.config.js
## 或者
pm2 restart ecosystem.config.js
# 重载配置文件内的全部应用
pm2 reload ecosystem.config.js
# 删除配置文件内的全部应用
pm2 delete ecosystem.config.js
# 如下命令对配置文件内的单一应用生效
pm2 start ecosystem.config.js --only api-app
pm2 restart ecosystem.config.js --only api-app
pm2 reload ecosystem.config.js --only api-app
pm2 delete ecosystem.config.js --only api-app
复制代码
在 Dockerfile 中运行以下命令,安装 pm2
RUN npm install pm2 -g
复制代码
CMD ["node", "app.js"]
复制代码
用下面这行命令替代上面这条命令:
CMD ["pm2-runtime", "app.js"]
复制代码
官网:keymetrics 操做界面以下,看文档操做入门很简单,这里我就再也不赘述了。