PM2 是什么

PM2(Process Manager 2)是具有内置负载均衡器的 Node.js 应用程序的生产运行时和进程管理器。它允许您永久保持应用程序活跃,无需停机即可重新加载它们,并促进常见的 Devops 任务

PM2 特性

  • 日志管理:应用程序日志保存在服务器的硬盘中 ~/.pm2/logs/
  • 负载均衡:PM2 可以通过创建共享同一服务器端口的多个子进程来扩展您的应用程序。这样做还允许您以零秒停机时间重新启动应用程序
  • 终端监控:可以在终端中监控您的应用程序并检查应用程序运行状况(CPU 使用率,使用的内存,请求/分钟等)
  • SSH部署:自动部署,避免逐个在所有服务器中进行 ssh
  • 静态服务:支持静态服务器功能
  • 多平台支持:适用于 Linux(稳定)和 macOS(稳定)和 Windows(稳定)

PM2 安装

- npm install pm2 -g
 
- yarn global add pm2
 
- apt update && apt install sudo curl && curl -sL https://raw.githubusercontent.com/Unitech/pm2/master/packager/setup.deb.sh | sudo -E bash -

PM2 命令

  • 启动服务:
pm2 start app.js                    //启动 app.js 应用
pm2 start app.js --name demo        //启动应用并设置name
pm2 start app.sh                    //脚本启动
  • 停止服务:
pm2 stop all                        //停止所有应用
pm2 stop [AppName]                  //根据应用名停止指定应用
pm2 stop [ID]                       //根据应用id停止指定应用
  • 删除应用:
pm2 delete all                      //关闭并删除应用
pm2 delete [AppName]                //根据应用名关闭并删除应用
pm2 delete [ID]                     //根据应用ID关闭并删除应用
  • 创建开机自启动:
pm2 startup
  • 更新 PM2:
pm2 updatePM2
pm2 update
  • 监听模式:
pm2 start app.js --watch            //当文件发生变化,自动重启
  • 更新 PM2:
pm2 updatePM2
pm2 update
  • 静态服务器:
pm2 serve ./dist 9090               //将目录dist作为静态服务器根目录,端口为9090
  • 启用群集模式(自动负载均衡):
//max 表示PM2将自动检测可用CPU的数量并运行尽可能多的进程
//max可以自定义,如果是4核CPU,设置为2者占用2个
pm2 start app.js -i max
  • 重新启动:
pm2 restart app.js            //同时杀死并重启所有进程。短时间内服务不可用。生成环境推荐使用reload
  • 0 秒停机重新加载:
pm2 reload app.js           //重新启动所有进程,始终保持至少一个进程在运行
pm2 gracefulReload all      //优雅地以群集模式重新加载所有应用程序
  • 查看启动列表:
pm2 list
  • 查看每个应用程序占用情况:
pm2 monit
  • 显示应用程序所有信息:
pm2 show [Name]             //根据 name 查看
pm2 show [ID]               //根据 id 查看
  • 日志查看:
pm2 logs                    //查看所有应用日志
pm2 logs [Name]             //根据指定应用名查看应用日志
pm2 logs [ID]               //根据指定应用ID查看应用日志
  • 保存当前应用列表:
pm2 save
  • 重启保存的应用列表:
pm2 resurrect
  • 清除保存的应用列表:
pm2 cleardump
  • 保存并恢复 PM2 进程:
pm2 update

PM2 配置文件方式

  • 生成示例配置文件:
pm2 ecosystem        //生成一个示例JSON配置文件
pm2 init
  • 配置文件示例:(实际使用自行删除)

module.exports = {
    apps : [{
        name      : 'API',      //应用名
        script    : 'app.js',   //应用文件位置
        env: {
            PM2_SERVE_PATH: ".",    //静态服务路径
            PM2_SERVE_PORT: 8080,   //静态服务器访问端口
            NODE_ENV: 'development' //启动默认模式
        },
        env_production : {
            NODE_ENV: 'production'  //使用production模式 pm2 start ecosystem.config.js --env production
        },
        instances:"max",          //将应用程序分布在所有CPU核心上,可以是整数或负数
        watch:true,               //监听模式
        output: './out.log',      //指定日志标准输出文件及位置
        error: './error.log',     //错误输出日志文件及位置,pm2 install pm2-logrotate进行日志文件拆分
        merge_logs: true,         //集群情况下,可以合并日志
        log_type:"json",          //日志类型
        log_date_format: "DD-MM-YYYY",  //日志日期记录格式
    }],
    deploy : {
        production : {
            user : 'node',                      //ssh 用户
            host : '212.83.163.1',              //ssh 地址
            ref  : 'origin/master',             //GIT远程/分支
            repo : 'git@github.com:repo.git',   //git地址
            path : '/var/www/production',       //服务器文件路径
            post-deploy : 'npm install && pm2 reload ecosystem.config.js --env production'  //部署后的动作
        }
    }
};