PM2來部署nodejs服務器永久開啓

1. pm2 是什麼?

日常開發中需要啓動一個node項目,需要用npm run …,,如果終端被關掉,程序也就自動停止,有時候幾個項目一起跑起來,好幾個終端開着,個人不太喜歡,有一神器可以解決:pm2。pm2 是一個帶有負載均衡功能的Node應用的進程管理器.當你要把你的獨立代碼利用全部的服務器上的所有CPU,並保證進程永遠都活着,0秒的重載, PM2是完美的。它非常適合IaaS結構,但不要把它用於PaaS方案。

2.安裝

npm install -g pm2

3.日常使用

由於node的百花齊放,啓動一個網站的辦法,也會有很多種。這裏先以:npm run dev爲例:

首先查看項目的package.json文件:

  "scripts": {
    "dev": "node build/dev-server.js --env=local",
    "start": "node build/dev-server.js --env=local",
    "build": "node build/build.js --env=publish",
    "build-local": "node build/build.js"
  },

npm run dev 實際就是運行node腳步文件:dev-server.js,

可以用pm2啓動:pm2 start build/dev-server.js,可以給這個進程取一個自己記得能理解的名字:pm2 start build/dev-server.js --name XXX,(XXX是你定義的名字)

如果你的node項目配置文件和以上代碼不一樣,,,莫急,pm2 也是有辦法可以啓動的(個人覺得這是一個萬能的啓動的方法):

pm2 start npm -- run XXX

用她替代:npm run dev,就可以寫成:pm2 start npm -- run dev,項目啓動:

雖然項目啓動了,但是名字並不是我想要的(我需要個自己能記得住的名字,並且是一個項目一個專屬name),這時候可以用:

pm2 start npm --watch --name XXX -- run start

項目啓動:

OK pm2的項目啓動大概就這些了,日常還有些常用指令,如:

查看所用已啓動項目:

pm2 list

重啓:

pm2 restart XXX

停止:

pm2 stop XXX

刪除

pm2 delete XXX

……

如果不記得了,直接在控制檯輸入:pm2,控制檯會給出日常指令,並且會對這些指令給出對應說明:

 

以下更多使用PM2來部署nodejs項目:

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

  • supervisor是開發環境用。
  • forever管理多個站點,每個站點訪問量不大,不需要監控。
  • pm2 網站訪問量比較大,需要完整的監控界面。

PM2的主要特性:

  • 內建負載均衡(使用Node cluster 集羣模塊)
  • 後臺運行
  • 0秒停機重載,我理解大概意思是維護升級的時候不需要停機.
  • 具有Ubuntu和CentOS 的啓動腳本
  • 停止不穩定的進程(避免無限循環)
  • 控制檯檢測
  • 提供 HTTP API
  • 遠程控制和實時的接口API ( Nodejs 模塊,允許和PM2進程管理器交互 )

安裝

npm install -g pm2

用法

$ npm install -g pm2 命令行全局安裝pm2
$ pm2 start app.js 啓動app項目
$ pm2 list 列出由pm2管理的所有進程信息,還會顯示一個進程會被啓動多少次,因爲沒處理的異常。


屏幕快照 2017-02-24 11.57.30.png


$ pm2 monit 監視每個node進程的CPU和內存的使用情況


屏幕快照 2017-02-24 11.58.46.png


$ 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裏。如下:


屏幕快照 2017-02-24 12.14.07.png

通過npm run pm2來啓動。


寫的特別詳細,轉自https://www.cnblogs.com/lxg0/p/7771229.html

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章