1. 程式人生 > 實用技巧 >Linux程序管理工具 Supervisor

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高薪實戰學習大合集