http://www.cnblogs.com/lan-writenbook/p/5473345.html
https://mp.weixin.qq.com/debug/wxadoc/dev/api/
http://blog.csdn.net/lilong_dream/article/details/23356513
http://www.linuxprobe.com/chapter-03.html
http://www.cnblogs.com/fnng/category/410088.html
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-680e62-1511421667535)]
pm2 list #查看pm2進(jìn)程,如下圖:
[圖片上傳失敗...(image-20bc39-1511421667535)]
七、備注
其他可參數(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 )