<<編程基礎(chǔ)-語言JavaScript.Nodejs.Mobile>>

<<編程基礎(chǔ)-語言JavaScript.Nodejs.Mobile>>
https://github.com/openstf

<pre>

pm2forever是啟動(dòng)Nodejs服務(wù)常用到的兩個(gè)工具。使用這兩個(gè)指令可以使node服務(wù)在后臺(tái)運(yùn)行(類似于linux的nohup),另外它們可以在服務(wù)因異?;蚱渌虮粴⒌艉筮M(jìn)行自動(dòng)重啟。 由于Node的單線程特征,自動(dòng)重啟能很大程度上的提高它的健壯性。
本文不對(duì)比兩者工具優(yōu)劣,只是結(jié)合自己的使用,簡要介紹如何在工程部署時(shí)更好的使用pm2。

基本指令

npm install pm2 -g : 全局安裝。
pm2 start app.js : 啟動(dòng)服務(wù),入口文件是app.js。
pm2 start app.js -i [n] --name [name] : 啟動(dòng)n個(gè)進(jìn)程,名字命名為name。
npm restart [name or id] : 重啟服務(wù)。
npm reload [name or id] : 和rastart功能相同,但是可以實(shí)現(xiàn)0s的無縫銜接;如果有nginx的使用經(jīng)驗(yàn),可以對(duì)比nginx reload指令。
pm2 start app.js --max_memory_restart 1024M : 當(dāng)內(nèi)存超過1024M時(shí)自動(dòng)重啟。 如果工程中有比較棘手的內(nèi)存泄露問題,這個(gè)算是一個(gè)折中方案。
pm2 monit : 對(duì)服務(wù)進(jìn)行監(jiān)控。

更多的指令可以參考 PM2 介紹

高級(jí)用法

pm2支持配置文件啟動(dòng):
pm2 ecosystem: 生成配置文件ecosystem.json
pm2 startOrRestart /file/path/ecosystem.json : 通過配置文件啟動(dòng)服務(wù)

如下是我開發(fā)時(shí)ecosystem.json的內(nèi)容:

  {
    /**
    * Application configuration section
    * http://pm2.keymetrics.io/docs/usage/application-declaration/
    * 多個(gè)服務(wù),依次放到apps對(duì)應(yīng)的數(shù)組里
    */
    apps : [
    // First application
        {
            name      : "nova",
            max_memory_restart: "300M",
            script    : "/root/nova/app.js",
            out_file : "/logs/nova_out.log",
            error_file : "/logs/nova_error.log",
            instances  : 4,
            exec_mode  : "cluster",
            env: {
                NODE_ENV: "production"
            }
        }
    ]
 }

上述采用cluster模式啟動(dòng)了4個(gè)服務(wù)進(jìn)程;如果服務(wù)占用的內(nèi)存超過300M,會(huì)自動(dòng)進(jìn)行重啟。

監(jiān)控工具

pm2的監(jiān)控功能是其一大特色,它提供的監(jiān)控服務(wù)Keymetrics monitoring 很酷炫,感興趣的可以配置玩一下。

一些思考

1. 服務(wù)進(jìn)程數(shù)

至于要啟動(dòng)幾個(gè)進(jìn)程,可以通過服務(wù)器的內(nèi)核數(shù)進(jìn)行確定,幾個(gè)內(nèi)核就啟動(dòng)幾個(gè)服務(wù)。指令如下:

  # 查看物理CPU個(gè)數(shù)
  cat /proc/cpuinfo| grep "physical id" | sort| uniq | wc -l

  # 查看每個(gè)物理CPU中core的個(gè)數(shù)(即核數(shù))
  cat /proc/cpuinfo| grep "cpu cores"| uniq

  # 查看邏輯CPU的個(gè)數(shù)
  cat /proc/cpuinfo| grep "processor"| wc -l

當(dāng)然可以啟動(dòng)多個(gè)端口,一個(gè)端口號(hào)對(duì)應(yīng)一個(gè)服務(wù),這樣的話就需要nignx來做負(fù)載均衡了。

2. 是否需要nginx

