摘要:首發于樊浩柏科學院是一款使用開發的非常優秀的進程管理工具。它可以在類系統上讓用戶精確地監視與控制多組指定數量的服務進程。當監控的服務進程意外退出時,會嘗試自動重啟這些服務,以保持服務可用狀態。安裝官方提供的安裝方式較多,這里采用方式安裝。
首發于 樊浩柏科學院
Supervisor 是一款使用 Python 開發的非常優秀的進程管理工具。它可以在類 UNIX 系統上讓用戶精確地監視與控制多組指定數量的服務進程。當監控的服務進程意外退出時,會嘗試自動重啟這些服務,以保持服務可用狀態。
安裝Supervisor 官方 提供的安裝方式較多,這里采用 pip 方式安裝。
安裝pip$ yum install python-pip # 升級pip $ pip install --upgrade pip $ pip -V pip 9.0.1安裝Supervisor
通過 pip 安裝 Supervisor:
$ pip install supervisor Successfully installed supervisor-3.3.3
安裝 Supervisor 后,會出現 supervisorctl 和 supervisord 兩個程序,其中 supervisorctl 為服務監控終端,而 supervisord 才是所有監控服務的大腦。查看 supervisord 是否安裝成功:
$ supervisord -v 3.3.3開機啟動
將 supervisord 配置成開機啟動服務,下載官方 init 腳本。
修改關鍵路徑配置:
PIDFILE=/var/run/supervisord.pid LOCKFILE=/var/lock/subsys/supervisord OPTIONS="-c /etc/supervisord.conf"
移到該文件到/etc/init.d目錄下,并重命名為 supervisor,添加可執行權限:
$ chmod 777 /etc/init.d/supervisor
配置成開機啟動服務:
$ chkconfig --add supervisor $ chkconfig supervisor on $ chkconfig --list | grep "supervisor" supervisor 0:off 1:off 2:on 3:on 4:on 5:on 6:off配置 生成配置文件
Supervisord 安裝后,需要使用如下命令生成配置文件。
$ mkdir /etc/supervisor $ echo_supervisord_conf > /etc/supervisor/supervisord.conf主配置部分
supervisord.conf的主配置部分說明:
[unix_http_server] file=/tmp/supervisor.sock ; socket文件的路徑 ;chmod=0700 ; socket文件權限 ;chown=nobody:nogroup ; socket文件用戶和用戶組 ;username=user ; 連接時認證的用戶名 ;password=123 ; 連接時認證的密碼 [inet_http_server] ; 監聽TCP port=127.0.0.1:9001 ; 監聽ip和端口 username=user ; 連接時認證的用戶名 password=123 ; 連接時認證的密碼 [supervisord] logfile=/var/log/supervisord.log ; log目錄 logfile_maxbytes=50MB ; log文件最大空間 logfile_backups=10 ; log文件保持的數量 loglevel=info ; log級別 pidfile=/var/run/supervisord.pid nodaemon=false ; 是否非守護進程態運行 minfds=1024 ; 系統空閑的最少文件描述符 minprocs=200 ; 可用的最小進程描述符 ;umask=022 ; 進程創建文件的掩碼 ;identifier=supervisor ; supervisord標識符 ;directory=/tmp ; 啟動前切換到的目錄 ;nocleanup=true ; 啟動前是否清除子進程的日志文件 ;childlogdir=/tmp ; AUTO模式,子進程日志路徑 ;environment=KEY="value" ; 設置環境變量 [rpcinterface:supervisor] ; XML_RPC配置 supervisor.rpcinterface_factory = supervisor.rpcinterface:make_main_rpcinterface [supervisorctl] serverurl=unix:///tmp/supervisor.sock ; 連接的socket路徑 ;username=chris ; 用戶名 ;password=123 ; 密碼 prompt=mysupervisor ; 輸入用戶名和密碼時的提示符 ;history_file=~/.sc_history ; 歷史操作記錄存儲路徑 [include] ; 包含文件,將每個進程配置為一個文件并包含 files = /etc/supervisor/*.ini ; 多個進程的配置文件
這部分我們不需要做太多的配置修改,如果需要開啟 WEB 終端監控,則需要配置并開啟 inet_http_server 項。
進程配置部分Supervisor 需管理的進程服務配置,示例如下:
[program:work] ; 服務名,例如work command=php -r "sleep(10);exit(1);" ; 帶有參數的可執行命令 process_name=%(process_num)s ; 進程名,當numprocs>1時,需包含%(process_num)s numprocs=2 ; 啟動進程的數目數 ;directory=/tmp ; 運行前切換到該目錄 ;umask=022 ; 進程掩碼 ;priority=999 ; 子進程啟動關閉優先級 autostart=true ; 子進程是否被自動啟動 startsecs=1 ; 成功啟動幾秒后則認為成功啟動 ;startretries=3 ; 子進程啟動失敗后,最大嘗試啟動的次數 autorestart=unexpected ; 子進程意外退出后自動重啟的選項,false,?unexpected,?true。unexpected表示不在exitcodes列表時重啟 exitcodes=0,2 ; 期待的子程序退出碼 ;stopsignal=QUIT ; 進程停止信號,可以為TERM,HUP,INT,QUIT,KILL,USR1,or?USR2等信號,默認為TERM ;stopwaitsecs=10 ; 發送停止信號后等待的最大時間 ;stopasgroup=false ; 是否向子進程組發送停止信號 ;killasgroup=false ; 是否向子進程組發送kill信號 ;redirect_stderr=true ; 是否重定向日志到標準輸出 stdout_logfile=/data/logs/work.log ; 進程的stdout的日志路徑 ;stdout_logfile_maxbytes=1MB ; 日志文件最大大小 ;stdout_logfile_backups=10 ;stdout_capture_maxbytes=1MB ;stderr_logfile=/a/path ; stderr的日志路徑 ;stderr_logfile_maxbytes=1MB ;stderr_logfile_backups=10 ;stderr_capture_maxbytes=1MB ;environment=A="1",B="2" ; 子進程的環境變量 ;serverurl=AUTO ; 子進程的環境變量SUPERVISOR_SERVER_URL
通常將每個進程的配置信息配置成獨立文件,并通過 include 模塊包含,這樣方便修改和管理配置文件。啟動
配置完成后,啟動 supervisord 守護服務:
$ supervisord -c /etc/supervisor/supervisord.conf
常用的命令參數說明:
-c:指定配置文件路徑
-n:是否非守護態運行
-l:日志文件目錄
-i:唯一標識
查看 supervisord 啟動情況:
$ ps -ef | grep "supervisor" root 24901 1 0 Sep23 ? 00:00:30 /usr/bin/python /usr/bin/supervisord -c /etc/supervisor/supervisord.conf $ netstat -tunpl tcp 0 0 127.0.0.1:9001 0.0.0.0:* LISTEN 24901/python監控進程
Supervisor 提供了多種監控服務的方式,包括 supervisorctl 命令行終端、Web 端、XML_RPC 接口多種方式。
命令終端直接使用 supervisorctl 即可在命令行終端查看所有服務的情況,如下:
$ supervisorctl work:0 RUNNING pid 31313, uptime 0:00:07 work:1 RUNNING pid 31318, uptime 0:00:06 # -u 用戶名 -p 密碼
supervisorctl 常用命令列表如下;
status:查看服務狀態
update:重新加載配置文件
restart:重新啟動服務
stop:停止服務
pid:查看某服務的 pid
tail:輸出最新的 log 信息
shutdown:關閉 supervisord 服務
Web在配置中開啟 inet_http_server 后,即可通過 Web 界面便捷地監控進程服務了。
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/31078.html
摘要:使用開發的一個服務,是系統下的一個進程管理工具。一切就緒后,我們使用如下命令就可以啟動隊列進程的監聽了這里值得注意的是,如果處理隊列的代碼更改了,需要重啟的隊列管理才能生效。 supervisor使用python開發的一個client/server服務,是linux/unix系統下的一個進程管理工具。它可以很方便的監聽、停止、重啟一個或多個進程。用supervisor管理的進程,打你...
閱讀 1309·2021-11-15 11:37
閱讀 3501·2021-11-11 16:55
閱讀 1750·2021-08-25 09:39
閱讀 3215·2019-08-30 15:44
閱讀 1734·2019-08-29 12:52
閱讀 1405·2019-08-29 11:10
閱讀 3241·2019-08-26 11:32
閱讀 3223·2019-08-26 10:16