擁抱 pm2 奈泪,為你的 nodejs 應(yīng)用助力

概述

  • pm2 與 supervisor 對比
  • pm2 基礎(chǔ)用法
  • 進程清單
  • Logs 日志
  • 操作
  • Misc
  • 配置文件
  • 配置文件操作命令
  • 集成 Docker
  • 在線監(jiān)控

pm2 與 supervisor 小對比

據(jù)我所知:
supervisor 可以實現(xiàn)修改命令后重啟應(yīng)用访圃,但是關(guān)閉控制臺之后仅醇,整個進程就掛了宣肚。
pm2 則可以后臺運行溜哮,關(guān)閉控制臺之后也不影響進程運行溃论,而且有如下眾多功能屎蜓,且聽我娓娓道來。

pm2 基礎(chǔ)用法

首先是 pm2 的安裝

npm install pm2 -g

啟動應(yīng)用:

pm2 start app.js --name myapp

停止應(yīng)用:

pm2 stop myapp

查看當前啟動應(yīng)用:

pm2 list

查看當前所有啟動應(yīng)用的 log:

pm2 logs

查看某一應(yīng)用的 log :

pm2 logs <app_name|app_id>  --> 例:pm2 logs myapp

<h3>基礎(chǔ)用法 plus

以下是 pm2 安裝好后的數(shù)據(jù)目錄

$HOME/.pm2 -->  will contain all PM2 related files
$HOME/.pm2/logs -->  will contain all applications logs
$HOME/.pm2/pids -->  will contain all applications pids
$HOME/.pm2/pm2.log -->  PM2 logs
$HOME/.pm2/pm2.pid -->  PM2 pid
$HOME/.pm2/rpc.sock -->  Socket file for remote commands
$HOME/.pm2/pub.sock -->  Socket file for publishable events
$HOME/.pm2/conf.js -->  PM2 Configuration

我們的 log 數(shù)據(jù)會持久化到 $HOME/.pm2/logs 目錄下钥勋,如需要查找相關(guān) log 則找到相應(yīng)的 log 文件即可炬转。

命名應(yīng)用:

pm2 start app.js --name myapp

文件修改后,自動重啟

pm2 start app.js --watch --name myapp

<h3>注意:
如果使用了 --watch 參數(shù)算灸,

pm2 stop myapp --> 將不會停止監(jiān)控
pm2 stop --watch myapp --> 將會停止監(jiān)控

設(shè)置日志時間:(其中 Z 為時區(qū))

pm2 start app.js --log-date-format="YYYY-MM-DD HH:mm Z"

傳參給 node v8:

pm2 start app.js --node-args="--debug=7001" 

內(nèi)存超過上限自動重啟:

pm2 start app.js --max-memory-restart 1024M

以當前可用 cpu 數(shù)量來開啟 node 進程數(shù)量

pm2 start app.js -i 0        
pm2 start app.js -i max     

進程清單

pm2 list               # 展示進程狀態(tài)
pm2 jlist              # 以原生 json 數(shù)據(jù)打印進程清單
pm2 prettylist         # 以格式化 json 數(shù)據(jù)打印進程清單
pm2 describe 0         # Display all informations about a specific process
pm2 monit              # 監(jiān)控所有進程

Logs 日志

pm2 logs [--raw]       # 以流的方式顯示所有日志
pm2 flush              # 清空所有 log 文件
pm2 reloadLogs         # 重載所有 log

操作

pm2 stop all           # 停止所有進程
pm2 restart all        # 重啟所有進程

pm2 reload all         # Will 0s downtime reload (for NETWORKED apps)

pm2 stop 0             # 通過進程 ID 來停止某個應(yīng)用
pm2 restart 0          # 通過進程 ID 來重啟某個應(yīng)用

pm2 delete 0           # 通過進程 ID 來刪除某個應(yīng)用
pm2 delete all         # 刪除所有應(yīng)用

Misc

pm2 reset <process>    # Reset meta data (restarted time...)
pm2 updatePM2          # Update in memory pm2
pm2 ping               # Ensure pm2 daemon has been launched
pm2 sendSignal SIGUSR2 my-app # Send system signal to script
pm2 start app.js --no-daemon
pm2 start app.js --no-vizion
pm2 start app.js --no-autorestart

配置文件

配置文件有 json 和 .yml 文件兩種格式扼劈。配置文件其實跟普通命令一樣,只是將命令寫進文件當中菲驴,我們可以將參數(shù)测僵,環(huán)境變量,logs file 寫進文件當中谢翎。而配置文件對微服務(wù)有很好的支持捍靠。
json 文件格式:(文件名需要以 .config.js 結(jié)尾)

module.exports = {
  apps : [{
    name        : "worker",
    script      : "./worker.js",
    output: './work/logs/out.log',//指定輸出 console.log 的位置
    error: './work/logs/error.log',//指定輸出 console.error 的位置
    log: './work/logs/combined.outerr.log',
    log_date_format: "YYYY-MM-DD HH:mm Z",
    watch       : true,
    env: {
      "NODE_ENV": "development",
    },
    env_production : {
       "NODE_ENV": "production"
    }
  },{
    name       : "api-app",
    script     : "./api.js",
    instances  : 4,
    exec_mode  : "cluster"
  }]
}

