前言
對於大部分程式設計師來說,主要工作都是進行編碼以及一些簡單的中間件安裝,這就導致了很多人對於「運維」相關的工作會比較生疏。例如當我們擁有一臺自己的伺服器以後,可能會在上面跑一跑自己blog程序,mysql,nginx等等。當程序越來越多了沒有一個統一的入口管理啟停,也可能會遇到一些特殊的原因導致程序被kill掉了,這時候又沒裝相關的監控程序或者腳本(太麻煩了懶得裝,機器配置差不想裝),所以只能當我們訪問自己程序發現異常的時候才會登上伺服器查找原因。
這些狀況對我們來說是比較麻煩的,那麼這就需要一個「神器」來解放我們的雙手,鐺鐺鐺!!Supervisor 就來了。
正文
Supervisor 介紹
Supervisor是用Python開發的一套通用的進程管理程序,能將一個普通的命令行進程變為後臺daemon,並監控進程狀態,異常退出時能自動重啟。它是通過fork/exec的方式把這些被管理的進程當作supervisor的子進程來啟動,這樣只要在supervisor的配置文件中,把要管理的進程的可執行文件的路徑寫進去即可。也實現當子進程掛掉的時候,父進程可以準確獲取子進程掛掉的信息的,可以選擇是否自己啟動和報警。
supervisor 安裝
簡單粗暴
yum install supervisor -y
supervisor 配置說明
通過這種形式安裝的supervisor,其配置文件的目錄位於:/etc/supervisord.conf (主配置文件,下面會詳細介紹)/etc/supervisor.d/ (默認子進程配置文件,也就是需要我們根據程序配置的地方)
supervisord.conf 基本配置項說明,由於其參數比較多,這些只貼出一些常用的配置項,詳細內容可參閱官網。溫馨提示 「;」 符號是表示該行配置被注釋。
[unix_http_server]file=/home/supervisor/supervisor.sock ; supervisorctl使用的 socket文件的路徑;chmod=0700 ; 默認的socket文件權限0700;chown=nobody:nogroup ; socket文件的擁有者[inet_http_server]; 提供web管理後臺管理相關配置port=0.0.0.0:9001 ; web管理後臺運行的ip地址及埠,綁定外網需考慮安全性 ;username=root ; web管理後臺登錄用戶名密碼;password=root[supervisord]logfile=/var/log/supervisord.log ; 日誌文件,默認在$CWD/supervisord.loglogfile_maxbytes=50MB ; 日誌限制大小,超過會生成新文件,0表示不限制logfile_backups=10 ; 日誌備份數量默認10,0表示不備份loglevel=info ; 日誌級別pidfile=/home/supervisor/supervisord.pid ; supervisord pidfile; default supervisord.pid ; pid文件nodaemon=false ; 是否在前臺啟動,默認後臺啟動falseminfds=1024 ; 可以打開文件描述符最小值minprocs=200 ; 可以打開的進程最小值[supervisorctl]serverurl=unix:///home/supervisor/supervisor.sock ; 通過socket連接supervisord,路徑與unix_http_server->file配置的一致[include]files = supervisor.d/*.conf ;指定了在當前目錄supervisor.d文件夾下配置多個配置文件
準備測試項目
這裡我打包了一個簡單的spring-boot程序,存放與「/opt/project/」下。
在這個程序中我們只是簡單的定義了一個rest接口,主要用於演示作用。
@RestControllerpublicclassHelloController{ @RequestMapping("/hello") public String hello(){ return"hello world"; }}
如果不用supervisor的話,我們啟動程序一般用一下命令
nohup java -jar springboot-hello-sample.jar &
這是以後臺的方式啟動jar包,程序運行相關輸出會在nohup.out中,我們我們就不再贅述了,那麼我們來看一下,切換到supervisor的方式,我們是怎麼配置項目,以及管理的呢?
定義supervisor管理進程配置文件
從上面的配置文件[include]->files配置項我們可以知道,supervisor會把supervisor.d/下以conf結尾的配置文件都加載進來,那麼我們在這個目錄下面新建一個sboot.conf,內容如下:
[program:sboot];[program:xxx] 這裡的xxx是指的項目名字directory = /opt/project ;程序所在目錄command = java -jar springboot-hello-sample.jar ;程序啟動命令autostart=true ;是否跟隨supervisord的啟動而啟動autorestart=true; 程序退出後自動重啟,可選值:[unexpected,true,false],默認為unexpected,表示進程意外殺死後才重啟stopasgroup=true;進程被殺死時,是否向這個進程組發送stop信號,包括子進程killasgroup=true;向進程組發送kill信號,包括子進程stdout_logfile=/var/log/sboot/supervisor.log;該程序日誌輸出文件,目錄需要手動創建stdout_logfile_maxbytes = 50MB;日誌大小stdout_logfile_backups = 100;備份數
可以看到,在配置文件裡面已經有配置該程序名,啟動路徑等,這樣一來,supervisor就可以完全的掌管程序的生死了。接著我們執行
service supervisord restart
重啟supervisord。
觀察效果
瀏覽器輸入:伺服器ip:9001 (這裡的web管理頁面埠是在配置文件配置好的。)
如圖所示,我們可以可以觀察到springboot程序已經是running狀態了,pid是27517,我們可以點擊Tail -f拉力觀察輸出日誌,它的作用跟我們在伺服器直接「tail -f」是類似的。
這裡我們為了方便延時就沒有添加驗證了,如果大家是在公網的使用環境,需要配置文件裡面的用戶名密碼驗證注釋打開。不然別人掃出你的後臺管理頁面就可以隨意控制程序了。
除了web管理頁面,還有一些簡單的命令也是需要我們掌握的。
直接在命令行輸入supervisorctl會展示當前已配置好的項目信息。
[root@wangzh supervisor.d]# supervisorctlsbootRUNNINGpid 27517, uptime 0:18:04supervisor>
然後可以執行
start/stop/restart sboot 來簡單控制項目的啟停等
supervisorctl update #更新配置文件supervisorctl reload #重新啟動配置的程序supervisorctl stop all #停止全部管理進程
結語
只需要一點簡單的配置,就可以統一的管理我們的程序了,同時也可以在進程意外死掉的時候自動重啟,這些工作以後就交給supervisor了,我們只要掌握一點簡單的命令就可以「為所欲為」。