nodejs高大上的部署方式(PM2)
如果直接通過node app來啟動(dòng),如果報(bào)錯(cuò)了可能直接停在整個(gè)運(yùn)行,supervisor感覺只是拿來用作開發(fā)環(huán)境的。再網(wǎng)上找到pm2.目前似乎最常見的線上部署nodejs項(xiàng)目的有forever,pm2這兩種。
使用場合:
- supervisor是開發(fā)環(huán)境用。
- forever管理多個(gè)站點(diǎn),每個(gè)站點(diǎn)訪問量不大,不需要監(jiān)控。
- nodemon 是開發(fā)環(huán)境使用,修改自動(dòng)重啟。
- pm2 網(wǎng)站訪問量比較大,需要完整的監(jiān)控界面。
PM2的主要特性:
- 內(nèi)建負(fù)載均衡(使用Node cluster 集群模塊)
- 后臺(tái)運(yùn)行
- 0秒停機(jī)重載,我理解大概意思是維護(hù)升級的時(shí)候不需要停機(jī).
- 具有Ubuntu和CentOS 的啟動(dòng)腳本
- 停止不穩(wěn)定的進(jìn)程(避免無限循環(huán))
- 控制臺(tái)檢測
- 提供 HTTP API
- 遠(yuǎn)程控制和實(shí)時(shí)的接口API ( Nodejs 模塊,允許和PM2進(jìn)程管理器交互 )
1、最常用的屬nohup了,其實(shí)就是在后臺(tái)執(zhí)行進(jìn)程,末尾加個(gè)&
[zhoujie@ops-dev ~]$ nohup node /home/zhoujie/ops/app.js & [1] 31490nohup: ignoring input and appending output to `nohup.out'
即此時(shí)程序已啟動(dòng),直接訪問即可,原程序的的標(biāo)準(zhǔn)輸出被自動(dòng)改向到當(dāng)前目錄下的nohup.out文件,起到了log的作用。該命令可以在你退出帳戶/關(guān)閉終端之后繼續(xù)運(yùn)行相應(yīng)的進(jìn)程。nohup就是不掛起的意思( no hang up)。
該命令的一般形式為:nohup command &
這個(gè)不太靠譜的樣子,經(jīng)常默默的進(jìn)程在后臺(tái)就掛了
2、用screen另開一個(gè)屏幕,這種方式可以直接在屏幕上看到程序運(yùn)行情況
給該應(yīng)用程序開個(gè)screen,如:screen -r ops ,用npm start啟動(dòng),
退出該后臺(tái):ctrl + a,再按d,可不能直接ctrl +c,否則就退出了
這種方式很不專業(yè),呵呵,不過方便看在生產(chǎn)環(huán)境的操作。
這個(gè)本質(zhì)上用的forever,package.json里配置的:
"scripts": { "start": "forever app.js", "test": "supervisor app.js" },
3、PM2
使用它要先安裝它,用root賬號和全局模式安裝一下:
npm install -g pm2
用它來啟動(dòng)程序(在當(dāng)前目錄下可以直接啟動(dòng),pm2 start app.js --name uops)
[zhoujie@ops-dev uops]$ pm2 start app.js [PM2] Spawning PM2 daemon [PM2] Success [PM2] Process app.js launched ┌──────────┬────┬──────┬─────┬────────┬───────────┬────────┬─────────────┬──────────┐ │ App name │ id │ mode │ PID │ status │ restarted │ uptime │ memory │ watching │ ├──────────┼────┼──────┼─────┼────────┼───────────┼────────┼─────────────┼──────────┤ │ app │ 0 │ fork │ 308 │ online │ 0 │ 0s │ 21.879 MB │ disabled │ └──────────┴────┴──────┴─────┴────────┴───────────┴────────┴─────────────┴──────────┘ Use `pm2 info <id|name>` to get more details about an app [zhoujie@ops-dev uops]$
看,它顯示了Success,程序已經(jīng)默默的成功的啟動(dòng)了,可以實(shí)時(shí)監(jiān)控程序的運(yùn)行,比如執(zhí)行個(gè)pm2 restart,則上述restarted那欄變成1,可以顯示程序運(yùn)行了多長時(shí)間、占用內(nèi)存大小,實(shí)在是太贊啦!
終止程序也很簡單:pm2 stop
列舉出所有用pm2啟動(dòng)的程序:pm2 list
[zhoujie@ops-dev uops]$ pm2 list ┌──────────┬────┬──────┬─────┬────────┬───────────┬────────┬─────────────┬──────────┐ │ App name │ id │ mode │ PID │ status │ restarted │ uptime │ memory │ watching │ ├──────────┼────┼──────┼─────┼────────┼───────────┼────────┼─────────────┼──────────┤ │ app │ 0 │ fork │ 984 │ online │ 1 │ 3s │ 64.141 MB │ disabled │ └──────────┴────┴──────┴─────┴────────┴───────────┴────────┴─────────────┴──────────┘ Use `pm2 info <id|name>` to get more details about an app
查看啟動(dòng)程序的詳細(xì)信息:pm2 describe id
[zhoujie@ops-dev uops]$ pm2 desc 0 Describing process with pid 0 - name app ┌───────────────────┬─────────────────────────────────────────┐ │ status │ online │ │ name │ app │ │ id │ 0 │ │ path │ /home/zhoujie/uops/app.js │ │ args │ │ │ exec cwd │ /home/zhoujie/uops │ │ error log path │ /home/zhoujie/.pm2/logs/app-error-0.log │ │ out log path │ /home/zhoujie/.pm2/logs/app-out-0.log │ │ pid path │ /home/zhoujie/.pm2/pids/app-0.pid │ │ mode │ fork_mode │ │ node v8 arguments │ │ │ watch & reload │ ✘ │ │ interpreter │ node │ │ restarts │ 1 │ │ unstable restarts │ 0 │ │ uptime │ 93s │ │ created at │ 2015-01-07T09:41:25.672Z │ └───────────────────┴─────────────────────────────────────────┘ [zhoujie@ops-dev uops]$
通過pm2 list命令來觀察所有運(yùn)行的進(jìn)程以及它們的狀態(tài)已經(jīng)足夠好了.但是怎么來追蹤它們的資源消耗呢?別擔(dān)心,用這個(gè)命令:pm2 monit
可以得到進(jìn)程(以及集群)的CPU的使用率和內(nèi)存占用(ctrl +c 退出)
實(shí)時(shí)集中l(wèi)og處理:pm2 logs
強(qiáng)大API: pm2 web
你想要監(jiān)控所有被PM2管理的進(jìn)程,而且同時(shí)還想監(jiān)控運(yùn)行這些進(jìn)程的機(jī)器的狀態(tài),
[zhoujie@ops-dev uops]$ pm2 web Launching web interface on port 9615 [PM2] Process /usr/local/node/lib/node_modules/pm2/lib/HttpInterface.js launched [PM2] Process launched ┌────────────────────┬────┬──────┬──────┬────────┬───────────┬────────┬─────────────┬──────────┐ │ App name │ id │ mode │ PID │ status │ restarted │ uptime │ memory │ watching │ ├────────────────────┼────┼──────┼──────┼────────┼───────────┼────────┼─────────────┼──────────┤ │ app │ 0 │ fork │ 984 │ online │ 1 │ 9m │ 74.762 MB │ disabled │ │ pm2-http-interface │ 1 │ fork │ 1878 │ online │ 0 │ 0s │ 15.070 MB │ disabled │ └────────────────────┴────┴──────┴──────┴────────┴───────────┴────────┴─────────────┴──────────┘ Use `pm2 info <id|name>` to get more details about an app
啟動(dòng)程序的時(shí)候順便在瀏覽器訪問:http://localhost:9615
擦,我眼睛被亮瞎了,這么炫酷,竟然把部署的服務(wù)器的信息和程序的信息都顯示出來了:
這東西對程序運(yùn)行的監(jiān)控頁面的開發(fā)實(shí)在是太有幫助了,呵呵~~
監(jiān)控:pm2 monit
實(shí)時(shí)集中l(wèi)og處理: pm2 logs
API:pm2 web (端口:9615 )
常用命令總結(jié):
$ 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 } ] }
說明:
- apps:json結(jié)構(gòu),apps是一個(gè)數(shù)組,每一個(gè)數(shù)組成員就是對應(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
來啟動(dòng)。
也可以把命令寫在package.json里。如下:
通過npm run start
來啟動(dòng)。
關(guān)于pm2遠(yuǎn)程部署到多臺(tái)機(jī)器,參考:http://pm2.keymetrics.io/docs/usage/deployment/
官網(wǎng):http://pm2.keymetrics.io/docs/usage/quick-start/
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
NodeJS學(xué)習(xí)筆記之Connect中間件模塊(二)
本文續(xù)上文的內(nèi)容,介紹下nodejs中connect中間件的使用方式及用途,希望大家喜歡。2015-01-01Nodejs讀取文件時(shí)相對路徑的正確寫法(使用fs模塊)
本篇文章主要介紹了linux 環(huán)境 mysql寫入中文報(bào)錯(cuò)的相關(guān)知識。具有很好的參考價(jià)值。下面跟著小編一起來看下吧2017-04-04nodejs express配置自簽名https服務(wù)器的方法
這篇文章主要介紹了nodejs express配置自簽名https服務(wù)器的方法,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2018-05-05Windows環(huán)境下npm install 報(bào)錯(cuò): operation not permitted, rename的解決
這篇文章主要介紹了Windows環(huán)境下npm install 報(bào)錯(cuò): operation not permitted, rename的解決方法,文中對解決的方法介紹的很詳細(xì),有需要的朋友們可以參考借鑒。2016-09-09Nodejs回調(diào)加超時(shí)限制兩種實(shí)現(xiàn)方法
這篇文章主要介紹了Nodejs回調(diào)加超時(shí)限制兩種實(shí)現(xiàn)方法的相關(guān)資料,需要的朋友可以參考下2017-06-06淺析Node.js實(shí)現(xiàn)HTTP文件下載
本文介紹如何用Node.js來實(shí)現(xiàn)HTTP文件下載,文章以實(shí)例演示所以很詳細(xì),有需要的小伙伴們可以參考學(xué)習(xí)。2016-08-08Grunt針對靜態(tài)文件的壓縮,版本控制打包的實(shí)例講解
下面小編就為大家?guī)硪黄狦runt針對靜態(tài)文件的壓縮,版本控制打包的實(shí)例講解。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-09-09nodejs抓取notion?emoji?svg資源的腳本示例
這篇文章主要為大家介紹了nodejs抓取notion?emoji?svg資源腳本實(shí)現(xiàn)示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-02-02詳解NodeJs項(xiàng)目 CentOs linux服務(wù)器線上部署
這篇文章主要介紹了NodeJs項(xiàng)目 CentOs linux服務(wù)器線上部署,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-09-09