PM2 部署 nodejs 项目
PM2 部署 nodejs 項目
在網上找到pm2.目前似乎最常見的線上部署nodejs項目的有forever,pm2這兩種。
使用場合:
forever管理多個站點,每個站點訪問量不大,不需要監控。
pm2 網站訪問量比較大,需要完整的監控界面。
PM2的主要特性:
內建負載均衡(使用Node cluster 集群模塊)
后臺運行
0秒停機重載,我理解大概意思是維護升級的時候不需要停機.
具有Ubuntu和CentOS 的啟動腳本
停止不穩定的進程(避免無限循環)
控制臺檢測
提供 HTTP API
遠程控制和實時的接口API ( Nodejs 模塊,允許和PM2進程管理器交互 )
安裝
用法
$ npm install -g pm2 命令行全局安裝pm2
$ pm2 start app.js 或者 pm2 start bin/www 啟動node項目
$ pm2 stop bin/www 停止pm2服務
$ pm2 list 列出由pm2管理的所有進程信息,還會顯示一個進程會被啟動多少次,因為沒處理的異常。
$ pm2 monit 監視每個node進程的CPU和內存的使用情況
$ 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 啟動 并 生成一個配置文件
配置pm2啟動文件
在項目根目錄添加一個processes.json:
內容如下:
說明:
apps:json結構,apps是一個數組,每一個數組成員就是對應一個pm2中運行的應用
name:應用程序名稱
cwd:應用程序所在的目錄
script:應用程序的腳本路徑
log_date_format:
error_file:自定義應用程序的錯誤日志文件
out_file:自定義應用程序日志文件
pid_file:自定義應用程序的pid文件
instances:
min_uptime:最小運行時間,這里設置的是60s即如果應用程序在60s內退出,pm2會認為程序異常退出,此時觸發重啟max_restarts設置數量
max_restarts:設置應用程序異常退出重啟的次數,默認15次(從0開始計數)
cron_restart:定時啟動,解決重啟能解決的問題
watch:是否啟用監控模式,默認是false。如果設置成true,當應用程序變動時,pm2會自動重載。這里也可以設置你要監控的文件。
merge_logs:
exec_interpreter:應用程序的腳本類型,這里使用的shell,默認是nodejs
exec_mode:應用程序啟動模式,這里設置的是cluster_mode(集群),默認是fork
autorestart:啟用/禁用應用程序崩潰或退出時自動重啟
vizion:啟用/禁用vizion特性(版本控制)
可以通過pm2 start processes.json來啟動。
也可以把命令寫在package.json里。如下:
在網上找到pm2.目前似乎最常見的線上部署nodejs項目的有forever,pm2這兩種。
使用場合:
forever管理多個站點,每個站點訪問量不大,不需要監控。
pm2 網站訪問量比較大,需要完整的監控界面。
PM2的主要特性:
內建負載均衡(使用Node cluster 集群模塊)
后臺運行
0秒停機重載,我理解大概意思是維護升級的時候不需要停機.
具有Ubuntu和CentOS 的啟動腳本
停止不穩定的進程(避免無限循環)
控制臺檢測
提供 HTTP API
遠程控制和實時的接口API ( Nodejs 模塊,允許和PM2進程管理器交互 )
安裝
npm install -g pm2
用法
$ npm install -g pm2 命令行全局安裝pm2
$ pm2 start app.js 或者 pm2 start bin/www 啟動node項目
$ pm2 stop bin/www 停止pm2服務
$ pm2 list 列出由pm2管理的所有進程信息,還會顯示一個進程會被啟動多少次,因為沒處理的異常。
$ pm2 monit 監視每個node進程的CPU和內存的使用情況
$ 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 啟動 并 生成一個配置文件
配置pm2啟動文件
在項目根目錄添加一個processes.json:
內容如下:
說明:
apps:json結構,apps是一個數組,每一個數組成員就是對應一個pm2中運行的應用
name:應用程序名稱
cwd:應用程序所在的目錄
script:應用程序的腳本路徑
log_date_format:
error_file:自定義應用程序的錯誤日志文件
out_file:自定義應用程序日志文件
pid_file:自定義應用程序的pid文件
instances:
min_uptime:最小運行時間,這里設置的是60s即如果應用程序在60s內退出,pm2會認為程序異常退出,此時觸發重啟max_restarts設置數量
max_restarts:設置應用程序異常退出重啟的次數,默認15次(從0開始計數)
cron_restart:定時啟動,解決重啟能解決的問題
watch:是否啟用監控模式,默認是false。如果設置成true,當應用程序變動時,pm2會自動重載。這里也可以設置你要監控的文件。
merge_logs:
exec_interpreter:應用程序的腳本類型,這里使用的shell,默認是nodejs
exec_mode:應用程序啟動模式,這里設置的是cluster_mode(集群),默認是fork
autorestart:啟用/禁用應用程序崩潰或退出時自動重啟
vizion:啟用/禁用vizion特性(版本控制)
可以通過pm2 start processes.json來啟動。
也可以把命令寫在package.json里。如下:
分享來源
總結
以上是生活随笔為你收集整理的PM2 部署 nodejs 项目的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: SketchUp Pro 2022 Ma
- 下一篇: 【快速上手教程】PC Web、Uni-A