pm2 是一個帶有負載均衡功能的Node應用的進程管理器。能夠把你的獨立代碼利用所有的服務器上的全部CPU,並保證進程永遠都活着,0秒的重載。html
一、內建負載均衡(使用Node cluster 集羣模塊) 二、後臺運行 三、0秒停機重載 四、具備Ubuntu和CentOS 的啓動腳本 五、中止不穩定的進程(避免無限循環) 六、控制檯檢測 七、提供 HTTP API 八、遠程控制和實時的接口API ( Nodejs 模塊,容許和PM2進程管理器交互 )node
npm install -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
pm2 delete 0 // 殺死指定的進程
pm2 delete all // 殺死所有進程12345678910111213141516
複製代碼
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 python12345678910111213
複製代碼
列出由pm2管理的全部進程信息,還會顯示一個進程會被啓動多少次,由於沒處理的異常。python
監視每一個node進程的CPU和內存的使用狀況。web
實時集中log處理。redis
如今事情一切順利,你的進程嗡嗡的運行着,你須要作一次硬重啓(hard restart).如今嗎?是的,首先,dump掉:shell
$ pm2 dump
複製代碼
而後,你能夠從文件中恢復它:npm
$ pm2 kill // 讓咱們假設一個PM2停掉了
$ pm2 resurect // 我全部的進程又滿血滿狀態復活了
複製代碼
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 啓動 並 生成一個配置文件
複製代碼
在項目根目錄添加一個processes.json:json
{
"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
}
]
}
複製代碼
說明:api
能夠經過pm2 start processes.json
來啓動。也能夠把命令寫在package.json裏,以下:數組
"scripts": {
"dev": "NODE_ENV=development nodemon src/server.js & NODE_ENV=development nodemon src/server/action-server.js & tools/redis/socket.js",
"dev_read_redis": "NODE_ENV=development nodemon src/app.js",
"start": "NODE_ENV=production nodemon src/app.js",
"test": "echo \"Error: no test specified\" && exit 1"
},
複製代碼
啓動
npm run start
複製代碼
彙總自: