簡介
supervisor是用python開發的乙個client/server服務,是linux/unix系統下的乙個程序管理工具。可以很方便的監聽、啟動、停止、重啟乙個或多個程序。用supervisor管理的程序,當乙個程序意外被殺死,supervisor監聽到程序死後,會自動將它重啟,很方便的做到程序自動恢復的功能,不再需要自己寫shell指令碼來控制。
安裝配置好yum源後,可以直接安裝
yum install supervisor
配置安裝好後在/etc/會生成乙個supervisord.conf檔案及乙個supervisord.d檔案目錄
supervisord.conf是一些預設配置,可自行修改:
file=/tmp/supervisor.sock ;unix socket 檔案,supervisorctl 會使用
;chmod=0700 ;socket檔案的mode,預設是0700
;chown=nobody:nogroup ;socket檔案的owner,格式:uid:gid
;[inet_http_server] ;http伺服器,提供web管理介面
;port=127.0.0.1:9001 ;web管理後台執行的ip和埠,如果開放到公網,需要注意安全性
;username=user ;登入管理後台的使用者名稱
;password=123 ;登入管理後台的密碼
[supervisord]
logfile=/tmp/supervisord.log ;日誌檔案,預設是 $cwd/supervisord.log
logfile_maxbytes=50mb ;日誌檔案大小,超出會rotate,預設 50mb,如果設成0,表示不限制大小
logfile_backups=10 ;日誌檔案保留備份數量預設10,設為0表示不備份
loglevel=info ;日誌級別,預設info,其它: debug,warn,trace
pidfile=/tmp/supervisord.pid ;pid 檔案
nodaemon=false ;是否在前台啟動,預設是false,即以 daemon 的方式啟動
minfds=1024 ;可以開啟的檔案描述符的最小值,預設 1024
minprocs=200 ;可以開啟的程序數的最小值,預設 200
[supervisorctl]
serverurl=unix:///tmp/supervisor.sock ;通過unix socket連線supervisord,路徑與unix_http_server部分的file一致
;serverurl= ; 通過http的方式連線supervisord
; [program:xx]是被管理的程序配置引數,xx是程序的名稱
[program:xx]
command=/opt/apache-tomcat-8.0.35/bin/catalina.sh run ; 程式啟動命令
autostart=true ; 在supervisord啟動的時候也自動啟動
startsecs=10 ; 啟動10秒後沒有異常退出,就表示程序正常啟動了,預設為1秒
autorestart=true ; 程式退出後自動重啟,可選值:[unexpected,true,false],預設為unexpected,表示程序意外殺死後才重啟
startretries=3 ; 啟動失敗自動重試次數,預設是3
user=tomcat ; 用哪個使用者啟動程序,預設是root
priority=999 ; 程序啟動優先順序,預設999,值小的優先啟動
redirect_stderr=true ; 把stderr重定向到stdout,預設false
stdout_logfile_maxbytes=20mb ; stdout 日誌檔案大小,預設50mb
stdout_logfile_backups = 20 ; stdout 日誌檔案備份數,預設是10
; stdout 日誌檔案,需要注意當指定目錄不存在時無法正常啟動,所以需要手動建立目錄(supervisord 會自動建立日誌檔案)
stdout_logfile=/opt/apache-tomcat-8.0.35/logs/catalina.out
stopasgroup=false ;預設為false,程序被殺死時,是否向這個程序組傳送stop訊號,包括子程序
killasgroup=false ;預設為false,向程序組傳送kill訊號,包括子程序
;包含其它配置檔案
[include]
files = relative/directory/*.ini ;可以指定乙個或多個以.ini結束的配置檔案
注意:[include]預設配置是制定*.ini,因個人習慣命名為*.conf檔案,因此修改配置如下:
[include]
files = relative/directory/*.conf
supervisord.d目錄用來存放使用者自定義的程序配置,參考:
[program:es]
command=/opt/software/elasticsearch/bin/elasticsearch
user=es
stdout_logfile=/opt/supervisor_test/run.log
autostart=true
autorestart=true
startsecs=60
stopasgroup=true
ikillasgroup=true
startretries=1
redirect_stderr=true
注意: supervisor不能監控後台程序,command 不能為後台執行命令
服務段啟動
supervisord -c /etc/supervisord.conf
常用命令介紹
supervisorctl 是 supervisord的命令列客戶端工具
supervisorctl status:檢視所有程序的狀態
supervisorctl stop es:停止es
supervisorctl start es:啟動es
supervisorctl restart es: 重啟es
supervisorctl update :配置檔案修改後可以使用該命令載入新的配置
supervisorctl reload: 重新啟動配置中的所有程式
...把es 換成all 可以管理配置中的所有程序
直接輸入:supervisorctl 進入supervisorctl 的shell互動介面,上面的命令不帶supervisorctl 可直接使用
踩過的坑
1、unix:///var/run/supervisor/supervisor.sock no such file
問題描述:安裝好supervisor沒有開啟服務直接使用supervisorctl報的錯
解決辦法:supervisord -c /etc/supervisord.conf
2、command中指定的程序已經起來,但supervisor還不斷重啟
問題描述:command中啟動方式為後台啟動,導致識別不到pid,然後不斷重啟,本人使用的是elasticsearch,command 指定的是$path/bin/elasticsearch -d,踩到的坑
解決辦法:supervisor無法檢測後台啟動程序的pid,而supervisor本身就是後台啟動守護程序,因此不用擔心這個
3、啟動了多個supervisord服務,導致無法正常關閉服務
問題描述:在執行supervisord -c /etc/supervisord.conf 之前,我直接執行過supervisord -c /etc/supervisord.d/xx.conf ,導致有些程序被多個superviord管理,無法正常關閉程序。
supervisor使用詳解
1.什麼是supervisor supervisor是用python寫的乙個程序管理工具,用來啟動,重啟,關閉程序。2.supervisor的安裝 pip install supervisor3.supervisor的配置檔案 supervisor安裝完畢後,會有乙個配置檔案supervisord....
supervisor 使用詳解
簡介 supervisor是用python開發的乙個client server服務,是linux unix系統下的乙個程序管理工具。可以很方便的監聽 啟動 停止 重啟乙個或多個程序。用supervisor管理的程序,當乙個程序意外被殺死,supervisor監聽到程序死後,會自動將它重啟,很方便的做...
supervisor 使用詳解
簡介 supervisor是用python開發的乙個client server服務,是linux unix系統下的乙個程序管理工具。可以很方便的監聽 啟動 停止 重啟乙個或多個程序。用supervisor管理的程序,當乙個程序意外被殺死,supervisor監聽到程序死後,會自動將它重啟,很方便的做...