次のスーパーバイザー構成があります。
[supervisord]
nodaemon=true
logfile=NONE
[program:service1]
command=/usr/sbin/service1
user=someone
autostart=true
autorestart=true
startsecs=30
[program:service2]
command=/usr/sbin/service2
user=root
autostart=true
autorestart=true
startsecs=30
私はdockerコンテナでこの設定を使用しています。問題は、service1がクラッシュした場合、すべてが大丈夫であるかのようにコンテナが実行され続けることです。 1つのサービスがクラッシュしたときにコンテナ全体がシャットダウンするように、この動作をどのように変更できますか?
答え1
今回のSF Q&Aのタイトルは以下の通りです。終了時に結果が0の場合、すべてのスーパーバイザプロセスを終了する方法あなたが探しているようです。
メモ:この方法はイベントリスナー。
例 #1
[supervisord]
nodaemon=true
logfile=NONE
[program:service1]
command=/usr/sbin/service1
user=someone
autostart=true
;autorestart=true ; disabled
;startsecs=30 ; disabled
process_name=service1
[program:service2]
command=/usr/sbin/service2
user=root
autostart=true
;autorestart=true ; disabled
;startsecs=30 ; disabled
process_name=service2
[eventlistener:service1_exit]
command=kill.py
process_name=service1
events=PROCESS_STATE_EXITED
[eventlistener:service2_exit]
command=kill.py
process_name=service2
events=PROCESS_STATE_EXITED
スクリプトkill.py
:
$ cat kill.py
#!/usr/bin/env python
import sys
import os
import signal
def write_stdout(s):
sys.stdout.write(s)
sys.stdout.flush()
def write_stderr(s):
sys.stderr.write(s)
sys.stderr.flush()
def main():
while 1:
write_stdout('READY\n')
line = sys.stdin.readline()
write_stdout('This line kills supervisor: ' + line);
try:
pidfile = open('/var/run/supervisord.pid','r')
pid = int(pidfile.readline());
os.kill(pid, signal.SIGQUIT)
except Exception as e:
write_stdout('Could not kill supervisor: ' + e.strerror + '\n')
write_stdout('RESULT 2\nOK')
if __name__ == '__main__':
main()
import sys
main issue I forgot to point to **process_name**
例 #2
この例では、イベントリスナーを引き続き使用するより単純化されたアプローチを示しますが、上記と同じことを行う方法を示していますが、単一のリスナーとシェルスクリプトのみを使用します。
検索および終了操作を実行するシェルスクリプト:
$ cat stop-supervisor.sh
#!/bin/bash
printf "READY\n";
while read line; do
echo "Processing Event: $line" >&2;
kill -3 $(cat "/var/run/supervisord.pid")
done < /dev/stdin
Supervisord.conf:
$ cat supervisord.conf
[supervisord]
nodaemon=true
loglevel=debug
logfile=/var/log/supervisor/supervisord.log
pidfile=/var/run/supervisord.pid
childlogdir=/var/log/supervisor
[program:service1]
command=/usr/sbin/service1
user=someone
autostart=true
;autorestart=true ; disabled
;startsecs=30 ; disabled
process_name=service1
[program:service2]
command=/usr/sbin/service2
user=root
autostart=true
;autorestart=true ; disabled
;startsecs=30 ; disabled
process_name=service2
[eventlistener:processes]
command=stop-supervisor.sh
events=PROCESS_STATE_STOPPED, PROCESS_STATE_EXITED, PROCESS_STATE_FATAL