nginx可以做的事情主要有兩個(gè):

  1. 反向代理,實(shí)現(xiàn)簡單的負(fù)載均衡: 如果有多臺(tái)服務(wù)器或者一臺(tái)服務(wù)器多個(gè)端口,可以考慮用nginx。

  2. 靜態(tài)資源緩存:把一些靜態(tài)資源(如靜態(tài)頁面,js等資源文件)放到nginx里,可以極大的提高服務(wù)的性能。

3. 自動(dòng)化部署

通過shell腳本實(shí)現(xiàn)資源拉取、服務(wù)重啟、nginx緩存更新等操作,再配合pm2的監(jiān)控功能,就初步達(dá)到了一個(gè)后端工程部署的標(biāo)配了。

參考資料:

  1. pm2官網(wǎng)

  2. node-deploy-practice

  3. pm2監(jiān)控

pm2是非常優(yōu)秀工具,它提供對(duì)基于node.js的項(xiàng)目運(yùn)行托管服務(wù)。它基于命令行界面,提供很多特性: 內(nèi)置的負(fù)載均衡器等等,下面我們就一起來看看吧。

一、簡介

pm2是一個(gè)帶有負(fù)載均衡功能的應(yīng)用進(jìn)程管理器,類似有Supervisor,forever。

二、安裝

Linux Binaries下載地址:https://nodejs.org/dist
cd oneinstack/src
wget https://nodejs.org/dist/v4.2.4/node-v4.2.4-linux-x64.tar.gz
tar xzf node-v4.2.4-linux-x64.tar.gz
cp node-v4.2.4-linux-x64/bin/node /usr/local/bin/
cp -R node-v4.2.4-linux-x64/lib/node_modules /usr/local/lib/
ln -s /usr/local/lib/node_modules/npm/bin/npm-cli.js /usr/local/bin/npm
npm install pm2@latest -g #安裝最新版本pm2模塊
PS: 如果你的主機(jī)無法連接公網(wǎng),先找到能連公網(wǎng)的主機(jī)安裝上面的方法安裝pm2,然后拷貝到你要安裝的主機(jī)。拷貝如下目錄:
/usr/local/bin/node
/usr/local/lib/node_modules
再創(chuàng)建相關(guān)軟連接

三、PM2常用命令

假設(shè)你現(xiàn)在已經(jīng)寫好了一個(gè)app.js的文件,需要啟動(dòng),你可以使用pm2進(jìn)行管理

1. 啟動(dòng)

pm2 start app.js

pm2 start app.js --name my-api #my-api為PM2進(jìn)程名稱

pm2 start app.js -i 0 #根據(jù)CPU核數(shù)啟動(dòng)進(jìn)程個(gè)數(shù)

pm2 start app.js --watch #實(shí)時(shí)監(jiān)控app.js的方式啟動(dòng),當(dāng)app.js文件有變動(dòng)時(shí),pm2會(huì)自動(dòng)reload

2. 查看進(jìn)程

pm2 list

pm2 show 0 或者 # pm2 info 0 #查看進(jìn)程詳細(xì)信息,0為PM2進(jìn)程id

3. 監(jiān)控

pm2 monit

4. 停止

pm2 stop all #停止PM2列表中所有的進(jìn)程

pm2 stop 0 #停止PM2列表中進(jìn)程為0的進(jìn)程

5. 重載

pm2 reload all #重載PM2列表中所有的進(jìn)程

pm2 reload 0 #重載PM2列表中進(jìn)程為0的進(jìn)程

6. 重啟

pm2 restart all #重啟PM2列表中所有的進(jìn)程

pm2 restart 0 #重啟PM2列表中進(jìn)程為0的進(jìn)程

7. 刪除PM2進(jìn)程

pm2 delete 0 #刪除PM2列表中進(jìn)程為0的進(jìn)程

pm2 delete all #刪除PM2列表中所有的進(jìn)程

8. 日志操作

pm2 logs [--raw] #Display all processes logs in streaming

pm2 flush #Empty all log file

pm2 reloadLogs #Reload all logs

9. 升級(jí)PM2

npm install pm2@lastest -g #安裝最新的PM2版本

pm2 updatePM2 #升級(jí)pm2

10. 更多命令參數(shù)請(qǐng)查看幫助

pm2 --help

