关于pm2的fork启动模式和nodejs cluster pm2模式的区别

&&国之画&&&& &&&&&&
&& &&&&&&&&&&&&&&
鲁ICP备号-4
打开技术之扣,分享程序人生!nodejs插件之pm2
pm2 是一个带有负载均衡功能的Node应用的进程管理器.
当你要把你的独立代码利用全部的服务器上的所有CPU,并保证进程永远都活着,0秒的重载,
PM2是完美的。它非常适合IaaS结构,但不要把它用于PaaS方案(随后将开发Paas的解决方案).
备注:SaaS、PaaS和IaaS是云服务模式。
&&&&&&&&SaaS
软件即服务,例如Google的 Gmail 邮箱服务.面向应用型用户.
&&&&&&&&PaaS
平台即服务.例如Google的GAE,面向开发型用户
&&&&&&&&IaaS
基础架构即服务,例如亚马逊的AWS,IaaS对于不知道新推出的应用程序/网站会有多成功的创业公司来说非常有用
&&&&&&请参考
主要特性:
内建负载均衡(使用Node cluster 集群模块)
0秒停机重载,我理解大概意思是维护升级的时候不需要停机.
具有Ubuntu和CentOS 的启动脚本
停止不稳定的进程(避免无限循环)
控制台检测
提供 HTTP API
远程控制和实时的接口API ( Nodejs 模块,允许和PM2进程管理器交互 )
测试过Nodejs v0.11 v0.10 v0.8版本,兼容CoffeeScript,基于Linux 和MacOS.
npm install -g pm2
$ npm install pm2 -g # 命令行安装 pm2
$ pm2 start app.js -i 4 #后台运行pm2,启动4个app.js
&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&#
也可以把'max' 参数传递给 start
&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&#
正确的进程数目依赖于Cpu的核心数目
$ pm2 start app.js --name my-api # 命名进程
$ pm2 list # 显示所有进程状态
$ pm2 monit # 监视所有进程
$ 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 ()
$ pm2 delete 0 # 杀死指定的进程
$ pm2 delete all # 杀死全部进程
运行进程的不同方式:
$ 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
$ 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 # 启动 并
生成一个配置文件
你也可以执行用其他语言编写的app ( fork 模式):
$ pm2 start my-bash-script.sh -x --interpreter bash
$ pm2 start my-python-script.py -x --interpreter python
0秒停机重载:
这项功能允许你重新载入代码而不用失去请求连接。
仅能用于web应用
运行于Node 0.11.x版本
运行于 cluster 模式(默认模式)
$ pm2 reload all
CoffeeScript:
$ pm2 start my_app.coffee #这就是全部
PM2准备好为产品级服务了吗?
只需在你的服务器上测试
$ git clone
$ npm install # 或者 npm install --dev ,如果devDependencies 没有安装
$ npm test
列出由pm2管理的所有进程信息,还会显示一个进程会被启动多少次,因为没处理的异常。
监视每个node进程的CPU和内存的使用情况。
已投稿到:
以上网友发言只代表其个人观点,不代表新浪网的观点或立场。nodejs高大上的部署方式-PM2
 今天坐在右边的同事忽然欣喜的跟我说:嘿,推荐你个好东西,用PM2试试,比forever高端多了。表示一向落后于时尚的科技前沿的我认真的回答:什么?PM2.5还这么严重,PM2又出来了!
  要不是都已习惯了我的二,这气氛还真要囧好一会儿~~呵呵&&
  先说说平时我都是怎么部署程序的吧
  1、最常用的属nohup了,其实就是在后台执行进程,末尾加个&
