pm2管理nodejs程序
阿新 • • 發佈:2019-01-22
pm2 是一個帶有負載均衡功能的Node應用的程序管理器.
當你要把你的獨立程式碼利用全部的伺服器上的所有CPU,並保證程序永遠都活著,0秒的過載, PM2是完美的。
它非常適合IaaS結構,但不要把它用於PaaS方案(隨後將開發Paas的解決方案).
和使用node index.js方式比較,優點:
1 一個命令視窗就可管理多個node伺服器程序。而node命令多個程序就需要開多個視窗。
2 關閉命令視窗,node程序仍然會執行。而node命令執行的關閉視窗後,程序也就關閉了。
一 安裝PM2
npm install -g pm2
二 用pm2 啟動index.js
pm2 start index.js --name tank
--name tank是給這個程序取個名字
三 其他pm2命令
安裝
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 (http://localhost:9615)
$ 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 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 # 啟動 並 生成一個配置檔案
你也可以執行用其他語言編寫的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 https://github.com/Unitech/pm2.git
$ cd pm2
$ npm install # 或者 npm install --dev ,如果devDependencies 沒有安裝
$ npm test