PM2 使用介紹

GitHub 地址:https://github.com/Unitech/pm2node

寫在前面

文章主要來自豆瓣上一位同窗的文章:PM2 介紹,中間可能有部分修改!python

介紹

PM2 是一個帶有負載均衡功能的 Node 應用的進程管理器。git

當你要把你的獨立代碼利用所有的服務器上的全部 CPU,並保證進程永遠都活着,0 秒的重載, PM2 是完美的。它很是適合 IaaS 結構,但不要把它用於 PaaS 方案(隨後將開發 Paas 的解決方案)。github

備註:web

  • SaaS、PaaS 和 IaaS 是雲服務模式
  • SaaS 軟件即服務,例如 Google 的 Gmail 郵箱服務,面向應用型用戶
  • PaaS 平臺即服務,例如 Google 的 GAE,面向開發型用戶
  • IaaS 基礎架構即服務,例如亞馬遜的 AWS,IaaS 對於不知道新推出的應用程序/網站會有多成功的創業公司來講很是有用

請參考npm

雲服務模式:SaaS、PaaS 和 IaaS,哪種適合你?json

主要特性

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

測試過 Nodejs v0.11/v0.10/v0.8 版本,兼容 CoffeeScript,基於 Linux 和 MacOS。api

安裝

npm install -g pm2

用法

$ npm install pm2 -g     # 命令行安裝 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 (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  # 啓動 並 生成一個配置文件
你也能夠執行用其餘語言編寫的app  ( fork 模式):
$ pm2 start my-bash-script.sh    -x --interpreter bash
$ pm2 start my-python-script.py -x --interpreter python

0 秒停機重載:這項功能容許你從新載入代碼而不用失去請求鏈接。bash

注意:

  • 僅能用於 web 應用
  • 運行於 Node 0.11.x 版本
  • 運行於 cluster 模式(默認模式)
$ pm2 reload all

CoffeeScript:

$ pm2 start my_app.coffee  #這就是所有

PM2 準備好爲產品級服務了嗎?

只需在你的服務器上測試服務器

$ git clone https://github.com/Unitech/pm2.git
$ cd pm2
$ npm install  # 或者 npm install --dev ,若是devDependencies 沒有安裝
$ npm test

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

圖片描述

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

圖片描述

相關文章
相關標籤/搜索