<<編程基礎(chǔ)-語言JavaScript.Nodejs.Mobile>>
https://github.com/openstf
<pre>
pm2和forever是啟動(dòng)Nodejs服務(wù)常用到的兩個(gè)工具。使用這兩個(gè)指令可以使node服務(wù)在后臺(tái)運(yùn)行(類似于linux的nohup),另外它們可以在服務(wù)因異?;蚱渌虮粴⒌艉筮M(jìn)行自動(dòng)重啟。 由于Node的單線程特征,自動(dòng)重啟能很大程度上的提高它的健壯性。
本文不對(duì)比兩者工具優(yōu)劣,只是結(jié)合自己的使用,簡要介紹如何在工程部署時(shí)更好的使用pm2。
基本指令
npm install pm2 -g : 全局安裝。
pm2 start app.js : 啟動(dòng)服務(wù),入口文件是app.js。
pm2 start app.js -i [n] --name [name] : 啟動(dòng)n個(gè)進(jìn)程,名字命名為name。
npm restart [name or id] : 重啟服務(wù)。
npm reload [name or id] : 和rastart功能相同,但是可以實(shí)現(xiàn)0s的無縫銜接;如果有nginx的使用經(jīng)驗(yàn),可以對(duì)比nginx reload指令。
pm2 start app.js --max_memory_restart 1024M : 當(dāng)內(nèi)存超過1024M時(shí)自動(dòng)重啟。 如果工程中有比較棘手的內(nèi)存泄露問題,這個(gè)算是一個(gè)折中方案。
pm2 monit : 對(duì)服務(wù)進(jìn)行監(jiān)控。
更多的指令可以參考 PM2 介紹
高級(jí)用法
pm2支持配置文件啟動(dòng):
pm2 ecosystem: 生成配置文件ecosystem.json
pm2 startOrRestart /file/path/ecosystem.json : 通過配置文件啟動(dòng)服務(wù)
如下是我開發(fā)時(shí)ecosystem.json的內(nèi)容:
{
/**
* Application configuration section
* http://pm2.keymetrics.io/docs/usage/application-declaration/
* 多個(gè)服務(wù),依次放到apps對(duì)應(yīng)的數(shù)組里
*/
apps : [
// First application
{
name : "nova",
max_memory_restart: "300M",
script : "/root/nova/app.js",
out_file : "/logs/nova_out.log",
error_file : "/logs/nova_error.log",
instances : 4,
exec_mode : "cluster",
env: {
NODE_ENV: "production"
}
}
]
}
上述采用cluster模式啟動(dòng)了4個(gè)服務(wù)進(jìn)程;如果服務(wù)占用的內(nèi)存超過300M,會(huì)自動(dòng)進(jìn)行重啟。
監(jiān)控工具
pm2的監(jiān)控功能是其一大特色,它提供的監(jiān)控服務(wù)Keymetrics monitoring 很酷炫,感興趣的可以配置玩一下。
一些思考
1. 服務(wù)進(jìn)程數(shù)
至于要啟動(dòng)幾個(gè)進(jìn)程,可以通過服務(wù)器的內(nèi)核數(shù)進(jìn)行確定,幾個(gè)內(nèi)核就啟動(dòng)幾個(gè)服務(wù)。指令如下:
# 查看物理CPU個(gè)數(shù)
cat /proc/cpuinfo| grep "physical id" | sort| uniq | wc -l
# 查看每個(gè)物理CPU中core的個(gè)數(shù)(即核數(shù))
cat /proc/cpuinfo| grep "cpu cores"| uniq
# 查看邏輯CPU的個(gè)數(shù)
cat /proc/cpuinfo| grep "processor"| wc -l
當(dāng)然可以啟動(dòng)多個(gè)端口,一個(gè)端口號(hào)對(duì)應(yīng)一個(gè)服務(wù),這樣的話就需要nignx來做負(fù)載均衡了。
2. 是否需要nginx
nginx可以做的事情主要有兩個(gè):
反向代理,實(shí)現(xiàn)簡單的負(fù)載均衡: 如果有多臺(tái)服務(wù)器或者一臺(tái)服務(wù)器多個(gè)端口,可以考慮用nginx。
靜態(tài)資源緩存:把一些靜態(tài)資源(如靜態(tài)頁面,js等資源文件)放到nginx里,可以極大的提高服務(wù)的性能。
3. 自動(dòng)化部署
通過shell腳本實(shí)現(xiàn)資源拉取、服務(wù)重啟、nginx緩存更新等操作,再配合pm2的監(jiān)控功能,就初步達(dá)到了一個(gè)后端工程部署的標(biāo)配了。
參考資料:
pm2是非常優(yōu)秀工具,它提供對(duì)基于node.js的項(xiàng)目運(yùn)行托管服務(wù)。它基于命令行界面,提供很多特性: 內(nèi)置的負(fù)載均衡器等等,下面我們就一起來看看吧。
一、簡介
pm2是一個(gè)帶有負(fù)載均衡功能的應(yīng)用進(jìn)程管理器,類似有Supervisor,forever。
二、安裝
Linux Binaries下載地址:https://nodejs.org/dist
cd oneinstack/src
wget https://nodejs.org/dist/v4.2.4/node-v4.2.4-linux-x64.tar.gz
tar xzf node-v4.2.4-linux-x64.tar.gz
cp node-v4.2.4-linux-x64/bin/node /usr/local/bin/
cp -R node-v4.2.4-linux-x64/lib/node_modules /usr/local/lib/
ln -s /usr/local/lib/node_modules/npm/bin/npm-cli.js /usr/local/bin/npm
npm install pm2@latest -g #安裝最新版本pm2模塊
PS: 如果你的主機(jī)無法連接公網(wǎng),先找到能連公網(wǎng)的主機(jī)安裝上面的方法安裝pm2,然后拷貝到你要安裝的主機(jī)。拷貝如下目錄:
/usr/local/bin/node
/usr/local/lib/node_modules
再創(chuàng)建相關(guān)軟連接
三、PM2常用命令
假設(shè)你現(xiàn)在已經(jīng)寫好了一個(gè)app.js的文件,需要啟動(dòng),你可以使用pm2進(jìn)行管理
1. 啟動(dòng)
pm2 start app.js
pm2 start app.js --name my-api #my-api為PM2進(jìn)程名稱
pm2 start app.js -i 0 #根據(jù)CPU核數(shù)啟動(dòng)進(jìn)程個(gè)數(shù)
pm2 start app.js --watch #實(shí)時(shí)監(jiān)控app.js的方式啟動(dòng),當(dāng)app.js文件有變動(dòng)時(shí),pm2會(huì)自動(dòng)reload
2. 查看進(jìn)程
pm2 list
pm2 show 0 或者 # pm2 info 0 #查看進(jìn)程詳細(xì)信息,0為PM2進(jìn)程id
3. 監(jiān)控
pm2 monit
4. 停止
pm2 stop all #停止PM2列表中所有的進(jìn)程
pm2 stop 0 #停止PM2列表中進(jìn)程為0的進(jìn)程
5. 重載
pm2 reload all #重載PM2列表中所有的進(jìn)程
pm2 reload 0 #重載PM2列表中進(jìn)程為0的進(jìn)程
6. 重啟
pm2 restart all #重啟PM2列表中所有的進(jìn)程
pm2 restart 0 #重啟PM2列表中進(jìn)程為0的進(jìn)程
7. 刪除PM2進(jìn)程
pm2 delete 0 #刪除PM2列表中進(jìn)程為0的進(jìn)程
pm2 delete all #刪除PM2列表中所有的進(jìn)程
8. 日志操作
pm2 logs [--raw] #Display all processes logs in streaming
pm2 flush #Empty all log file
pm2 reloadLogs #Reload all logs
9. 升級(jí)PM2
npm install pm2@lastest -g #安裝最新的PM2版本
pm2 updatePM2 #升級(jí)pm2
10. 更多命令參數(shù)請(qǐng)查看幫助
pm2 --help
四、PM2目錄結(jié)構(gòu)
默認(rèn)的目錄是:當(dāng)前用于的家目錄下的.pm2目錄(此目錄可以自定義,請(qǐng)參考:五、自定義啟動(dòng)文件),詳細(xì)信息如下:
$HOME/.pm2 #will contain all PM2 related files
$HOME/.pm2/logs #will contain all applications logs
$HOME/.pm2/pids #will contain all applications pids
$HOME/.pm2/pm2.log #PM2 logs
$HOME/.pm2/pm2.pid #PM2 pid
$HOME/.pm2/rpc.sock #Socket file for remote commands
$HOME/.pm2/pub.sock #Socket file for publishable events
$HOME/.pm2/conf.js #PM2 Configuration
五、自定義啟動(dòng)文件
創(chuàng)建一個(gè)test.json的示例文件,格式如下:
{
"apps":
{
"name": "test",
"cwd": "/data/wwwroot/nodejs",
"script": "./test.sh",
"exec_interpreter": "bash",
"min_uptime": "60s",
"max_restarts": 30,
"exec_mode" : "cluster_mode",
"error_file" : "./test-err.log",
"out_file": "./test-out.log",
"pid_file": "./test.pid"
"watch": false
}
}
說明:
apps:json結(jié)構(gòu),apps是一個(gè)數(shù)組,每一個(gè)數(shù)組成員就是對(duì)應(yīng)一個(gè)pm2中運(yùn)行的應(yīng)用
name:應(yīng)用程序的名稱
cwd:應(yīng)用程序所在的目錄
script:應(yīng)用程序的腳本路徑
exec_interpreter:應(yīng)用程序的腳本類型,這里使用的shell,默認(rèn)是nodejs
min_uptime:最小運(yùn)行時(shí)間,這里設(shè)置的是60s即如果應(yīng)用程序在60s內(nèi)退出,pm2會(huì)認(rèn)為程序異常退出,此時(shí)觸發(fā)重啟max_restarts設(shè)置數(shù)量
max_restarts:設(shè)置應(yīng)用程序異常退出重啟的次數(shù),默認(rèn)15次(從0開始計(jì)數(shù))
exec_mode:應(yīng)用程序啟動(dòng)模式,這里設(shè)置的是cluster_mode(集群),默認(rèn)是fork
error_file:自定義應(yīng)用程序的錯(cuò)誤日志文件
out_file:自定義應(yīng)用程序日志文件
pid_file:自定義應(yīng)用程序的pid文件
watch:是否啟用監(jiān)控模式,默認(rèn)是false。如果設(shè)置成true,當(dāng)應(yīng)用程序變動(dòng)時(shí),pm2會(huì)自動(dòng)重載。這里也可以設(shè)置你要監(jiān)控的文件。
詳細(xì)參數(shù)列表:見附件八
六、實(shí)例
已上面的test.json為例
cat > /data/wwwroot/nodejs/test.sh << EOF
!/bin/bash
while :
do
echo "Test" >> 1.log
sleep 5
done
EOF
chmod +x test.sh #添加執(zhí)行權(quán)限
pm2 start test.json #啟動(dòng),如下圖:
[圖片上傳失敗...(image-291475-1511349583307)]
pm2 list #查看pm2進(jìn)程,如下圖:
[圖片上傳失敗...(image-1f3f2c-1511349583307)]
七、備注
其他可參數(shù)見官網(wǎng):http://pm2.keymetrics.io
====================================================================================================================
安裝:npm install -g pm2
啟動(dòng)程序:pm2 start <app_name|id|all>
列舉進(jìn)程:pm2 list
退出程序:pm2 stop <app_name|id|all>
重起應(yīng)用:pm2 restart
程序信息:pm2 describe id|all
監(jiān)控:pm2 monit
實(shí)時(shí)集中l(wèi)og處理: pm2 logs
API:pm2 web (端口:9615 )
<pre>
使用PM2來部署nodejs項(xiàng)目。
如果直接通過node app來啟動(dòng),如果報(bào)錯(cuò)了可能直接停在整個(gè)運(yùn)行,supervisor感覺只是拿來用作開發(fā)環(huán)境的。再網(wǎng)上找到pm2.目前似乎最常見的線上部署nodejs項(xiàng)目的有forever,pm2這兩種。
使用場(chǎng)合:
supervisor是開發(fā)環(huán)境用。
forever管理多個(gè)站點(diǎn),每個(gè)站點(diǎn)訪問量不大,不需要監(jiān)控。
pm2 網(wǎng)站訪問量比較大,需要完整的監(jiān)控界面。
PM2的主要特性:
內(nèi)建負(fù)載均衡(使用Node cluster 集群模塊)
后臺(tái)運(yùn)行
0秒停機(jī)重載,我理解大概意思是維護(hù)升級(jí)的時(shí)候不需要停機(jī).
具有Ubuntu和CentOS 的啟動(dòng)腳本
停止不穩(wěn)定的進(jìn)程(避免無限循環(huán))
控制臺(tái)檢測(cè)
提供 HTTP API
遠(yuǎn)程控制和實(shí)時(shí)的接口API ( Nodejs 模塊,允許和PM2進(jìn)程管理器交互 )
安裝
npm install -g pm2
用法
$ npm install -g pm2 命令行全局安裝pm2
$ pm2 start app.js 啟動(dòng)app項(xiàng)目
$ pm2 list 列出由pm2管理的所有進(jìn)程信息,還會(huì)顯示一個(gè)進(jìn)程會(huì)被啟動(dòng)多少次,因?yàn)闆]處理的異常。

