若是直接经过node app来启动,若是报错了可能直接停在整个运行,supervisor感受只是拿来用做开发环境的。再网上找到pm2.目前彷佛最多见的线上部署nodejs项目的有forever,pm2这两种。
使用场合:node
npm install pm2@latest -g
安装好以后 须要配置全局环境ln -s opt/node.js/node-v10.13.0-linux-x64/bin/pm2 /usr/local/bin/
opt/node.js/node-v10.13.0-linux-x64/bin/pm2是我node安装目录 /usr/local/bin/全局环境配置目录
pm2 list //这个命令自己是列举出全部用pm2启动的程序linux
[root@WeiHuSrv /]# pm2 list ┌──────────┬────┬─────────┬──────┬───────┬────────┬─────────┬────────┬─────┬───────────┬──────┬──────────┐ │ App name │ id │ version │ mode │ pid │ status │ restart │ uptime │ cpu │ mem │ user │ watching │ ├──────────┼────┼─────────┼──────┼───────┼────────┼─────────┼────────┼─────┼───────────┼──────┼──────────┤ │ app │ 0 │ 1.0.0 │ fork │ 17362 │ online │ 0 │ 42m │ 0% │ 35.1 MB │ root │ disabled │ └──────────┴────┴─────────┴──────┴───────┴────────┴─────────┴────────┴─────┴───────────┴──────┴──────────┘ Use `pm2 show <id|name>` to get more details about an app
出现这个就成功啦web
$ pm2 logs 显示全部进程日志
$ pm2 stop all 中止全部进程
$ pm2 restart all 重启全部进程
$ pm2 reload all 0秒停机重载进程 (用于 NETWORKED 进程)
$ pm2 stop 0 中止指定的进程
$ pm2 restart 0 重启指定的进程
$ pm2 startup 产生 init 脚本 保持进程活着
$ pm2 web 运行健壮的 computer API endpoint (http://localhost:8080)
$ pm2 delete 0 杀死指定的进程
$ pm2 delete all 杀死所有进程npm
运行进程的不一样方式:
$ pm2 start app.js -i max 根据有效CPU数目启动最大进程数目
$ pm2 start app.js -i 3 启动3个进程
$ pm2 start app.js -x 用fork模式启动 app.js 而不是使用 cluster
$ pm2 start app.js -x -- -a 23 用fork模式启动 app.js 而且传递参数 (-a 23)
$ pm2 start app.js --name serverone 启动一个进程并把它命名为 serverone
$ pm2 stop serverone 中止 serverone 进程
$ pm2 start app.json 启动进程, 在 app.json里设置选项
$ pm2 start app.js -i max -- -a 23 在--以后给 app.js 传递参数
$ pm2 start app.js -i max -e err.log -o out.log 启动 并 生成一个配置文件json
关于pm2远程部署到多台机器,参考:app
http://pm2.keymetrics.io/docs...负载均衡
官网:网站