服务

发布于 更新于

AI总结: 本文介绍了PM2的基本使用方法,包括启动、查看进程、监控、日志管理、停止、重载、重启、删除应用及其他功能的命令。具体命令包括启动应用程序、设置集群模式、监控资源使用、查看和清理日志、管理应用的生命周期,以及使用pm2-logrotate进行日志切割和管理。此外,还提供了pm2.json配置文件的示例,展示了如何配置应用的属性和日志管理。 优化建议:可以将命令分组并提供简要描述,以便用户快速查找所需功能。例如,可以将启动命令、监控命令、日志命令等分别归类,并在每组前添加简短的说明。同时,考虑增加示例应用场景,以帮助用户理解每个命令的实际应用。

启动

$ 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 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:workerInterval 30 # 每30秒检查日志文件大小
pm2 set pm2-logrotate:rotateInterval '0 0 * * *' # 每天0点执行

相关链接

  1. pm2-logrotate