supervisor是用python寫的一個進程管理工具,用來啓動,重啓,關閉進程。下面這篇文章主要給你們介紹了關於python實現的進程管理工具supervisor的安裝與使用的相關資料,須要的朋友能夠參考借鑑,下面來一塊兒看看吧。python
前言web
在一個分佈式環境中,每臺機器上可能須要啓動和中止多個進程,使用命令行方式一個一個手動啓動和中止很是麻煩,並且查看每一個進程的狀態也很不方便。若是有一個工具可以實現每臺機器上多個進程的簡單高效中心化管理將是很是方便的。因而Supervisord工具應運而生。與Supervisord相似的工具包括monit,daemontools和runit。下面話很少說,來一塊兒看看詳細的介紹吧。瀏覽器
安裝安全
Supervisord是運行在Python環境下的服務監控程序,因此在安裝supervisord以前必須有python環境。服務器
yum install python-setuptools
easy_install supervisor
若是安裝成功,鍵入:echo_supervisord_conf
,會顯示一個superviscord_conf 的配置模板。app
配置文件詳解socket
[unix_http_server] 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 logfile_backups=10 ; 日誌文件保留備份數量默認 10 loglevel=info ; 日誌級別,默認 info,其它: debug,warn,trace pidfile=/tmp/supervisord.pid ; pid 文件 nodaemon=false ; 是否在前臺啓動,默認是 false,即以 daemon 的方式啓動 minfds=1024 ; 能夠打開的文件描述符的最小值,默認 1024 minprocs=200 ; 能夠打開的進程數的最小值,默認 200 ; the below section must remain in the config file for RPC ; (supervisorctl/web interface) to work, additional interfaces may be ; added by defining them in separate rpcinterface: sections [rpcinterface:supervisor] supervisor.rpcinterface_factory = supervisor.rpcinterface:make_main_rpcinterface [supervisorctl] serverurl=unix:///tmp/supervisor.sock ; 經過 UNIX socket 鏈接 supervisord,路徑與 unix_http_server 部分的 file 一致 ;serverurl=http://127.0.0.1:9001 ; 經過 HTTP 的方式鏈接 supervisord ; 包含其餘的配置文件 [include] files = relative/directory/*.ini ; 能夠是 *.conf 或 *.ini
進程Program配置分佈式
[program:usercenter] directory = /home/leon/projects/usercenter ; 程序的啓動目錄 command = gunicorn -c gunicorn.py wsgi:app ; 啓動命令,能夠看出與手動在命令行啓動的命令是同樣的 autostart = true ; 在 supervisord 啓動的時候也自動啓動 startsecs = 5 ; 啓動 5 秒後沒有異常退出,就看成已經正常啓動了 autorestart = true ; 程序異常退出後自動重啓 startretries = 3 ; 啓動失敗自動重試次數,默認是 3 user = leon ; 用哪一個用戶啓動 redirect_stderr = true ; 把 stderr 重定向到 stdout,默認 false stdout_logfile_maxbytes = 20MB ; stdout 日誌文件大小,默認 50MB stdout_logfile_backups = 20 ; stdout 日誌文件備份數 ; stdout 日誌文件,須要注意當指定目錄不存在時沒法正常啓動,因此須要手動建立目錄(supervisord 會自動建立日誌文件) stdout_logfile = /data/logs/usercenter_stdout.log ; 能夠經過 environment 來添加須要的環境變量,一種常見的用法是修改 PYTHONPATH ; environment=PYTHONPATH=$PYTHONPATH:/path/to/somewhere
將進程配置添加到supervisord.conf文件中工具
推薦將各個進程配置放到單獨的文件中,而後經過[include]配置項引用post
[include]
files = /etc/supervisor/*.conf
supervisor服務啓動
運行命令
supervisord -c /etc/supervisord.conf
supervisor服務客戶端管理
可使用supervisord的命令行客戶端管理工具supervisorctl來管理進程。
supervisorctl status
supervisorctl stop usercenter
supervisorctl start usercenter
supervisorctl restart usercenter
supervisorctl reread
supervisorctl update
supervisor web管理界面
;[inet_http_server] ; HTTP 服務器,提供 web 管理界面 ;port=127.0.0.1:9001 ; Web 管理後臺運行的 IP 和端口,若是開放到公網,須要注意安全性 ;username=user ; 登陸管理後臺的用戶名 ;password=123 ; 登陸管理後臺的密碼
在瀏覽器中輸入http://127.0.0.1:9001,便可進入web管理界面
原文連接:https://www.chen-hao.com.cn/posts/6255/