您好,登錄后才能下訂單哦!
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
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持億速云。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。