最近2018中文字幕在日韩欧美国产成人片_国产日韩精品一区二区在线_在线观看成年美女黄网色视频_国产精品一区三区五区_国产精彩刺激乱对白_看黄色黄大色黄片免费_人人超碰自拍cao_国产高清av在线_亚洲精品电影av_日韩美女尤物视频网站

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時(shí)間:8:30-17:00
你可能遇到了下面的問(wèn)題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營(yíng)銷解決方案
nodejs高大上的部署方式(PM2)

如果直接通過(guò)node app來(lái)啟動(dòng),如果報(bào)錯(cuò)了可能直接停在整個(gè)運(yùn)行,supervisor感覺(jué)只是拿來(lái)用作開(kāi)發(fā)環(huán)境的。再網(wǎng)上找到pm2.目前似乎最常見(jiàn)的線上部署nodejs項(xiàng)目的有forever,pm2這兩種。

讓客戶滿意是我們工作的目標(biāo),不斷超越客戶的期望值來(lái)自于我們對(duì)這個(gè)行業(yè)的熱愛(ài)。我們立志把好的技術(shù)通過(guò)有效、簡(jiǎn)單的方式提供給客戶,將通過(guò)不懈努力成為客戶在信息化領(lǐng)域值得信任、有價(jià)值的長(zhǎng)期合作伙伴,公司提供的服務(wù)項(xiàng)目有:域名與空間、雅安服務(wù)器托管、營(yíng)銷軟件、網(wǎng)站建設(shè)、懷化網(wǎng)站維護(hù)、網(wǎng)站推廣。

使用場(chǎng)合:

  • supervisor是開(kāi)發(fā)環(huán)境用。
  • forever管理多個(gè)站點(diǎn),每個(gè)站點(diǎn)訪問(wèn)量不大,不需要監(jiān)控。
  • nodemon 是開(kāi)發(fā)環(huán)境使用,修改自動(dòng)重啟。
  • pm2 網(wǎng)站訪問(wèn)量比較大,需要完整的監(jiān)控界面。

PM2的主要特性:

  • 內(nèi)建負(fù)載均衡(使用Node cluster 集群模塊)
  • 后臺(tái)運(yùn)行
  • 0秒停機(jī)重載,我理解大概意思是維護(hù)升級(jí)的時(shí)候不需要停機(jī).
  • 具有Ubuntu和CentOS 的啟動(dòng)腳本
  • 停止不穩(wěn)定的進(jìn)程(避免無(wú)限循環(huán))
  • 控制臺(tái)檢測(cè)
  • 提供 HTTP API
  • 遠(yuǎn)程控制和實(shí)時(shí)的接口API ( Nodejs 模塊,允許和PM2進(jìn)程管理器交互 )

1、最常用的屬nohup了,其實(shí)就是在后臺(tái)執(zhí)行進(jìn)程,末尾加個(gè)&

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

即此時(shí)程序已啟動(dòng),直接訪問(wèn)即可,原程序的的標(biāo)準(zhǔn)輸出被自動(dòng)改向到當(dāng)前目錄下的nohup.out文件,起到了log的作用。該命令可以在你退出帳戶/關(guān)閉終端之后繼續(xù)運(yùn)行相應(yīng)的進(jìn)程。nohup就是不掛起的意思( no hang up)。

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

這個(gè)不太靠譜的樣子,經(jīng)常默默的進(jìn)程在后臺(tái)就掛了

2、用screen另開(kāi)一個(gè)屏幕,這種方式可以直接在屏幕上看到程序運(yùn)行情況

給該應(yīng)用程序開(kāi)個(gè)screen,如:screen -r ops ,用npm start啟動(dòng),

退出該后臺(tái):ctrl + a,再按d,可不能直接ctrl +c,否則就退出了

這種方式很不專業(yè),呵呵,不過(guò)方便看在生產(chǎn)環(huán)境的操作。

這個(gè)本質(zhì)上用的forever,package.json里配置的:

 "scripts": {
  "start": "forever app.js",
  "test": "supervisor app.js"
 },

3、PM2

使用它要先安裝它,用root賬號(hào)和全局模式安裝一下:

npm install -g pm2

用它來(lái)啟動(dòng)程序(在當(dāng)前目錄下可以直接啟動(dòng),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 ` to get more details about an app
[zhoujie@ops-dev uops]$

看,它顯示了Success,程序已經(jīng)默默的成功的啟動(dòng)了,可以實(shí)時(shí)監(jiān)控程序的運(yùn)行,比如執(zhí)行個(gè)pm2 restart,則上述restarted那欄變成1,可以顯示程序運(yùn)行了多長(zhǎng)時(shí)間、占用內(nèi)存大小,實(shí)在是太贊啦!

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

終止程序也很簡(jiǎn)單:pm2 stop

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

列舉出所有用pm2啟動(dòng)的程序: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 ` to get more details about an app

查看啟動(dòng)程序的詳細(xì)信息: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]$

通過(guò)pm2 list命令來(lái)觀察所有運(yùn)行的進(jìn)程以及它們的狀態(tài)已經(jīng)足夠好了.但是怎么來(lái)追蹤它們的資源消耗呢?別擔(dān)心,用這個(gè)命令:pm2 monit

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

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

實(shí)時(shí)集中l(wèi)og處理:pm2 logs

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

