Open jackieli123723 opened 7 years ago
npm install pm2 -g
# 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:默认启动时,定义环境变量
# 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
# pm2 list # pm2 show 0 或者 # pm2 info 0 #查看进程详细信息,0为PM2进程id
# pm2 monit
# pm2 stop all #停止PM2列表中所有的进程 # pm2 stop 0 #停止PM2列表中进程为0的进程
# pm2 reload all #重载PM2列表中所有的进程 # pm2 reload 0 #重载PM2列表中进程为0的进程
# pm2 restart all #重启PM2列表中所有的进程 # pm2 restart 0 #重启PM2列表中进程为0的进程
# pm2 delete 0 #删除PM2列表中进程为0的进程 # pm2 delete all #删除PM2列表中所有的进程
# pm2 logs [--raw] #查看所有进程的日志 # pm2 flush #清空所有日志文件 # pm2 reloadLogs #重新加载所有日志
# npm install pm2@lastest -g #安装最新的PM2版本 # pm2 updatePM2 #升级pm2
# pm2 --help
1. 安装 pm2
2. 写启动脚本
常用参数说明:
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. 相关命令