启动
$ pm2 start app.js # 启动app.js应用程序
$ pm2 start app.js -i 4 # cluster mode 模式启动4个app.js的应用实例, 4个应用程序会自动进行负载均衡
$ pm2 start app.js --name="api" # 启动应用程序并命名为 "api"
$ pm2 start app.js --watch # 当文件变化时自动重启应用
$ pm2 start script.sh # 启动 bash 脚本
pm2 start app.js --node-args="--max-old-space-size=1024"
查看进程
$ pm2 list # 列表 PM2 启动的所有的应用程序
$ pm2 show [app-name] # 显示应用程序的所有信息
监控
$ pm2 monit # 显示每个应用程序的CPU和内存占用情况
日志
$ pm2 logs # 显示所有应用程序的日志
$ pm2 logs [app-name] # 显示指定应用程序的日志
$ pm2 flush # 清空所有日志文件
停止
$ pm2 stop all # 停止所有的应用程序
$ pm2 stop 0 # 停止 id为 0的指定应用程序
重载
$ pm2 reload all # 重启 cluster mode下的所有应用
$ pm2 gracefulReload all # Graceful reload all apps in cluster mode
$ pm2 reload pm2.json --update-env #配置修改后使用 --update-env 重载, 否则新配置如"cron_restart"可能不会生效
重启
$ pm2 restart all # 重启所有应用
删除应用
$ pm2 delete all # 关闭并删除所有应用
$ pm2 delete 0 # 删除指定应用 id 0
其他
$ pm2 scale api 10 # 把名字叫api的应用扩展到10个实例
$ 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
$ pm2 deploy app.json prod setup # Setup "prod" remote server
$ pm2 deploy app.json prod # Update "prod" remote server
$ pm2 deploy app.json prod revert 2 # Revert "prod" remote server by 2
$ pm2 module:generate [name] # Generate sample module with name [name]
$ pm2 install pm2-logrotate # Install module (here a log rotation system)
$ pm2 uninstall pm2-logrotate # Uninstall module
$ pm2 publish # Increment version, git push and npm publish
pm2.json
{
"apps": [
{
"name": "名称",
"script": "脚本名.py",
"instances": 1,
"interpreter": "./.venv/bin/python",
"autorestart": true,
"watch": ["main.py"], # 监听文件变更
"cron_restart": "0 0 * * *", # 每天0点 定时重启
"merge_logs": false, # 是否合并文件, false时 按pm2 id拆分日志文件, 如error_1.log
"log_date_format": "YYYY-MM-DD HH:mm Z", # 日志日期格式
"error_file": "logs/error.log", # 错误日志文件
"out_file": "logs/output.log" # 日志文件 当error_file和out_file配置一样时, 可输出到同一个文件
}
]
}
pm2-logrotate 日志切割
pm2 install pm2-logrotate
pm2 conf # 查询配置
配置参数:
pm2 set pm2-logrotate:max_size 10M # 单个文件最大10M
pm2 set pm2-logrotate:retain 30 # 保留30个历史文件
pm2 set pm2-logrotate:compress true # 启用压缩
pm2 set pm2-logrotate:dateFormat YYYY-MM-DD_HH-mm-ss # 设置日志文件名格式
pm2 set pm2-logrotate:workerInterval 30 # 每30秒检查日志文件大小
pm2 set pm2-logrotate:rotateInterval '0 0 * * *' # 每天0点执行
pm2 set pm2-logrotate:rotateModule true
手动触发日志切割
pm2 reloadLogs