強(qiáng)大API: pm2 web

你想要監(jiān)控所有被PM2管理的進(jìn)程,而且同時(shí)還想監(jiān)控運(yùn)行這些進(jìn)程的機(jī)器的狀態(tài),

[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 ` to get more details about an app

啟動(dòng)程序的時(shí)候順便在瀏覽器訪問(wèn):http://localhost:9615

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

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

這東西對(duì)程序運(yùn)行的監(jiān)控頁(yè)面的開(kāi)發(fā)實(shí)在是太有幫助了,呵呵~~

監(jiān)控:pm2 monit
實(shí)時(shí)集中l(wèi)og處理: pm2 logs
API:pm2 web (端口:9615 )

常用命令總結(jié):

  • $ pm2 logs 顯示所有進(jìn)程日志
  • $ pm2 stop all 停止所有進(jìn)程
  • $ pm2 restart all 重啟所有進(jìn)程
  • $ pm2 reload all 0秒停機(jī)重載進(jìn)程 (用于 NETWORKED 進(jìn)程)
  • $ pm2 stop 0 停止指定的進(jìn)程
  • $ pm2 restart 0 重啟指定的進(jìn)程
  • $ pm2 startup 產(chǎn)生 init 腳本 保持進(jìn)程活著
  • $ pm2 web 運(yùn)行健壯的 computer API endpoint (http://localhost:9615)
  • $ pm2 delete 0 殺死指定的進(jìn)程
  • $ pm2 delete all 殺死全部進(jìn)程

運(yùn)行進(jìn)程的不同方式:

  • $ pm2 start app.js -i max 根據(jù)有效CPU數(shù)目啟動(dòng)最大進(jìn)程數(shù)目
  • $ pm2 start app.js -i 3 啟動(dòng)3個(gè)進(jìn)程
  • $ pm2 start app.js -x 用fork模式啟動(dòng) app.js 而不是使用 cluster
  • $ pm2 start app.js -x -- -a 23 用fork模式啟動(dòng) app.js 并且傳遞參數(shù) (-a 23)
  • $ pm2 start app.js --name serverone 啟動(dòng)一個(gè)進(jìn)程并把它命名為 serverone
  • $ pm2 stop serverone 停止 serverone 進(jìn)程
  • $ pm2 start app.json 啟動(dòng)進(jìn)程, 在 app.json里設(shè)置選項(xiàng)
  • $ pm2 start app.js -i max -- -a 23 在--之后給 app.js 傳遞參數(shù)
  • $ pm2 start app.js -i max -e err.log -o out.log 啟動(dòng) 并 生成一個(gè)配置文件

配置pm2啟動(dòng)文件

在項(xiàng)目根目錄添加一個(gè)processes.json:

內(nèi)容如下:

{
 "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
  }
 ]
}

說(shuō)明:

  • apps:json結(jié)構(gòu),apps是一個(gè)數(shù)組,每一個(gè)數(shù)組成員就是對(duì)應(yīng)一個(gè)pm2中運(yùn)行的應(yīng)用
  • name:應(yīng)用程序名稱
  • cwd:應(yīng)用程序所在的目錄
  • script:應(yīng)用程序的腳本路徑
  • log_date_format:
  • error_file:自定義應(yīng)用程序的錯(cuò)誤日志文件
  • out_file:自定義應(yīng)用程序日志文件
  • pid_file:自定義應(yīng)用程序的pid文件
  • instances:
  • min_uptime:最小運(yùn)行時(shí)間,這里設(shè)置的是60s即如果應(yīng)用程序在60s內(nèi)退出,pm2會(huì)認(rèn)為程序異常退出,此時(shí)觸發(fā)重啟max_restarts設(shè)置數(shù)量
  • max_restarts:設(shè)置應(yīng)用程序異常退出重啟的次數(shù),默認(rèn)15次(從0開(kāi)始計(jì)數(shù))
  • cron_restart:定時(shí)啟動(dòng),解決重啟能解決的問(wèn)題
  • watch:是否啟用監(jiān)控模式,默認(rèn)是false。如果設(shè)置成true,當(dāng)應(yīng)用程序變動(dòng)時(shí),pm2會(huì)自動(dòng)重載。這里也可以設(shè)置你要監(jiān)控的文件。
  • merge_logs:
  • exec_interpreter:應(yīng)用程序的腳本類型,這里使用的shell,默認(rèn)是nodejs
  • exec_mode:應(yīng)用程序啟動(dòng)模式,這里設(shè)置的是cluster_mode(集群),默認(rèn)是fork
  • autorestart:啟用/禁用應(yīng)用程序崩潰或退出時(shí)自動(dòng)重啟
  • vizion:啟用/禁用vizion特性(版本控制)

可以通過(guò)pm2 start processes.json來(lái)啟動(dòng)。

也可以把命令寫在package.json里。如下:

通過(guò)npm run start來(lái)啟動(dòng)。

關(guān)于pm2遠(yuǎn)程部署到多臺(tái)機(jī)器,參考:http://pm2.keymetrics.io/docs/usage/deployment/

官網(wǎng):http://pm2.keymetrics.io/docs/usage/quick-start/

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持創(chuàng)新互聯(lián)。


當(dāng)前名稱:nodejs高大上的部署方式(PM2)
本文路徑:http://fisionsoft.com.cn/article/gcdgei.html