如果直接通過node app來啟動,如果報錯了可能直接停在整個運行,supervisor感覺只是拿來用作開發(fā)環(huán)境的。再網(wǎng)上找到pm2.目前似乎最常見的線上部署nodejs項目的有forever,pm2這兩種。
使用場合:
PM2的主要特性:
1、最常用的屬nohup了,其實就是在后臺執(zhí)行進程,末尾加個&
[zhoujie@ops-dev ~]$ nohup node /home/zhoujie/ops/app.js &[1] 31490nohup: ignoring input and appending output to `nohup.out'
即此時程序已啟動,直接訪問即可,原程序的的標準輸出被自動改向到當前目錄下的nohup.out文件,起到了log的作用。該命令可以在你退出帳戶/關(guān)閉終端之后繼續(xù)運行相應(yīng)的進程。nohup就是不掛起的意思( no hang up)。
該命令的一般形式為:nohup command &
這個不太靠譜的樣子,經(jīng)常默默的進程在后臺就掛了
2、用screen另開一個屏幕,這種方式可以直接在屏幕上看到程序運行情況
給該應(yīng)用程序開個screen,如:screen -r ops ,用npm start啟動,
退出該后臺:ctrl + a,再按d,可不能直接ctrl +c,否則就退出了
這種方式很不專業(yè),呵呵,不過方便看在生產(chǎn)環(huán)境的操作。
這個本質(zhì)上用的forever,package.json里配置的:
 "scripts": {  "start": "forever app.js",  "test": "supervisor app.js" },3、PM2
使用它要先安裝它,用root賬號和全局模式安裝一下:
npm install -g pm2
用它來啟動程序(在當前目錄下可以直接啟動,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)默默的成功的啟動了,可以實時監(jiān)控程序的運行,比如執(zhí)行個pm2 restart,則上述restarted那欄變成1,可以顯示程序運行了多長時間、占用內(nèi)存大小,實在是太贊啦!

終止程序也很簡單:pm2 stop

列舉出所有用pm2啟動的程序: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
查看啟動程序的詳細信息:pm2 describe id
[zhoujie@ops-dev uops]$ pm2 desc 0Describing 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命令來觀察所有運行的進程以及它們的狀態(tài)已經(jīng)足夠好了.但是怎么來追蹤它們的資源消耗呢?別擔心,用這個命令:pm2 monit
可以得到進程(以及集群)的CPU的使用率和內(nèi)存占用(ctrl +c 退出)

實時集中l(wèi)og處理:pm2 logs

強大API: pm2 web
你想要監(jiān)控所有被PM2管理的進程,而且同時還想監(jiān)控運行這些進程的機器的狀態(tài),
[zhoujie@ops-dev uops]$ pm2 webLaunching 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
啟動程序的時候順便在瀏覽器訪問:http://localhost:9615
擦,我眼睛被亮瞎了,這么炫酷,竟然把部署的服務(wù)器的信息和程序的信息都顯示出來了:

這東西對程序運行的監(jiān)控頁面的開發(fā)實在是太有幫助了,呵呵~~
監(jiān)控:pm2 monit
實時集中l(wèi)og處理: pm2 logs
API:pm2 web (端口:9615 )
常用命令總結(jié):
$ pm2 logs 顯示所有進程日志$ pm2 stop all 停止所有進程$ pm2 restart all 重啟所有進程$ pm2 reload all 0秒停機重載進程 (用于 NETWORKED 進程)$ pm2 stop 0 停止指定的進程$ pm2 restart 0 重啟指定的進程$ pm2 startup 產(chǎn)生 init 腳本 保持進程活著$ pm2 web 運行健壯的 computer API endpoint (http://localhost:9615)$ pm2 delete 0 殺死指定的進程$ pm2 delete all 殺死全部進程運行進程的不同方式:
$ pm2 start app.js -i max 根據(jù)有效CPU數(shù)目啟動最大進程數(shù)目$ 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 并且傳遞參數(shù) (-a 23)$ pm2 start app.js --name serverone 啟動一個進程并把它命名為 serverone$ pm2 stop serverone 停止 serverone 進程$ pm2 start app.json 啟動進程, 在 app.json里設(shè)置選項$ pm2 start app.js -i max -- -a 23 在--之后給 app.js 傳遞參數(shù)$ pm2 start app.js -i max -e err.log -o out.log 啟動 并 生成一個配置文件配置pm2啟動文件
在項目根目錄添加一個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  } ]}說明:
可以通過pm2 start processes.json來啟動。
也可以把命令寫在package.json里。如下:
通過npm run start來啟動。
關(guān)于pm2遠程部署到多臺機器,參考:http://pm2.keymetrics.io/docs/usage/deployment/
官網(wǎng):http://pm2.keymetrics.io/docs/usage/quick-start/
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持武林網(wǎng)。
新聞熱點
疑難解答