您好,登錄后才能下訂單哦!
本篇文章給大家分享的是有關(guān)node.js項(xiàng)目怎么利用PM2進(jìn)行部署,小編覺得挺實(shí)用的,因此分享給大家學(xué)習(xí),希望大家閱讀完這篇文章后可以有所收獲,話不多說(shuō),跟著小編一起來(lái)看看吧。
使用場(chǎng)合:
supervisor是開發(fā)環(huán)境用。
forever管理多個(gè)站點(diǎn),每個(gè)站點(diǎn)訪問量不大,不需要監(jiān)控。
pm2 網(wǎng)站訪問量比較大,需要完整的監(jiān)控界面。
PM2的主要特性:
內(nèi)建負(fù)載均衡(使用Node cluster 集群模塊)
后臺(tái)運(yùn)行
0秒停機(jī)重載,我理解大概意思是維護(hù)升級(jí)的時(shí)候不需要停機(jī).
具有Ubuntu和CentOS 的啟動(dòng)腳本
停止不穩(wěn)定的進(jìn)程(避免無(wú)限循環(huán))
控制臺(tái)檢測(cè)
提供 HTTP API
遠(yuǎn)程控制和實(shí)時(shí)的接口API ( Nodejs 模塊,允許和PM2進(jìn)程管理器交互 )
安裝
npm install -g pm2
用法
$ npm install -g pm2
命令行全局安裝pm2
$ pm2 start app.js
啟動(dòng)app項(xiàng)目
$ pm2 list
列出由pm2管理的所有進(jìn)程信息,還會(huì)顯示一個(gè)進(jìn)程會(huì)被啟動(dòng)多少次,因?yàn)闆]處理的異常。
$ pm2 monit
監(jiān)視每個(gè)node進(jìn)程的CPU和內(nèi)存的使用情況
$ pm2 logs
顯示所有進(jìn)程日志
$ pm2 stop all
停止所有進(jìn)程
$ pm2 restart all
重啟所有進(jìn)程
$ pm2 reload all 0
秒停機(jī)重載進(jìn)程 (用于 NETWORKED 進(jìn)程)
$ pm2 stop 0
停止指定的進(jìn)程
$ pm2 restart 0
重啟指定的進(jìn)程
$ pm2 startup
產(chǎn)生 init 腳本 保持進(jìn)程活著
$ pm2 web
運(yùn)行健壯的 computer API endpoint (http://localhost:9615)
$ pm2 delete 0
殺死指定的進(jìn)程
$ pm2 delete all
殺死全部進(jìn)程
運(yùn)行進(jìn)程的不同方式:
$ pm2 start app.js -i max
根據(jù)有效CPU數(shù)目啟動(dòng)最大進(jìn)程數(shù)目
$ pm2 start app.js -i 3
啟動(dòng)3個(gè)進(jìn)程
$ pm2 start app.js -x
用fork模式啟動(dòng) app.js 而不是使用 cluster
$ pm2 start app.js -x -- -a 23
用fork模式啟動(dòng) app.js 并且傳遞參數(shù) (-a 23)
$ pm2 start app.js --name serverone
啟動(dòng)一個(gè)進(jìn)程并把它命名為 serverone
$ pm2 stop serverone
停止 serverone 進(jìn)程
$ pm2 start app.json
啟動(dòng)進(jìn)程, 在 app.json里設(shè)置選項(xiàng)
$ pm2 start app.js -i max -- -a 23
在--之后給 app.js 傳遞參數(shù)
$ pm2 start app.js -i max -e err.log -o out.log
啟動(dòng) 并 生成一個(gè)配置文件
配置pm2啟動(dòng)文件
在項(xiàng)目根目錄添加一個(gè)processes.json:
內(nèi)容如下:
{ "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 } ] }
說(shuō)明:
apps:json結(jié)構(gòu),apps是一個(gè)數(shù)組,每一個(gè)數(shù)組成員就是對(duì)應(yīng)一個(gè)pm2中運(yùn)行的應(yīng)用
name:應(yīng)用程序名稱
cwd:應(yīng)用程序所在的目錄
script:應(yīng)用程序的腳本路徑
log_date_format:
error_file:自定義應(yīng)用程序的錯(cuò)誤日志文件
out_file:自定義應(yīng)用程序日志文件
pid_file:自定義應(yīng)用程序的pid文件
instances:
min_uptime:最小運(yùn)行時(shí)間,這里設(shè)置的是60s即如果應(yīng)用程序在60s內(nèi)退出,pm2會(huì)認(rèn)為程序異常退出,此時(shí)觸發(fā)重啟max_restarts設(shè)置數(shù)量
max_restarts:設(shè)置應(yīng)用程序異常退出重啟的次數(shù),默認(rèn)15次(從0開始計(jì)數(shù))
cron_restart:定時(shí)啟動(dòng),解決重啟能解決的問題
watch:是否啟用監(jiān)控模式,默認(rèn)是false。如果設(shè)置成true,當(dāng)應(yīng)用程序變動(dòng)時(shí),pm2會(huì)自動(dòng)重載。這里也可以設(shè)置你要監(jiān)控的文件。
merge_logs:
exec_interpreter:應(yīng)用程序的腳本類型,這里使用的shell,默認(rèn)是nodejs
exec_mode:應(yīng)用程序啟動(dòng)模式,這里設(shè)置的是cluster_mode(集群),默認(rèn)是fork
autorestart:啟用/禁用應(yīng)用程序崩潰或退出時(shí)自動(dòng)重啟
vizion:啟用/禁用vizion特性(版本控制)
可以通過pm2 start processes.json
來(lái)啟動(dòng)。
也可以把命令寫在package.json里。如下:
通過npm run pm2
來(lái)啟動(dòng)。
以上就是node.js項(xiàng)目怎么利用PM2進(jìn)行部署,小編相信有部分知識(shí)點(diǎn)可能是我們?nèi)粘9ぷ鲿?huì)見到或用到的。希望你能通過這篇文章學(xué)到更多知識(shí)。更多詳情敬請(qǐng)關(guān)注億速云行業(yè)資訊頻道。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。