PM2
是由北京邦永科技有限公司
自主研发的一套管理集成系统。用于提升管理水平和管理效率。
PM2
是一个带有负载均衡功能的 Node
应用的进程管理器。我们都知道nodejs
是单进程执行的,当程序出现错误死掉之后需要能够自动,这时候就需要PM2
了。当然进程管理工具有很多,例如Forever
、 Python
底层写的Supervisorctl
等等...
PM2
的特点:
- 工具小巧
- 内建负载均衡(使用Node cluster 集群模块)
- 后台运行
- 0秒停机重载,我理解大概意思是维护升级的时候不需要停机.
- 具有
Ubuntu
和CentOS
的启动脚本 - 停止不稳定的进程(避免无限循环)
- 控制台检测
- 提供
HTTP API
- 远程控制和实时的接口
API
(Nodejs
模块,允许和PM2进程管理器
交互 )
一、安装
# 全局安装
$ npm install pm2 -g
# 国内可以使用 cnpm install pm2 -g
Ubuntu下安装基本完毕,但是Centos下全局安装完毕后还需要配置全局变量,不然使用pm2命令时系统会告知没有这个命令...
Centos安装完毕后会有两条警告(Centos才看这下面一段)
npm WARN optional SKIPPING OPTIONAL DEPENDENCY: fsevents@1.1.3 (node_modules/pm2/node_modules/fsevents):
npm WARN notsup SKIPPING OPTIONAL DEPENDENCY: Unsupported platform for fsevents@1.1.3: wanted {"os":"darwin","arch":"any"} (current: {"os":"linux","arch":"x64"})
npm
安装的时候有警告可以直接忽略。这里其实也是。我们只需配置一下环境变量就可以了
$ ln -s /usr/local/src/node-v10.1.0-linux-x64/bin/pm2 /usr/local/bin/pm2
# 每个人因自己配置地址而异,但基本上会是这个地址...
配置完成后
$ pm2 list
# 查看守护进程的列表,主要检查环境变量是否生效
二、基本用法及命令介绍
$ pm2 start index.js # 启动index.js程序
$ pm2 start index.js -i 3 # cluster mode 模式启动3个index.js的应用实例
# 3个应用程序会自动进行负载均衡
$ pm2 start index.js --name="index" # 启动应用程序并命名为 "index"
$ pm2 start index.js --watch # 当文件变化时自动重启应用
$ pm2 start script.sh # 启动 bash 脚本
$ pm2 list # 列表 PM2 启动的所有的应用程序
$ pm2 monit # 显示每个应用程序的CPU和内存占用情况
$ pm2 show [app-name] # 显示应用程序的所有信息
$ pm2 logs # 显示所有应用程序的日志
$ pm2 logs [app-name] # 显示指定应用程序的日志
$ pm2 flush # 清空所有日志文件
$ pm2 stop all # 停止所有的应用程序
$ pm2 stop 0 # 停止 id为 0的指定应用程序
$ pm2 restart all # 重启所有应用
$ pm2 reload all # 重启 cluster mode下的所有应用
$ pm2 gracefulReload all # Graceful reload all apps in cluster mode
$ pm2 delete all # 关闭并删除所有应用
$ pm2 delete 0 # 删除指定应用 id 0
$ pm2 scale api 100 # 把名字叫api的应用扩展到100个实例
$ pm2 reset [app-name] # 重置重启数量
$ pm2 startup # 创建开机自启动命令
$ pm2 save # 保存当前应用列表
$ pm2 resurrect # 重新加载保存的应用列表
$ pm2 update # Save processes, kill PM2 and restore processes
$ pm2 generate # Generate a sample json configuration file
结束语:守护进程工具能守护的东西很多,例如:nodeJs程序、消息队列程序、Shell脚本等...