目錄
1.高大上先上部署node方式:
直接通過node app
來啓動,如果報錯了可能直接停在整個運行,
supervisor感覺只是拿來用作開發環境的。
目前似乎最常見的線上部署nodejs項目的有forever,pm2這兩種。
2.使用場合:
- supervisor是開發環境用。
- forever管理多個站點,每個站點訪問量不大,不需要監控。
- pm2 網站訪問量比較大,需要完整的監控界面
3.pm2主要特性:
- 內建負載均衡(使用Node cluster 集羣模塊)
- 後臺運行
- 0秒停機重載,我理解大概意思是維護升級的時候不需要停機.
- 具有Ubuntu和CentOS 的啓動腳本
- 停止不穩定的進程(避免無限循環)
- 控制檯檢測
- 提供 HTTP API
- 遠程控制和實時的接口API ( Nodejs 模塊,允許和PM2進程管理器交互
4.使用npm/cnpm全局安裝:
npm i -g pm2
5.pm2命令使用(項目更目錄下使用):
$ pm2 start app.js
啓動app項目$ pm2 list
列出由pm2管理的所有進程信息,還會顯示一個進程會被啓動多少次,因爲沒處理的異常。$ pm2 monit
監視每個node進程的CPU和內存的使用情況$ 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:9615)$ pm2 delete 0
殺死指定的進程$ pm2 delete all
殺死全部進程
6.啓動進程的方式詳細:
$ 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
啓動 並 生成一個配置文件
7.配置pm2啓動文件:
可以通過pm2 start processes.json
來啓動。
在項目根目錄下添加文件processes.json:
{
"apps": [
{
"name": "mywork",
"cwd": "/srv/node-app/current",
"script": "bin/xxx",
"log_date_format": "YYYY-MM-DD HH:mm:ss",
"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
}
]
}
8.processes.json說明:
- apps:json結構,apps是一個數組,每一個數組成員就是對應一個pm2中運行的應用
- name:應用程序名稱
- cwd:應用程序所在的目錄
- script:應用程序的腳本路徑
- log_date_format:
- error_file:自定義應用程序的錯誤日誌文件
- out_file:自定義應用程序日誌文件
- pid_file:自定義應用程序的pid文件
- instances:
- min_uptime:最小運行時間,這裏設置的是60s即如果應用程序在60s內退出,pm2會認爲程序異常退出,此時觸發重啓max_restarts設置數量
- max_restarts:設置應用程序異常退出重啓的次數,默認15次(從0開始計數)
- cron_restart:定時啓動,解決重啓能解決的問題
- watch:是否啓用監控模式,默認是false。如果設置成true,當應用程序變動時,pm2會自動重載。這裏也可以設置你要監控的文件。
- merge_logs:
- exec_interpreter:應用程序的腳本類型,這裏使用的shell,默認是nodejs
- exec_mode:應用程序啓動模式,這裏設置的是cluster_mode(集羣),默認是fork
- autorestart:啓用/禁用應用程序崩潰或退出時自動重啓
- vizion:啓用/禁用vizion特性(版本控制)
也可以把啓動命令寫在package.json裏:
"scripts": {
"start": "node ./bin/xxx",
"pm2":"pm2 start processes.json"
},