今天介紹一個生產級的流程管理工具 PM2,通常我們說到 PM2 的時候,都是在說如何部署 Node.js 程式,但是實際上 PM2 很強大,不僅僅可以用來管理 Node.js,它還可以用來管理 Python、PHP、Ruby、perl 等等。
這裡就以 Python 舉例子,來看看 PM2 如何部署管理 Python 指令碼。
PM2-Python
PM2 是一個生產級流程管理器,可以輕鬆管理後臺程序,在 Python 的世界中,PM2 是可以和 Supervisord 相媲美的,並且 PM2 還有一些非常棒的功能。
使用 PM2,讓崩潰重啟、觀察、檢查日誌甚至部署應用程式,都變的簡單,並且 PM2 非常重視在命令列介面的操作體驗,因此 PM2 非常易於使用和掌握。
PM2 發展到今天,已經 5 年了,在 Github 上有超過 6500w 次下載,已經成為在生產伺服器中執行 Node.js 的首選方式之一。但是它也支援 Python。
安裝 PM2
PM2 依賴於 Node.js,所以需要提前安裝 Node,這一步非常簡單:
curl -sL | sudo -E bash -
sudo apt-get install -y nodejs
其他平臺如何安裝 Node.js,可自行查詢教程。
有了 Node 的環境後,就可以通過 npm 來安裝 PM2 了。
$ sudo npm install pm2 -g
要初始化 PM2 ,可以使用 pm2 ls 命令,此時就可以看到一個很友好的介面。
現在,已經成功安裝好 PM2 了,讓我們啟動一個 Python 應用吧。
啟動 Python
使用 PM2 啟動應用非常的簡單,它講根據指令碼擴充套件自動匹配直譯器,用以執行指定的應用程式。
我們先建立一個簡單的 Python 應用程式,例如:hello.py。
#!/usr/bin/python
import time
while 1:
print("Start: %s" % time.ctime())
time.sleep(1)
我們有了一個簡單的 Python 指令碼,接下來我們就用 PM2 去啟動它。
$ pm2 start hello.py
然後在 Terminal 裡就可以看到該程序了。
到這一步,這個 Python 程式就將永遠的執行下去,這意味著如果該程序退出或者丟擲異常,它將被自動重啟。
此處的 mode 為 fork,也就是關閉當前的 Terminal 視窗,它依然可以檢查到此應用的狀態。
想要檢視 PM2 執行管理的應用程式,可以使用 pm2 ls 命令進行檢視。
檢查日誌
通過 PM2 執行的程式,如果想要檢視 Log,可以輸入 pm2 logs 命令。
如果想要指定檢視某個程序的 Log,可以使用 pm2 logs <app_name> 進行指定。
另外 PM2 還提供了自動化的日誌輪換功能,但是需要安裝 pm2-logrotate
$ pm2 install pm2-logrotate
pm2-logrotate 將提供每天日誌輪換更新的功能,並保持總的日誌控制元件大小為 10M。
檢視某程序的資訊
想要檢視當前使用 PM2 啟動的程式的詳細資訊,可以使用 pm describe <app_name> 命令進行檢視。
在輸出中,可以看到日誌檔案的路徑,已經直譯器等資訊。
管理 PM2 的程序狀態
介紹完啟動和檢視日誌,再看幾個簡單的管理命令。
1. 停止某個程式
$ pm2 stop hello
2. 重啟某個程式
$ pm2 restart hello
$ pm2 delete hello
更多的命令,可以直接檢視官方文件。
伺服器重啟時,依然保持執行
使用 PM2 啟動 Python 程式之後,PM2 只能保證啟動的這個 Python 程式發生意外崩潰的時候,對他進行重啟。如果你希望在重啟伺服器的時候,依然保持應用程式線上,則需要設定 init 指令碼,用以告訴系統啟動 PM2 以及你的應用程式。
想讓 PM2 跟隨系統啟動,只需要執行此命令。
$ pm2 startup
startup 可以生成一個設定環境變數的命令。
æªå¾ - ä" - 2018-09-19-13-05-39
複製/貼上此命令的最後一行,執行後將在系統重啟時,自動啟動 PM2。
現在已經可以重啟 PM2 了,還需要告訴 PM2 那些程序狀態需要在重啟時保持不變,只需要輸入命令:
$ pm2 save
這將建立一個轉存檔案,記錄當前由 PM2 管理的程序狀態,PM2 將在重啟時,按照之前的狀態恢復他們。
監聽 CPU/記憶體資訊
要監聽 CPU/記憶體並檢查有關程序的一些資訊,需要使用 pm2 monit 命令。
這將開啟一個 termcaps 介面,允許試試了解正在執行的應用程式。
你還可以使用 pm2 show <app_name> 獲取有關應用程式的所有可能資訊。
使用 Ecosystem 檔案
如果有多個程式需要啟動,或者在啟動的時候需要傳遞不同的引數、選項等,可以使用 eocsystem 檔案對應用程式進行配置。
Eocsystem 需要通過 ecosystem.config.js 檔案進行配置,此檔案可以通過 pm2 init 命令生成。生成好後,我們可以在其中配置一些配置資訊。
module.exports = {
apps : [{
name: 'echo-python',
cmd: 'hello.py',
args: 'arg1 arg2',
autorestart: false,
watch: true,
pid: '/path/to/pid/file.pid',
instances: 4,
max_memory_restart: '1G',
env: {
ENV: 'development'
},
env_production : {
ENV: 'production'
}
}, {
name: 'echo-python-3',
cmd: 'hello.py',
interpreter: 'python3'
}]
};
在這個例子中,我們聲明了兩個應用程式,通過 interpreter 配置程式啟動的直譯器,一個使用 Python2 (預設)執行,另一個使用 Python3 執行。
啟動它,依然使用 pm2 start 命令。
$ pm2 start ecosystem.config.js
想要單獨重啟 “production” (env_production):
$ pm2 restart ecosystem.config.js --env production
Ecosystem.config.js 檔案中,很多配置都是可以通過命令來指定,例如,可以通過 --interpreter 來指定解析程式。
通常我們會同時安裝 Python2.x 和 Python3.x 的環境,而 PM2 在預設情況下,是通過指令碼檔案字尾來判斷的,如果沒有後綴就需要強制指定 --interpreter 。
{
".sh": "bash",
".py": "python",
".rb": "ruby",
".coffee" : "coffee",
".php": "php",
".pl" : "perl",
".js" : "node"
}
這些配置資訊也標記了 PM2 支援的指令碼程式。
那麼如果需要使用 Python3.x 來執行某個指令碼,就需要 --interpreter 了。
$ pm2 start hello.py --interpreter=python3
小結
PM2 的簡單使用,就先介紹到這裡。雖然這裡使用 Python 來舉例,但是本文所有相關命令,是可以適用其他 PM2 支援的指令碼程式。
PM2 還有很多強大的功能,比如說利用 SSH 輕鬆部署到伺服器、負載均衡等等都是一些不錯的功能,有興趣可以查閱文件。PM2 文件很健全,大部分問題都可以在文件中找到答案。