四、PM2目錄結(jié)構(gòu)

默認(rèn)的目錄是:當(dāng)前用于的家目錄下的.pm2目錄(此目錄可以自定義,請(qǐng)參考:五、自定義啟動(dòng)文件),詳細(xì)信息如下:
$HOME/.pm2 #will contain all PM2 related files
$HOME/.pm2/logs #will contain all applications logs
$HOME/.pm2/pids #will contain all applications pids
$HOME/.pm2/pm2.log #PM2 logs
$HOME/.pm2/pm2.pid #PM2 pid
$HOME/.pm2/rpc.sock #Socket file for remote commands
$HOME/.pm2/pub.sock #Socket file for publishable events
$HOME/.pm2/conf.js #PM2 Configuration

五、自定義啟動(dòng)文件

創(chuàng)建一個(gè)test.json的示例文件,格式如下:
{
"apps":
{
"name": "test",
"cwd": "/data/wwwroot/nodejs",
"script": "./test.sh",
"exec_interpreter": "bash",
"min_uptime": "60s",
"max_restarts": 30,
"exec_mode" : "cluster_mode",
"error_file" : "./test-err.log",
"out_file": "./test-out.log",
"pid_file": "./test.pid"
"watch": false
}
}

說明:

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)用程序的腳本路徑
exec_interpreter:應(yīng)用程序的腳本類型,這里使用的shell,默認(rèn)是nodejs
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開始計(jì)數(shù))
exec_mode:應(yīng)用程序啟動(dòng)模式,這里設(shè)置的是cluster_mode(集群),默認(rèn)是fork
error_file:自定義應(yīng)用程序的錯(cuò)誤日志文件
out_file:自定義應(yīng)用程序日志文件
pid_file:自定義應(yīng)用程序的pid文件
watch:是否啟用監(jiān)控模式,默認(rèn)是false。如果設(shè)置成true,當(dāng)應(yīng)用程序變動(dòng)時(shí),pm2會(huì)自動(dòng)重載。這里也可以設(shè)置你要監(jiān)控的文件。
詳細(xì)參數(shù)列表:見附件八

六、實(shí)例

已上面的test.json為例

cat > /data/wwwroot/nodejs/test.sh << EOF

!/bin/bash

while :
do
echo "Test" >> 1.log
sleep 5
done
EOF

chmod +x test.sh #添加執(zhí)行權(quán)限

pm2 start test.json #啟動(dòng),如下圖:

[圖片上傳失敗...(image-291475-1511349583307)]

pm2 list #查看pm2進(jìn)程,如下圖:

[圖片上傳失敗...(image-1f3f2c-1511349583307)]

七、備注
其他可參數(shù)見官網(wǎng):http://pm2.keymetrics.io

====================================================================================================================

安裝:npm install -g pm2

啟動(dòng)程序:pm2 start <app_name|id|all>

列舉進(jìn)程:pm2 list

退出程序:pm2 stop <app_name|id|all>

重起應(yīng)用:pm2 restart

程序信息:pm2 describe id|all

監(jiān)控:pm2 monit

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

API:pm2 web (端口:9615 )

<pre>

使用PM2來部署nodejs項(xiàng)目。

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

  • supervisor是開發(fā)環(huán)境用。

  • forever管理多個(gè)站點(diǎn),每個(gè)站點(diǎn)訪問量不大,不需要監(jiān)控。

  • pm2 網(wǎng)站訪問量比較大,需要完整的監(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)程(避免無限循環(huán))

  • 控制臺(tái)檢測(cè)

  • 提供 HTTP API

  • 遠(yuǎn)程控制和實(shí)時(shí)的接口API ( Nodejs 模塊,允許和PM2進(jìn)程管理器交互 )

安裝

npm install -g pm2

用法

$ npm install -g pm2 命令行全局安裝pm2
$ pm2 start app.js 啟動(dòng)app項(xiàng)目
$ pm2 list 列出由pm2管理的所有進(jìn)程信息,還會(huì)顯示一個(gè)進(jìn)程會(huì)被啟動(dòng)多少次,因?yàn)闆]處理的異常。

image

$ pm2 monit 監(jiān)視每個(gè)node進(jìn)程的CPU和內(nèi)存的使用情況

