服务 Linux

发布于 更新于

AI总结: 本文介绍了使用PM2管理Node.js应用程序的各种命令,包括启动、查看进程、监控、日志管理、停止、重载、重启和删除应用等功能。PM2支持集群模式、自动重启和日志管理,用户可以通过pm2.json配置文件来设定应用的基本信息和行为。还介绍了pm2-logrotate模块的安装和配置,用于管理日志文件的大小和保留策略。文中未提及的是,使用PM2时需确保Node.js环境已正确配置,且部分命令可能需要管理员权限。

启动

$ 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  

相关链接

  1. pm2-logrotate