$ pm2 monit 監(jiān)視每個(gè)node進(jìn)程的CPU和內(nèi)存的使用情況

$ pm2 logs 顯示所有進(jìn)程日志
$ pm2 stop all 停止所有進(jìn)程
$ pm2 restart all 重啟所有進(jìn)程
$ pm2 reload all 0秒停機(jī)重載進(jìn)程 (用于 NETWORKED 進(jìn)程)
$ pm2 stop 0 停止指定的進(jìn)程
$ pm2 restart 0 重啟指定的進(jìn)程
$ pm2 startup 產(chǎn)生 init 腳本 保持進(jìn)程活著
$ pm2 web 運(yùn)行健壯的 computer API endpoint (http://localhost:9615)
$ pm2 delete 0 殺死指定的進(jìn)程
$ pm2 delete all 殺死全部進(jìn)程
運(yùn)行進(jìn)程的不同方式:
$ pm2 start app.js -i max 根據(jù)有效CPU數(shù)目啟動(dòng)最大進(jìn)程數(shù)目
$ pm2 start app.js -i 3 啟動(dòng)3個(gè)進(jìn)程
$ pm2 start app.js -x 用fork模式啟動(dòng) app.js 而不是使用 cluster
$ pm2 start app.js -x -- -a 23 用fork模式啟動(dòng) app.js 并且傳遞參數(shù) (-a 23)
$ pm2 start app.js --name serverone 啟動(dòng)一個(gè)進(jìn)程并把它命名為 serverone
$ pm2 stop serverone 停止 serverone 進(jìn)程
$ pm2 start app.json 啟動(dòng)進(jìn)程, 在 app.json里設(shè)置選項(xiàng)
$ pm2 start app.js -i max -- -a 23 在--之后給 app.js 傳遞參數(shù)
$ pm2 start app.js -i max -e err.log -o out.log 啟動(dòng) 并 生成一個(gè)配置文件
配置pm2啟動(dòng)文件
在項(xiàng)目根目錄添加一個(gè)processes.json:
內(nèi)容如下:
{
"apps": [
{
"name": "mywork",
"cwd": "/srv/node-app/current",
"script": "bin/www",
"log_date_format": "YYYY-MM-DD HH:mm Z",
"error_file": "/var/log/node-app/node-app.stderr.log",
"out_file": "log/node-app.stdout.log",
"pid_file": "pids/node-geo-api.pid",
"instances": 6,
"min_uptime": "200s",
"max_restarts": 10,
"max_memory_restart": "1M",
"cron_restart": "1 0 * * *",
"watch": false,
"merge_logs": true,
"exec_interpreter": "node",
"exec_mode": "fork",
"autorestart": false,
"vizion": false
}
]
}
說明:
apps:json結(jié)構(gòu),apps是一個(gè)數(shù)組,每一個(gè)數(shù)組成員就是對(duì)應(yīng)一個(gè)pm2中運(yùn)行的應(yīng)用
name:應(yīng)用程序名稱
cwd:應(yīng)用程序所在的目錄
script:應(yīng)用程序的腳本路徑
log_date_format:
error_file:自定義應(yīng)用程序的錯(cuò)誤日志文件
out_file:自定義應(yīng)用程序日志文件
pid_file:自定義應(yīng)用程序的pid文件
instances:
min_uptime:最小運(yùn)行時(shí)間,這里設(shè)置的是60s即如果應(yīng)用程序在60s內(nèi)退出,pm2會(huì)認(rèn)為程序異常退出,此時(shí)觸發(fā)重啟max_restarts設(shè)置數(shù)量
max_restarts:設(shè)置應(yīng)用程序異常退出重啟的次數(shù),默認(rèn)15次(從0開始計(jì)數(shù))
cron_restart:定時(shí)啟動(dòng),解決重啟能解決的問題
watch:是否啟用監(jiān)控模式,默認(rèn)是false。如果設(shè)置成true,當(dāng)應(yīng)用程序變動(dòng)時(shí),pm2會(huì)自動(dòng)重載。這里也可以設(shè)置你要監(jiān)控的文件。
merge_logs:
exec_interpreter:應(yīng)用程序的腳本類型,這里使用的shell,默認(rèn)是nodejs
exec_mode:應(yīng)用程序啟動(dòng)模式,這里設(shè)置的是cluster_mode(集群),默認(rèn)是fork
autorestart:啟用/禁用應(yīng)用程序崩潰或退出時(shí)自動(dòng)重啟
vizion:啟用/禁用vizion特性(版本控制)
可以通過pm2 start processes.json來啟動(dòng)。
也可以把命令寫在package.json里。如下:

pm2 是一個(gè)帶有負(fù)載均衡功能的Node應(yīng)用的進(jìn)程管理器.
當(dāng)你要把你的獨(dú)立代碼利用全部的服務(wù)器上的所有CPU,并保證進(jìn)程永遠(yuǎn)都活著,0秒的重載, PM2是完美的。它非常適合IaaS結(jié)構(gòu),但不要把它用于PaaS方案(隨后將開發(fā)Paas的解決方案).
備注:SaaS、PaaS和IaaS是云服務(wù)模式。
SaaS 軟件即服務(wù),例如Google的 Gmail 郵箱服務(wù).面向應(yīng)用型用戶.
PaaS 平臺(tái)即服務(wù).例如Google的GAE,面向開發(fā)型用戶
IaaS 基礎(chǔ)架構(gòu)即服務(wù),例如亞馬遜的AWS,IaaS對(duì)于不知道新推出的應(yīng)用程序/網(wǎng)站會(huì)有多成功的創(chuàng)業(yè)公司來說非常有用
請(qǐng)參考
云服務(wù)模式:SaaS、PaaS和IaaS,哪一種適合你?
主要特性:
內(nèi)建負(fù)載均衡(使用Node cluster 集群模塊)
后臺(tái)運(yùn)行
0秒停機(jī)重載,我理解大概意思是維護(hù)升級(jí)的時(shí)候不需要停機(jī).
具有Ubuntu和CentOS 的啟動(dòng)腳本
停止不穩(wěn)定的進(jìn)程(避免無限循環(huán))
控制臺(tái)檢測(cè)
提供 HTTP API
遠(yuǎn)程控制和實(shí)時(shí)的接口API ( Nodejs 模塊,允許和PM2進(jìn)程管理器交互 )
測(cè)試過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 #后臺(tái)運(yùn)行pm2,啟動(dòng)4個(gè)app.js
# 也可以把'max' 參數(shù)傳遞給 start
# 正確的進(jìn)程數(shù)目依賴于Cpu的核心數(shù)目
$ pm2 start app.js --name my-api # 命名進(jìn)程
$ pm2 list # 顯示所有進(jìn)程狀態(tài)
$ pm2 monit # 監(jiān)視所有進(jìn)程
$ pm2 logs # 顯示所有進(jìn)程日志
$ pm2 stop all # 停止所有進(jìn)程
$ pm2 restart all # 重啟所有進(jìn)程
$ pm2 reload all # 0秒停機(jī)重載進(jìn)程 (用于 NETWORKED 進(jìn)程)
$ pm2 stop 0 # 停止指定的進(jìn)程
$ pm2 restart 0 # 重啟指定的進(jìn)程
$ pm2 startup # 產(chǎn)生 init 腳本 保持進(jìn)程活著
$ pm2 web # 運(yùn)行健壯的 computer API endpoint (
)
$ pm2 delete 0 # 殺死指定的進(jìn)程
$ pm2 delete all # 殺死全部進(jìn)程
運(yùn)行進(jìn)程的不同方式:
$ pm2 start app.js -i max # 根據(jù)有效CPU數(shù)目啟動(dòng)最大進(jìn)程數(shù)目
$ pm2 start app.js -i 3 # 啟動(dòng)3個(gè)進(jìn)程
$ pm2 start app.js -x #用fork模式啟動(dòng) app.js 而不是使用 cluster
$ pm2 start app.js -x -- -a 23 # 用fork模式啟動(dòng) app.js 并且傳遞參數(shù) (-a 23)
$ pm2 start app.js --name serverone # 啟動(dòng)一個(gè)進(jìn)程并把它命名為 serverone
$ pm2 stop serverone # 停止 serverone 進(jìn)程
$ pm2 start app.json # 啟動(dòng)進(jìn)程, 在 app.json里設(shè)置選項(xiàng)
$ pm2 start app.js -i max -- -a 23 #在--之后給 app.js 傳遞參數(shù)
$ pm2 start app.js -i max -e err.log -o out.log # 啟動(dòng) 并 生成一個(gè)配置文件
你也可以執(zhí)行用其他語言編寫的app ( fork 模式):
$ pm2 start my-bash-script.sh -x --interpreter bash
$ pm2 start my-python-script.py -x --interpreter python
0秒停機(jī)重載:
這項(xiàng)功能允許你重新載入代碼而不用失去請(qǐng)求連接。
注意:
僅能用于web應(yīng)用
運(yùn)行于Node 0.11.x版本
運(yùn)行于 cluster 模式(默認(rèn)模式)
$ pm2 reload all
CoffeeScript:
$ pm2 start my_app.coffee #這就是全部
PM2準(zhǔn)備好為產(chǎn)品級(jí)服務(wù)了嗎?
只需在你的服務(wù)器上測(cè)試
$ git clone
https://github.com/Unitech/pm2.git
$ cd pm2
$ npm install # 或者 npm install --dev ,如果devDependencies 沒有安裝
$ npm test
pm2 list
列出由pm2管理的所有進(jìn)程信息,還會(huì)顯示一個(gè)進(jìn)程會(huì)被啟動(dòng)多少次,因?yàn)闆]處理的異常。
|
|
| |
pm2 monit
監(jiān)視每個(gè)node進(jìn)程的CPU和內(nèi)存的使用情況。
|
|