1. 程式人生 > >nodejs高大上的部署方式-PM2

nodejs高大上的部署方式-PM2

如果直接通過node app來啟動,如果報錯了可能直接停在整個執行,supervisor感覺只是拿來用作開發環境的。再網上找到pm2.目前似乎最常見的線上部署nodejs專案的有forever,pm2這兩種。 使用場合:

  • supervisor是開發環境用。
  • forever管理多個站點,每個站點訪問量不大,不需要監控。
  • nodemon 是開發環境使用,修改自動重啟。
  • pm2 網站訪問量比較大,需要完整的監控介面。

PM2的主要特性:

  • 內建負載均衡(使用Node cluster 叢集模組)
  • 後臺執行
  • 0秒停機過載,我理解大概意思是維護升級的時候不需要停機.
  • 具有Ubuntu和CentOS 的啟動指令碼
  • 停止不穩定的程序(避免無限迴圈)
  • 控制檯檢測
  • 提供 HTTP API
  • 遠端控制和實時的介面API ( Nodejs 模組,允許和PM2程序管理器互動 )

1、最常用的屬nohup了,其實就是在後臺執行程序,末尾加個&

[[email protected] ~]$ nohup node /home/zhoujie/ops/app.js &
[1] 31490nohup: ignoring input and appending output to `nohup.out'

即此時程式已啟動,直接訪問即可,原程式的的標準輸出被自動改向到當前目錄下的nohup.out檔案,起到了log的作用。該命令可以在你退出帳戶/關閉終端之後繼續執行相應的程序。nohup就是不掛起的意思( no hang up)。

該命令的一般形式為:nohup command &

  這個不太靠譜的樣子,經常默默的程序在後臺就掛了

2、用screen另開一個螢幕,這種方式可以直接在螢幕上看到程式執行情況

給該應用程式開個screen,如:screen -r ops ,用npm start啟動,

退出該後臺:ctrl + a,再按d,可不能直接ctrl +c,否則就退出了

這種方式很不專業,呵呵,不過方便看在生產環境的操作。

這個本質上用的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)

複製程式碼

[[email protected] 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
[[email protected] uops]$

複製程式碼

看,它顯示了Success,程式已經默默的成功的啟動了,可以實時監控程式的執行,比如執行個pm2 restart,則上述restarted那欄變成1,可以顯示程式運行了多長時間、佔用記憶體大小,實在是太贊啦!

終止程式也很簡單:pm2 stop 

列舉出所有用pm2啟動的程式:pm2 list

複製程式碼

[[email protected] 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

複製程式碼

[[email protected] 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                │
└───────────────────┴─────────────────────────────────────────┘
[[email protected] uops]$ 

複製程式碼

通過pm2 list命令來觀察所有執行的程序以及它們的狀態已經足夠好了.但是怎麼來追蹤它們的資源消耗呢?別擔心,用這個命令:pm2 monit

可以得到程序(以及叢集)的CPU的使用率和記憶體佔用(ctrl +c 退出)

實時集中log處理:pm2 logs

強大API: pm2 web

你想要監控所有被PM2管理的程序,而且同時還想監控執行這些程序的機器的狀態,

複製程式碼

[[email protected] 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

複製程式碼

啟動程式的時候順便在瀏覽器訪問:http://localhost:9615

擦,我眼睛被亮瞎了,這麼炫酷,竟然把部署的伺服器的資訊和程式的資訊都顯示出來了:

這東西對程式執行的監控頁面的開發實在是太有幫助了,呵呵~~

監控:pm2 monit 實時集中log處理: pm2 logs API:pm2 web (埠:9615 )

常用命令總結:

$ 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": [
    {
      "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結構,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裡。如下:

複製程式碼

 "scripts": {
    "dev": "NODE_ENV=development nodemon src/server.js & NODE_ENV=development nodemon src/server/action-server.js & tools/redis/socket.js",
    "dev_read_redis": "NODE_ENV=development nodemon src/app.js",
    "start": "NODE_ENV=production nodemon src/app.js",
    "test": "echo \"Error: no test specified\" && exit 1"
  },

複製程式碼

通過npm run start來啟動。

關於pm2遠端部署到多臺機器,參考:

官網: