1. 安装 pm2

npm install pm2 -g

2. 写启动脚本

# vi ~/ecosystem.json
{
  "apps" : [{
    // Application #1
    "name"        : "api",
    "script"      : "server.js",
    "merge_logs"  : true,
    "cwd"         : "/home/web/mmf-blog-api",
    "env": {
      "NODE_ENV": "development",
      "AWESOME_SERVICE_API_TOKEN": "xxx"
    },
    "env_production" : {
       "NODE_ENV": "production"
    },
    "exec_mode"  : "cluster_mode",
    "log_date_format": "YYYY-MM-DD HH:mm Z",
    "error_file" : "./log/api-err.log",
    "out_file"   : "./log/api-out.log"
  },{
    // Application #2
    "name"        : "apiv2",
    "script"      : "server.js",
    "merge_logs"  : true,
    "cwd"         : "/home/web/mmf-blog-api-v2",
    "env": {
      "NODE_ENV": "development",
      "AWESOME_SERVICE_API_TOKEN": "xxx"
    },
    "env_production" : {
       "NODE_ENV": "production"
    },
    "exec_mode"  : "cluster_mode",
    "log_date_format": "YYYY-MM-DD HH:mm Z",
    "error_file" : "./log/apiv2-err.log",
    "out_file"   : "./log/apiv2-out.log"
  },{
    // Application #3
    "name"        : "ssr",
    "script"      : "server.js",
    "merge_logs"  : true,
    "cwd"         : "/home/web/mmf-blog-vue2-ssr",
    "max_memory_restart": "600M",
    "env": {
      "NODE_ENV": "development",
      "AWESOME_SERVICE_API_TOKEN": "xxx"
    },
    "env_production" : {
       "NODE_ENV": "production"
    },
    "exec_mode"  : "cluster_mode",
    "log_date_format": "YYYY-MM-DD HH:mm Z",
    "error_file" : "./log/ssr-err.log",
    "out_file"   : "./log/ssr-out.log"
  }]
}

常用参数说明:

apps:json 结构,apps 是一个数组,每一个数组成员就是对应一个 pm2 中运行的应用
name:应用程序的名称
cwd:应用程序所在的目录
script:应用程序的脚本路径
exec_interpreter:应用程序的脚本类型,这里使用的 shell,默认是 nodejs
min_uptime:最小运行时间,这里设置的是 60s 即如果应用程序在 60s 内退出,pm2 会认为程序异常退出,此时触发重启 max_restarts 设置数量
max_restarts:设置应用程序异常退出重启的次数,默认 15 次(从0开始计数)
max_memory_restart: 内存达到设置的阙值时, pm2 将自动重启该应用
exec_mode:应用程序启动模式,这里设置的是cluster_mode(集群),默认是fork
error_file:自定义应用程序的错误日志文件, 使用相对路径时, 相对上面设置才 cwd 路径
out_file:自定义应用程序日志文件, 使用相对路径时, 相对上面设置才 cwd 路径
pid_file:自定义应用程序的 pid 文件
watch:是否启用监控模式,默认是 false。如果设置成 true,当应用程序变动时,pm2 会自动重载。这里也可以设置你要监控的文件。
env:默认启动时,定义环境变量

3. 相关命令

  1. 启动
    # pm2 start ecosystem.json --env production  #以加载 json 脚本方式启动, 根据 json 文件可以同时启动多个项目
    # ---其他启动方式---
    # pm2 start app.js
    # pm2 start app.js --name my-api       #my-api为PM2进程名称
    # pm2 start app.js -i 0                #根据CPU核数启动进程个数
    # pm2 start app.js --watch             #实时监控app.js的方式启动,当app.js文件有变动时,pm2会自动reload
    
  2. 查看进程
    # pm2 list
    # pm2 show 0 或者 # pm2 info 0         #查看进程详细信息,0为PM2进程id
    
  3. 监控
    # pm2 monit
    
  4. 停止
    # pm2 stop all                        #停止PM2列表中所有的进程
    # pm2 stop 0                          #停止PM2列表中进程为0的进程
    
  5. 重载
    # pm2 reload all                      #重载PM2列表中所有的进程
    # pm2 reload 0                        #重载PM2列表中进程为0的进程
    
  6. 重启
    # pm2 restart all                     #重启PM2列表中所有的进程
    # pm2 restart 0                       #重启PM2列表中进程为0的进程
    
  7. 删除PM2进程
    # pm2 delete 0                        #删除PM2列表中进程为0的进程
    # pm2 delete all                      #删除PM2列表中所有的进程
    
  8. 日志操作
    # pm2 logs [--raw]                    #查看所有进程的日志
    # pm2 flush                           #清空所有日志文件
    # pm2 reloadLogs                      #重新加载所有日志
    
  9. 升级PM2
    # npm install pm2@lastest -g          #安装最新的PM2版本
    # pm2 updatePM2                       #升级pm2
    
  10. 更多命令参数请查看帮助
    # pm2 --help
    
发表评论
68259164
非常优秀
Josh
棒棒哦
小王
111