Node js — 使用pm2部署項目

pm2 是一個帶有負載均衡功能的Node應用的進程管理器。能夠把你的獨立代碼利用所有的服務器上的全部CPU,並保證進程永遠都活着,0秒的重載。html

pm2的主要特性

一、內建負載均衡(使用Node cluster 集羣模塊) 二、後臺運行 三、0秒停機重載 四、具備Ubuntu和CentOS 的啓動腳本 五、中止不穩定的進程(避免無限循環) 六、控制檯檢測 七、提供 HTTP API 八、遠程控制和實時的接口API ( Nodejs 模塊,容許和PM2進程管理器交互 )node

pm2的安裝

npm install -g pm2
複製代碼

pm2的用法

pm2 start app.js -i 4   // 後臺運行pm2,啓動4個app.js 
                        // 也能夠把'max' 參數傳遞給 start
                        // 正確的進程數目依賴於Cpu的核心數目
pm2 start app.js --name my-api // 命名進程
pm2 list               // 顯示全部進程狀態
pm2 monit              // 監視全部進程
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 
pm2 delete 0           // 殺死指定的進程
pm2 delete all         // 殺死所有進程12345678910111213141516
複製代碼

pm2運行進程的不一樣方式

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  // 啓動並生成一個配置文件

// 也能夠執行用其餘語言編寫的app  ( fork 模式):
pm2 start my-bash-script.sh    -x --interpreter bash
pm2 start my-python-script.py -x --interpreter python12345678910111213
複製代碼

pm2 list

列出由pm2管理的全部進程信息,還會顯示一個進程會被啓動多少次,由於沒處理的異常。python

pm2 monit

監視每一個node進程的CPU和內存的使用狀況。web

pm2 logs

實時集中log處理。redis

快速恢復

如今事情一切順利,你的進程嗡嗡的運行着,你須要作一次硬重啓(hard restart).如今嗎?是的,首先,dump掉:shell

$ pm2 dump
複製代碼

而後,你能夠從文件中恢復它:npm

$ pm2 kill // 讓咱們假設一個PM2停掉了 
$ pm2 resurect // 我全部的進程又滿血滿狀態復活了 
複製代碼

經常使用命令總結

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: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
    }
  ]
}
複製代碼

說明:api

  • 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
複製代碼

彙總自:

www.cnblogs.com/zhoujie/p/n…

blog.csdn.net/starter____…

相關文章
相關標籤/搜索