中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

nodejs高大上的部署方式(PM2)

發布時間:2020-08-27 22:35:35 來源:腳本之家 閱讀:183 作者:單曲蕁環 欄目:web開發

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

使用場合:

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

PM2的主要特性:

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

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

[zhoujie@ops-dev ~]$ 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)

[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,程序已經默默的成功的啟動了,可以實時監控程序的運行,比如執行個pm2 restart,則上述restarted那欄變成1,可以顯示程序運行了多長時間、占用內存大小,實在是太贊啦!

nodejs高大上的部署方式(PM2)

終止程序也很簡單:pm2 stop

nodejs高大上的部署方式(PM2)

列舉出所有用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 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        │
└───────────────────┴─────────────────────────────────────────┘
[zhoujie@ops-dev uops]$

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

可以得到進程(以及集群)的CPU的使用率和內存占用(ctrl +c 退出)

nodejs高大上的部署方式(PM2)

實時集中log處理:pm2 logs

nodejs高大上的部署方式(PM2)

強大API: pm2 web

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

[zhoujie@ops-dev 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

擦,我眼睛被亮瞎了,這么炫酷,竟然把部署的服務器的信息和程序的信息都顯示出來了:

nodejs高大上的部署方式(PM2)

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

監控: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里。如下:

通過npm run start來啟動。

關于pm2遠程部署到多臺機器,參考:http://pm2.keymetrics.io/docs/usage/deployment/

官網:http://pm2.keymetrics.io/docs/usage/quick-start/

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持億速云。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

沭阳县| 桑日县| 龙江县| 南丹县| 雅安市| 双峰县| 深州市| 平昌县| 黔西县| 界首市| 长治县| 桂平市| 玛纳斯县| 渭南市| 洪江市| 兰西县| 武冈市| 五大连池市| 建阳市| 灵山县| 皋兰县| 鄂伦春自治旗| 深水埗区| 吴桥县| 印江| 泾源县| 建平县| 长岭县| 黑龙江省| 连平县| 兴安盟| 敦煌市| 平远县| 乌兰察布市| 军事| 雷波县| 嘉兴市| 施秉县| 武邑县| 贺州市| 隆子县|