image

$ 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
    }
  ]
}

說明:

  • 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開始計(jì)數(shù))

  • cron_restart:定時(shí)啟動(dòng),解決重啟能解決的問題

  • 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特性(版本控制)

可以通過pm2 start processes.json來啟動(dòng)。
也可以把命令寫在package.json里。如下:

image

pm2 是一個(gè)帶有負(fù)載均衡功能的Node應(yīng)用的進(jìn)程管理器.

當(dāng)你要把你的獨(dú)立代碼利用全部的服務(wù)器上的所有CPU,并保證進(jìn)程永遠(yuǎn)都活著,0秒的重載, PM2是完美的。它非常適合IaaS結(jié)構(gòu),但不要把它用于PaaS方案(隨后將開發(fā)Paas的解決方案).

備注:SaaS、PaaS和IaaS是云服務(wù)模式。
SaaS 軟件即服務(wù),例如Google的 Gmail 郵箱服務(wù).面向應(yīng)用型用戶.
PaaS 平臺(tái)即服務(wù).例如Google的GAE,面向開發(fā)型用戶
IaaS 基礎(chǔ)架構(gòu)即服務(wù),例如亞馬遜的AWS,IaaS對(duì)于不知道新推出的應(yīng)用程序/網(wǎng)站會(huì)有多成功的創(chuàng)業(yè)公司來說非常有用

請(qǐng)參考
云服務(wù)模式:SaaS、PaaS和IaaS,哪一種適合你?

主要特性:

內(nèi)建負(fù)載均衡(使用Node cluster 集群模塊)

后臺(tái)運(yùn)行

0秒停機(jī)重載,我理解大概意思是維護(hù)升級(jí)的時(shí)候不需要停機(jī).

具有Ubuntu和CentOS 的啟動(dòng)腳本

停止不穩(wěn)定的進(jìn)程(避免無限循環(huán))

控制臺(tái)檢測(cè)

提供 HTTP API

遠(yuǎn)程控制和實(shí)時(shí)的接口API ( Nodejs 模塊,允許和PM2進(jìn)程管理器交互 )

測(cè)試過Nodejs v0.11 v0.10 v0.8版本,兼容CoffeeScript,基于Linux 和MacOS.

安裝

npm install -g pm2

用法

$ npm install pm2 -g # 命令行安裝 pm2

$ pm2 start app.js -i 4 #后臺(tái)運(yùn)行pm2,啟動(dòng)4個(gè)app.js

                            # 也可以把'max' 參數(shù)傳遞給 start

                            # 正確的進(jìn)程數(shù)目依賴于Cpu的核心數(shù)目

$ pm2 start app.js --name my-api # 命名進(jìn)程

$ pm2 list # 顯示所有進(jìn)程狀態(tài)

$ pm2 monit # 監(jiān)視所有進(jìn)程

$ 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è)配置文件

你也可以執(zhí)行用其他語言編寫的app ( fork 模式):

$ pm2 start my-bash-script.sh -x --interpreter bash

$ pm2 start my-python-script.py -x --interpreter python

0秒停機(jī)重載:

這項(xiàng)功能允許你重新載入代碼而不用失去請(qǐng)求連接。

注意:

僅能用于web應(yīng)用

運(yùn)行于Node 0.11.x版本

運(yùn)行于 cluster 模式(默認(rèn)模式)

$ pm2 reload all

CoffeeScript:

$ pm2 start my_app.coffee #這就是全部

PM2準(zhǔn)備好為產(chǎn)品級(jí)服務(wù)了嗎?

只需在你的服務(wù)器上測(cè)試

$ git clone

https://github.com/Unitech/pm2.git

$ cd pm2

$ npm install # 或者 npm install --dev ,如果devDependencies 沒有安裝

$ npm test

pm2 list

列出由pm2管理的所有進(jìn)程信息,還會(huì)顯示一個(gè)進(jìn)程會(huì)被啟動(dòng)多少次,因?yàn)闆]處理的異常。

|
image

|
| |

pm2 monit

監(jiān)視每個(gè)node進(jìn)程的CPU和內(nèi)存的使用情況。

|
image

|

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容