概述
- pm2 與 supervisor 對比
- pm2 基礎(chǔ)用法
- 進程清單
- Logs 日志
- 操作
- Misc
- 配置文件
- 配置文件操作命令
- 集成 Docker
- 在線監(jiān)控
pm2 與 supervisor 小對比
據(jù)我所知:
supervisor 可以實現(xiàn)修改命令后重啟應(yīng)用访圃,但是關(guān)閉控制臺之后仅醇,整個進程就掛了宣肚。
pm2 則可以后臺運行溜哮,關(guān)閉控制臺之后也不影響進程運行溃论,而且有如下眾多功能屎蜓,且聽我娓娓道來。
pm2 基礎(chǔ)用法
首先是 pm2 的安裝
npm install pm2 -g
啟動應(yīng)用:
pm2 start app.js --name myapp
停止應(yīng)用:
pm2 stop myapp
查看當前啟動應(yīng)用:
pm2 list
查看當前所有啟動應(yīng)用的 log:
pm2 logs
查看某一應(yīng)用的 log :
pm2 logs <app_name|app_id> --> 例:pm2 logs myapp
<h3>基礎(chǔ)用法 plus
以下是 pm2 安裝好后的數(shù)據(jù)目錄
$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
我們的 log 數(shù)據(jù)會持久化到 $HOME/.pm2/logs 目錄下钥勋,如需要查找相關(guān) log 則找到相應(yīng)的 log 文件即可炬转。
命名應(yīng)用:
pm2 start app.js --name myapp
文件修改后,自動重啟
pm2 start app.js --watch --name myapp
<h3>注意:
如果使用了 --watch 參數(shù)算灸,
pm2 stop myapp --> 將不會停止監(jiān)控
pm2 stop --watch myapp --> 將會停止監(jiān)控
設(shè)置日志時間:(其中 Z 為時區(qū))
pm2 start app.js --log-date-format="YYYY-MM-DD HH:mm Z"
傳參給 node v8:
pm2 start app.js --node-args="--debug=7001"
內(nèi)存超過上限自動重啟:
pm2 start app.js --max-memory-restart 1024M
以當前可用 cpu 數(shù)量來開啟 node 進程數(shù)量
pm2 start app.js -i 0
pm2 start app.js -i max
進程清單
pm2 list # 展示進程狀態(tài)
pm2 jlist # 以原生 json 數(shù)據(jù)打印進程清單
pm2 prettylist # 以格式化 json 數(shù)據(jù)打印進程清單
pm2 describe 0 # Display all informations about a specific process
pm2 monit # 監(jiān)控所有進程
Logs 日志
pm2 logs [--raw] # 以流的方式顯示所有日志
pm2 flush # 清空所有 log 文件
pm2 reloadLogs # 重載所有 log
操作
pm2 stop all # 停止所有進程
pm2 restart all # 重啟所有進程
pm2 reload all # Will 0s downtime reload (for NETWORKED apps)
pm2 stop 0 # 通過進程 ID 來停止某個應(yīng)用
pm2 restart 0 # 通過進程 ID 來重啟某個應(yīng)用
pm2 delete 0 # 通過進程 ID 來刪除某個應(yīng)用
pm2 delete all # 刪除所有應(yīng)用
Misc
pm2 reset <process> # Reset meta data (restarted time...)
pm2 updatePM2 # Update in memory pm2
pm2 ping # Ensure pm2 daemon has been launched
pm2 sendSignal SIGUSR2 my-app # Send system signal to script
pm2 start app.js --no-daemon
pm2 start app.js --no-vizion
pm2 start app.js --no-autorestart
配置文件
配置文件有 json 和 .yml 文件兩種格式扼劈。配置文件其實跟普通命令一樣,只是將命令寫進文件當中菲驴,我們可以將參數(shù)测僵,環(huán)境變量,logs file 寫進文件當中谢翎。而配置文件對微服務(wù)有很好的支持捍靠。
json 文件格式:(文件名需要以 .config.js 結(jié)尾)
module.exports = {
apps : [{
name : "worker",
script : "./worker.js",
output: './work/logs/out.log',//指定輸出 console.log 的位置
error: './work/logs/error.log',//指定輸出 console.error 的位置
log: './work/logs/combined.outerr.log',
log_date_format: "YYYY-MM-DD HH:mm Z",
watch : true,
env: {
"NODE_ENV": "development",
},
env_production : {
"NODE_ENV": "production"
}
},{
name : "api-app",
script : "./api.js",
instances : 4,
exec_mode : "cluster"
}]
}
.yml 文件格式:
apps:
- script : ./api.js
name : 'api-app'
instances: 4
exec_mode: cluster
- script : ./worker.js
name : 'worker'
watch : true
env :
NODE_ENV: development
env_production:
NODE_ENV: production
配置文件操作命令
配置文件修改之后,需要 pm2 delete app 之后森逮,再重新啟動榨婆,修改的配置才能生效
# 開啟配置文件內(nèi)的所有應(yīng)用
pm2 start ecosystem.config.js
# 開啟配置文件內(nèi)的所有應(yīng)用,并配置環(huán)境變量 production
pm2 start ecosystem.config.js --env production
# 只啟動應(yīng)用名為:myapp 的應(yīng)用
pm2 start ecosystem.config.js --only api-app
# 停止配置文件內(nèi)的所有應(yīng)用
pm2 stop ecosystem.config.js
# 重啟配置文件內(nèi)的所有應(yīng)用
pm2 start ecosystem.config.js
## 或者
pm2 restart ecosystem.config.js
# 重載配置文件內(nèi)的所有應(yīng)用
pm2 reload ecosystem.config.js
# 刪除配置文件內(nèi)的所有應(yīng)用
pm2 delete ecosystem.config.js
# 以下命令對配置文件內(nèi)的單一應(yīng)用生效
pm2 start ecosystem.config.js --only api-app
pm2 restart ecosystem.config.js --only api-app
pm2 reload ecosystem.config.js --only api-app
pm2 delete ecosystem.config.js --only api-app
集成 Docker
在 Dockerfile 中運行如下命令,安裝 pm2
RUN npm install pm2 -g
CMD ["node", "app.js"]
用下面這行命令替代上面這條命令:
CMD ["pm2-runtime", "app.js"]
在線監(jiān)控
官網(wǎng):keymetrics
操作界面如下褒侧,看文檔操作入門很簡單良风,這里我就不再贅述了。
本文首發(fā)于公眾號「zone7」闷供,后臺回復(fù)「find bug」烟央,為你精心準備時下最熱門教程。