Linux程序管理工具 Supervisor
Supervisor安裝與配置(linux/unix程序管理工具)
Supervisor(http://supervisord.org)是用Python開發的一個client/server服務,是Linux/Unix系統下的一個程序管理工具,不支援Windows系統。它可以很方便的監聽、啟動、停止、重啟一個或多個程序。用Supervisor管理的程序,當一個程序意外被殺死,supervisort監聽到程序死後,會自動將它重新拉起,很方便的做到程序自動恢復的功能,不再需要自己寫shell指令碼來控制。
因為Supervisor是Python開發的,安裝前先檢查一下系統否安裝了Python2.4以上版本。下面以CentOS7.6,Python2.7.5版本環境下,介紹Supervisor的安裝與配置步聚:
實驗環境
系統平臺
cat /etc/redhat-release
CentOS Linux release 7.6.1810 (Core)
Python版本
python -V
Python 2.7.5
如果python版本低於2.6請升級,下面貼出一個安裝python3.6.8的安裝示例
yum install zlib-devel bzip2-devel openssl-devel ncurses-devel sqlite-devel readline-devel tk-devel gdbm-devel db4-devel libpcap-devel xz-devel -y libffi-devel wget https://www.python.org/ftp/python/3.6.8/Python-3.6.8.tar.xz tar xf Python-3.6.8.tar.xz cd Python-3.6.8 ./configure --prefix=/usr/local/python368 make && make install echo 'export PATH=/usr/local/python368/bin:$PATH' >> /etc/profile source /etc/profile python3 -V
安裝 Supervisor
安裝 Supervisor的方法很多,以下介紹三種,我這裡所採用的為第三種
1、easy_install 安裝 supervisor
安裝Python包管理工具(easy_install)
easy_install是setuptools包裡帶的一個命令,使用easy_install實際上是在呼叫setuptools來完成安裝模組的工作,所以安裝setuptools即可:
wget https://pypi.io/packages/source/s/setuptools/setuptools-33.1.1.zip unzip setuptools-33.1.1.zip cd setuptools-33.1.1 python setup.py install easy_install supervisor
2、pip 安裝 supervisor
使用 pip 來安裝,前提要保證pip版本大於2.6
pip install supervisor
3、yum epel-release 安裝 supervisor
yum install -y epel-release && yum install -y supervisor
superviso命令
supervisor安裝完成後會生成三個執行程式:supervisortd、supervisorctl、echo_supervisord_conf:
- supervisortd:用於管理supervisor本身服務
- supervisorctl:用於管理我們需要委託給superviso工具的服務
- echo_supervisord_conf:用於生成superviso的配置檔案
- supervisor的守護程序服務(用於接收程序管理命令)
- 客戶端(用於和守護程序通訊,傳送管理程序的指令)
[root@Jumpserver /]# which supervisord
/bin/supervisord
[root@Jumpserver /]# which supervisorctl
/bin/supervisorctl
[root@Jumpserver /]# which echo_supervisord_conf
/bin/echo_supervisord_conf
配置Supervisor
通過執行echo_supervisord_conf程式生成supervisor的初始化配置檔案
如果使用yum安裝則此步驟省略,直接進行修改配置檔案步驟
mkdir /etc/supervisord.d
echo_supervisord_conf > /etc/supervisord.conf
修改配置檔案
supervisor的配置檔案內容有很多,不過好多都不需要修改就行使用,我這裡只修改了以下兩項
#修改socket檔案的mode,預設是0700
sed -i 's/;chmod=0700/chmod=0766/g' /etc/supervisord.conf
#在配置檔案最後新增以下兩行內容來包含/etc/supervisord目錄
sed -i '$a [include] \
files = /etc/supervisord.d/*.conf' /etc/supervisord.conf
編寫需要被Supervisor管理的程序
Supervisor只能管理非dameon程序,像預設的redis為前臺執行、Tomcat其實是 startup.sh shutdown.sh來呼叫catalina.sh進行後臺執行的,預設catalina.sh為前臺執行的程式,不能管理像Nginx一樣的非dameon程序
Tomcat被Supervisor管理
Tomcat安裝如下:
wget http://us.mirrors.quenda.co/apache/tomcat/tomcat-8/v8.5.47/bin/apache-tomcat-8.5.47.tar.gz
yum install java-1.8.0-openjdk.x86_64 java-1.8.0-openjdk-devel.x86_64 -y
tar xf apache-tomcat-8.5.47.tar.gz -C /usr/local/
mv /usr/local/apache-tomcat-8.5.47 /usr/local/tomcat
想要我們的應用被Supervisor管理,就需要在/etc/supervisord目錄下編寫配置檔案,Tomcat案例如下:
vim /etc/supervisord.d/tomcat.conf
[program:tomcat] #程式唯一名稱
directory=/usr/local/tomcat #程式路徑
command=/usr/local/tomcat/bin/catalina.sh run #執行程式的命令
autostart=true #是否在supervisord啟動後tomcat也啟動
startsecs=10 #啟動10秒後沒有異常退出,就表示程序正常啟動了,預設為1秒
autorestart=true #程式退出後自動重啟,可選值:[unexpected,true,false],預設為unexpected,表示程序意外殺死後才重啟;意思為如果不是supervisord來關閉的該程序則認為不正當關閉,supervisord會再次把該程序給啟動起來,只能使用該supervisorctl來進行關閉、啟動、重啟操作
startretries=3 #啟動失敗自動重試次數,預設是3
user=root #用哪個使用者啟動程序,預設是root
priority=999 #程序啟動優先順序,預設999,假如Supervisord需要管理多個程序,那麼值小的優先啟動
stopsignal=INT
redirect_stderr=true #把stderr重定向到stdout標準輸出,預設false
stdout_logfile_maxbytes=200MB #stdout標準輸出日誌檔案大小,日誌檔案大小到200M後則進行切割,切割後的日誌檔案會標示為catalina.out1,catalina.out2,catalina.out3...,預設50MB
stdout_logfile_backups = 100 #stdout標準輸出日誌檔案備份數,儲存100個200MB的日誌檔案,超過100個後老的將被刪除,預設為10儲存10個
stdout_logfile=/usr/local/tomcat/logs/catalina.out #標準日誌輸出位置,如果輸出位置不存在則會啟動失敗
stopasgroup=false #預設為false,程序被殺死時,是否向這個程序組傳送stop訊號,包括子程序
killasgroup=false #預設為false,向程序組傳送kill訊號,包括子程序
啟動程序
使用supervisord管理啟動後,當你使用/usr/local/tomcat/shutdown.sh或者kill $PID的時候,supervisord都會認為是意外關閉,會自動再次把程序拉起,除非是使用supervisord命令關閉
#supervisord啟動
supervisord -c /etc/supervisord.conf #啟動supervisord程序,我們在配置檔案中設定了 autostart=true 引數,在supervisord啟動的時候 tomcat也隨之啟動
ps -ef|grep java #檢視tomcat是否啟動
程式管理
supervisorctl status tomcat #tomcat狀態
supervisorctl stop tomcat #停止tomcat
supervisorctl start tomcat #啟動tomcat
supervisorctl restart tomcat #重啟tomcat
supervisorctl reoload tomcat #重仔tomcat
Redis被Supervisor管理
redis預設不在配置檔案中新增 daemonize yes
引數則是前臺啟動的,所以也可以被我們的的Supervisor所管理
redis配置檔案如下:
cat redis6001.conf
port 6001
bind 192.168.31.230
protected-mode yes
pidfile "/usr/local/redis/run/redis6001.pid"
loglevel notice
logfile "/usr/local/redis/logs/redis6001.log"
save 900 1
stop-writes-on-bgsave-error yes
rdbcompression yes
rdbchecksum yes
dbfilename dump.rdb
dir "/usr/local/redis/data/rdb/"
timeout 0
tcp-keepalive 300
編寫redis被Supervisor管理的案例
vim /etc/supervisord.d/redis.conf
[program:redis]
directory=/usr/local/redis
command=/usr/local/redis/bin/redis-server /usr/local/redis/etc/redis6001.conf
autostart=true
startsecs=10
autorestart=true
startretries=3
user=root
priority=999
stopsignal=INT
redirect_stderr=true
stdout_logfile_maxbytes=200MB
stdout_logfile_backups = 100
stdout_logfile=/usr/local/redis/logs/redis6001.log
stopasgroup=false
killasgroup=false
使用super啟動redis
#關閉tomcat
supervisorctl stop tomcat
tomcat: stopped
#殺掉supervisord
ps -ef|grep supervisord
root 26927 1 0 10:47 ? 00:00:00 /usr/bin/python /bin/supervisord -c /etc/supervisord.conf
root 27549 27402 0 11:07 pts/2 00:00:00 grep --color=auto super
kill -9 26927
#重新啟動supervisord使其重新載入配置檔案,supervisord預設會把redis和tomcat都拉起來
supervisord -c /etc/supervisord.conf
程式管理
supervisorctl status redis #redis狀態
supervisorctl stop redis #停止redis
supervisorctl start redis #啟動redis
supervisorctl restart reids #重啟redis
supervisorctl reoload redis #過載redis
程式管理
程式管理
supervisorctl status all #檢視所有程序狀態
supervisorctl stop all #停止所有程序
supervisorctl start all #啟動所有程序
supervisorctl restart all #重啟所有程序
supervisorctl reoload all #過載所有程序
Supervisord開啟啟動配置
vim /usr/lib/systemd/system/supervisord.service
[Unit]
Description=Process Monitoring and Control Daemon
After=rc-local.service nss-user-lookup.target
[Service]
Type=forking
ExecStart=/usr/bin/supervisord -c /etc/supervisord.conf
[Install]
WantedBy=multi-user.target
systemctl enable supervisord
systemctl is-enabled supervisord
有段時間沒跟大家分享資源福利了,看了下自己的資料夾,整理了一些我認為比較好的Python學習資料了。相信這套資料可以對你進階高階工程師有幫助
學習工具
大廠實戰手冊
自學視訊(部分)
【資料免費領取方式】:點這裡:2020Python高薪實戰學習大合集