.yml 文件格式:

apps:
  - script   : ./api.js
    name     : 'api-app'
    instances: 4
    exec_mode: cluster
  - script : ./worker.js
    name   : 'worker'
    watch  : true
    env    :
      NODE_ENV: development
    env_production:
      NODE_ENV: production

配置文件操作命令

配置文件修改之后,需要 pm2 delete app 之后森逮,再重新啟動榨婆,修改的配置才能生效

# 開啟配置文件內(nèi)的所有應(yīng)用
pm2 start ecosystem.config.js

# 開啟配置文件內(nèi)的所有應(yīng)用,并配置環(huán)境變量 production
pm2 start ecosystem.config.js --env production

# 只啟動應(yīng)用名為:myapp 的應(yīng)用
pm2 start ecosystem.config.js --only api-app

# 停止配置文件內(nèi)的所有應(yīng)用
pm2 stop ecosystem.config.js

# 重啟配置文件內(nèi)的所有應(yīng)用
pm2 start   ecosystem.config.js
## 或者
pm2 restart ecosystem.config.js

# 重載配置文件內(nèi)的所有應(yīng)用
pm2 reload ecosystem.config.js

# 刪除配置文件內(nèi)的所有應(yīng)用
pm2 delete ecosystem.config.js

# 以下命令對配置文件內(nèi)的單一應(yīng)用生效
pm2 start   ecosystem.config.js --only api-app
pm2 restart ecosystem.config.js --only api-app
pm2 reload  ecosystem.config.js --only api-app
pm2 delete  ecosystem.config.js --only api-app

集成 Docker

在 Dockerfile 中運行如下命令,安裝 pm2

RUN npm install pm2 -g

CMD ["node", "app.js"]

用下面這行命令替代上面這條命令:

CMD ["pm2-runtime", "app.js"]

在線監(jiān)控

官網(wǎng):keymetrics
操作界面如下褒侧,看文檔操作入門很簡單良风,這里我就不再贅述了。

image.png

本文首發(fā)于公眾號「zone7」闷供,后臺回復(fù)「find bug」烟央,為你精心準備時下最熱門教程。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末歪脏,一起剝皮案震驚了整個濱河市疑俭,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌婿失,老刑警劉巖钞艇,帶你破解...
    沈念sama閱讀 217,542評論 6 504
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件啄寡,死亡現(xiàn)場離奇詭異,居然都是意外死亡哩照,警方通過查閱死者的電腦和手機挺物,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,822評論 3 394
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來飘弧,“玉大人识藤,你說我怎么就攤上這事〈瘟妫” “怎么了痴昧?”我有些...
    開封第一講書人閱讀 163,912評論 0 354
  • 文/不壞的土叔 我叫張陵,是天一觀的道長学少。 經(jīng)常有香客問我,道長秧骑,這世上最難降的妖魔是什么版确? 我笑而不...
    開封第一講書人閱讀 58,449評論 1 293
  • 正文 為了忘掉前任,我火速辦了婚禮乎折,結(jié)果婚禮上绒疗,老公的妹妹穿的比我還像新娘。我一直安慰自己骂澄,他們只是感情好吓蘑,可當我...
    茶點故事閱讀 67,500評論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著坟冲,像睡著了一般磨镶。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上健提,一...
    開封第一講書人閱讀 51,370評論 1 302
  • 那天琳猫,我揣著相機與錄音,去河邊找鬼私痹。 笑死脐嫂,一個胖子當著我的面吹牛,可吹牛的內(nèi)容都是我干的紊遵。 我是一名探鬼主播账千,決...
    沈念sama閱讀 40,193評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼暗膜!你這毒婦竟也來了匀奏?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,074評論 0 276
  • 序言:老撾萬榮一對情侶失蹤学搜,失蹤者是張志新(化名)和其女友劉穎攒射,沒想到半個月后醋旦,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,505評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡会放,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,722評論 3 335
  • 正文 我和宋清朗相戀三年饲齐,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片咧最。...
    茶點故事閱讀 39,841評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡捂人,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出矢沿,到底是詐尸還是另有隱情滥搭,我是刑警寧澤,帶...
    沈念sama閱讀 35,569評論 5 345
  • 正文 年R本政府宣布捣鲸,位于F島的核電站瑟匆,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏栽惶。R本人自食惡果不足惜愁溜,卻給世界環(huán)境...
    茶點故事閱讀 41,168評論 3 328
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望外厂。 院中可真熱鬧冕象,春花似錦、人聲如沸汁蝶。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,783評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽掖棉。三九已至墓律,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間幔亥,已是汗流浹背只锻。 一陣腳步聲響...
    開封第一講書人閱讀 32,918評論 1 269
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留紫谷,地道東北人齐饮。 一個月前我還...
    沈念sama閱讀 47,962評論 2 370
  • 正文 我出身青樓,卻偏偏與公主長得像笤昨,于是被迫代替她去往敵國和親祖驱。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 44,781評論 2 354

推薦閱讀更多精彩內(nèi)容