PM2 常用命令以及配置

PM2 常用命令

$ pm2 start app.js # 啓動app.js應用程序

$ pm2 start app.js -i 4 # cluster mode 模式啓動4個app.js的應用實例

4個應用程序會自動進行負載均衡

$ pm2 start app.js --name=“api” # 啓動應用程序並命名爲 “api”

$ pm2 start app.js --watch # 當文件變化時自動重啓應用

$ pm2 start script.sh # 啓動 bash 腳本

$ pm2 list # 列表 PM2 啓動的所有的應用程序

$ pm2 monit # 顯示每個應用程序的CPU和內存佔用情況

$ pm2 show [app-name] # 顯示應用程序的所有信息

$ pm2 logs # 顯示所有應用程序的日誌

$ pm2 logs [app-name] # 顯示指定應用程序的日誌

$ pm2 flush # 清空所有日誌文件

$ pm2 stop all # 停止所有的應用程序

$ pm2 stop 0 # 停止 id爲 0的指定應用程序

$ pm2 restart all # 重啓所有應用

$ pm2 reload all # 重啓 cluster mode下的所有應用

$ pm2 gracefulReload all # Graceful reload all apps in cluster mode

$ pm2 delete all # 關閉並刪除所有應用

$ pm2 delete 0 # 刪除指定應用 id 0

$ pm2 scale api 10 # 把名字叫api的應用擴展到10個實例

$ pm2 reset [app-name] # 重置重啓數量

$ pm2 startup # 創建開機自啓動命令

$ pm2 save # 保存當前應用列表

$ pm2 resurrect # 重新加載保存的應用列表

$ pm2 update # Save processes, kill PM2 and restore processes

$ pm2 generate # Generate a sample json configuration file

pm2文檔地址:http://pm2.keymetrics.io/docs/usage/quick-start/

PM2是一個帶有負載均衡功能的Node應用的進程管理!

內建負載均衡(使用Node cluster 集羣模塊)
可以在後臺運行
可以0秒停機重載,(可以理解爲不需要停機重啓,在用戶愉快的瀏覽頁面時我們已經程序更新了)
控制檯檢測
日誌管理
熱重載

在我們的Node項目中實現
將以下PM2配置文件於package.json放到一個根目錄下
在package.json 的scripts裏添加 “pm2”: "pm2 start pm2.json"這一段代碼這樣我們就可以使用 npm run pm2來啓動我們的Node項目
ps:pm2 restart 不會重新進行 配置文件 需要關掉重啓
以下就是我們的配置文件詳細介紹
{
“apps”: {
“name”: “wuwu”, // 項目名
“script”: “./bin/www”, // 執行文件
“cwd”: “./”, // 根目錄
“args”: “”, // 傳遞給腳本的參數
“interpreter”: “”, // 指定的腳本解釋器
“interpreter_args”: “”, // 傳遞給解釋器的參數
“watch”: true, // 是否監聽文件變動然後重啓
“ignore_watch”: [ // 不用監聽的文件
“node_modules”,
“logs”
],
“exec_mode”: “cluster_mode”, // 應用啓動模式,支持fork和cluster模式
“instances”: 4, // 應用啓動實例個數,僅在cluster模式有效 默認爲fork;或者 max
“max_memory_restart”: 8, // 最大內存限制數,超出自動重啓
“error_file”: “./logs/app-err.log”, // 錯誤日誌文件
“out_file”: “./logs/app-out.log”, // 正常日誌文件
“merge_logs”: true, // 設置追加日誌而不是新建日誌
“log_date_format”: “YYYY-MM-DD HH:mm:ss”, // 指定日誌文件的時間格式
“min_uptime”: “60s”, // 應用運行少於時間被認爲是異常啓動
“max_restarts”: 30, // 最大異常重啓次數,即小於min_uptime運行時間重啓次數;
“autorestart”: true, // 默認爲true, 發生異常的情況下自動重啓
“cron_restart”: “”, // crontab時間格式重啓應用,目前只支持cluster模式;
“restart_delay”: “60s” // 異常重啓情況下,延時重啓時間
“env”: {
“NODE_ENV”: “production”, // 環境參數,當前指定爲生產環境 process.env.NODE_ENV
“REMOTE_ADDR”: “愛上大聲地” // process.env.REMOTE_ADDR
},
“env_dev”: {
“NODE_ENV”: “development”, // 環境參數,當前指定爲開發環境 pm2 start app.js --env_dev
“REMOTE_ADDR”: “”
},
“env_test”: { // 環境參數,當前指定爲測試環境 pm2 start app.js --env_test
“NODE_ENV”: “test”,
“REMOTE_ADDR”: “”
}
}
}

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章