[zhoujie@ops-dev ~]$ nohup node /home/zhoujie/ops/app.js &
[1] 31490nohup: ignoring input and appending output to `nohup.out'
即此时程序已启动,直接访问即可,原程序的的标准输出被自动改向到当前目录下的nohup.out文件,起到了log的作用。该命令可以在你退出帐户/关闭终端之后继续运行相应的进程。nohup就是不挂起的意思( no hang up)。
该命令的一般形式为:nohup command &
  这个不太靠谱的样子,经常默默的进程在后台就挂了
  2、用screen另开一个屏幕,这种方式可以直接在屏幕上看到程序运行情况
给该应用程序开个screen,如:screen -r ops ,用npm start启动,
退出该后台:ctrl + a,再按d,可不能直接ctrl +c,否则就退出了
这种方式很不专业,呵呵,不过方便看在生产环境的操作。
这个本质上用的forever,package.json里配置的:
& &scripts&: {
& & &start&: &forever app.js&,
& & &test&: &supervisor app.js&
  3、PM2
使用它要先安装它,用root账号和全局模式安装一下:
npm install -g pm2
用它来启动程序(在当前目录下可以直接启动,pm2 start app.js --name uops)
[zhoujie@ops-dev uops]$ pm2 start app.js&
[PM2] Spawning PM2 daemon
[PM2] Success
[PM2] Process app.js launched
┌──────────┬────┬──────┬─────┬────────┬───────────┬────────┬─────────────┬──────────┐
│ App name │ id │ mode │ PID │ status │ restarted │ uptime │ & & &memory │ watching │
├──────────┼────┼──────┼─────┼────────┼───────────┼────────┼─────────────┼──────────┤
│ app & & &│ 0 &│ fork │ 308 │ online │ & & & & 0 │ 0s & & │ 21.879 MB & │ disabled │
└──────────┴────┴──────┴─────┴────────┴───────────┴────────┴─────────────┴──────────┘
&Use `pm2 info &id|name&` to get more details about an app
[zhoujie@ops-dev uops]$
看,它显示了Success,程序已经默默的成功的启动了,可以实时监控程序的运行,比如执行个pm2 restart,则上述restarted那栏变成1,可以显示程序运行了多长时间、占用内存大小,实在是太赞啦!
终止程序也很简单:pm2 stop&
列举出所有用pm2启动的程序:pm2 list
[zhoujie@ops-dev uops]$ pm2 list
┌──────────┬────┬──────┬─────┬────────┬───────────┬────────┬─────────────┬──────────┐
│ App name │ id │ mode │ PID │ status │ restarted │ uptime │ & & &memory │ watching │
├──────────┼────┼──────┼─────┼────────┼───────────┼────────┼─────────────┼──────────┤
│ app & & &│ 0 &│ fork │ 984 │ online │ & & & & 1 │ 3s & & │ 64.141 MB & │ disabled │
└──────────┴────┴──────┴─────┴────────┴───────────┴────────┴─────────────┴──────────┘
&Use `pm2 info &id|name&` to get more details about an app
查看启动程序的详细信息:pm2 describe id
[zhoujie@ops-dev uops]$ pm2 desc 0
Describing process with pid 0 - name app
┌───────────────────┬─────────────────────────────────────────┐
│ status & & & & & &│ online & & & & & & & & & & & & & & & & &│
│ name & & & & & & &│ app & & & & & & & & & & & & & & & & & & │
│ id & & & & & & & &│ 0 & & & & & & & & & & & & & & & & & & & │
│ path & & & & & & &│ /home/zhoujie/uops/app.js & & & & & & & │
│ args & & & & & & &│ & & & & & & & & & & & & & & & & & & & & │
│ exec cwd & & & & &│ /home/zhoujie/uops & & & & & & & & & & &│
│ error log path & &│ /home/zhoujie/.pm2/logs/app-error-0.log │
│ out log path & & &│ /home/zhoujie/.pm2/logs/app-out-0.log & │
│ pid path & & & & &│ /home/zhoujie/.pm2/pids/app-0.pid & & & │
│ mode & & & & & & &│ fork_mode & & & & & & & & & & & & & & & │
│ node v8 arguments │ & & & & & & & & & & & & & & & & & & & & │
│ watch & reload & &│ ✘ & & & & & & & & & & & & & & & & & & & │
│ interpreter & & & │ node & & & & & & & & & & & & & & & & & &│
│ restarts & & & & &│ 1 & & & & & & & & & & & & & & & & & & & │
│ unstable restarts │ 0 & & & & & & & & & & & & & & & & & & & │
│ uptime & & & & & &│ 93s & & & & & & & & & & & & & & & & & & │
│ created at & & & &│ T09:41:25.672Z & & & & & & & &│
└───────────────────┴─────────────────────────────────────────┘
[zhoujie@ops-dev uops]$&
通过pm2 list命令来观察所有运行的进程以及它们的状态已经足够好了.但是怎么来追踪它们的资源消耗呢?别担心,用这个命令:pm2 monit
可以得到进程(以及集群)的CPU的使用率和内存占用(ctrl +c 退出)
实时集中log处理:pm2 logs
强大API: pm2 web
你想要监控所有被PM2管理的进程,而且同时还想监控运行这些进程的机器的状态,
[zhoujie@ops-dev uops]$ pm2 web
Launching web interface on port 9615
[PM2] Process /usr/local/node/lib/node_modules/pm2/lib/HttpInterface.js launched
[PM2] Process launched
┌────────────────────┬────┬──────┬──────┬────────┬───────────┬────────┬─────────────┬──────────┐
│ App name & & & & & │ id │ mode │ PID &│ status │ restarted │ uptime │ & & &memory │ watching │
├────────────────────┼────┼──────┼──────┼────────┼───────────┼────────┼─────────────┼──────────┤
│ app & & & & & & & &│ 0 &│ fork │ 984 &│ online │ & & & & 1 │ 9m & & │ 74.762 MB & │ disabled │
│ pm2-http-interface │ 1 &│ fork │ 1878 │ online │ & & & & 0 │ 0s & & │ 15.070 MB & │ disabled │
└────────────────────┴────┴──────┴──────┴────────┴───────────┴────────┴─────────────┴──────────┘
&Use `pm2 info &id|name&` to get more details about an app
启动程序的时候顺便在访问:http://localhost:9615
擦,我眼睛被亮瞎了,这么炫酷,竟然把部署的服务器的信息和程序的信息都显示出来了:
这东西对程序运行的监控页面的开发实在是太有帮助了,呵呵~~
  好吧,我承认我有点失控了,前面说的有点混乱,我愿意重新把命令整理一遍:
安装:npm install -g pm2
启动程序:pm2 start &app_name|id|all&
列举进程:pm2 list
退出程序:pm2 stop &app_name|id|all&
重起应用:pm2 restart
程序信息:pm2 describe id|all
监控:pm2 monit
实时集中log处理: pm2 logs
API:pm2 web (端口:9615 )
(window.slotbydup=window.slotbydup || []).push({
id: '2467140',
container: s,
size: '1000,90',
display: 'inlay-fix'
(window.slotbydup=window.slotbydup || []).push({
id: '2467141',
container: s,
size: '1000,90',
display: 'inlay-fix'
(window.slotbydup=window.slotbydup || []).push({
id: '2467142',
container: s,
size: '1000,90',
display: 'inlay-fix'
(window.slotbydup=window.slotbydup || []).push({
id: '2467143',
container: s,
size: '1000,90',
display: 'inlay-fix'
(window.slotbydup=window.slotbydup || []).push({
id: '2467148',
container: s,
size: '1000,90',
display: 'inlay-fix'

我要回帖

更多关于 pm2 fork cluster 的文章

 

随机推荐