วิธีออกจากกระบวนการผู้ควบคุมงานทั้งหมดหากมีการออกด้วย 0 ผลลัพธ์


14

ฉันเรียกใช้คอนเทนเนอร์นักเทียบเคียงกับหัวหน้างานเช่นนี้:

Dockerfile

CMD ["/run.sh"]

run.sh

#!/usr/bin/env bash
exec supervisord -n

ผู้บังคับบัญชา serf.conf

[group:job]
programs=serf,producer

[program:serf]
command=/start-serf-agent.sh
numprocs=1
autostart=true
autorestart=unexpected
stopasgroup=true
killasgroup=true
stdout_logfile=/dev/stdout
stdout_logfile_maxbytes=0
stderr_logfile=/dev/stderr
stderr_logfile_maxbytes=0

start-serf-agent.sh

#!/bin/bash
exec serf agent --join=serf:7946 -tag role=producer

ผู้บังคับบัญชา servce.conf

[program:producer]
command=/start.sh
numprocs=1
stopasgroup=true
killasgroup=true
stdout_logfile=/dev/stdout
stdout_logfile_maxbytes=0
stderr_logfile=/dev/stderr
stderr_logfile_maxbytes=0

start.sh

#!/bin/bash
exec /producer --project=${NAME}

หลังจากที่ผู้ผลิตหยุดฉันก็มี:

producer_1 |     2016/02/29 21:59:50 [INFO] serf: EventMemberLeave: 7c4fbc80af97 172.19.0.2
producer_1 | 2016/02/29 21:59:51 INF    1 stopping
producer_1 | 2016/02/29 21:59:51 INF    1 exiting router
producer_1 | 2016-02-29 21:59:51,281 INFO exited: producer (exit status 0; expected)
producer_1 |     2016/02/29 21:59:51 [INFO] agent: Received event: member-leave

แต่ serf-agent เก็บคอนเทนเนอร์ในสถานะกำลังทำงาน ฉันต้องการหยุดนักเทียบท่าคอนเทนเนอร์เมื่อผู้ผลิตทำงานของเขาอย่างถูกต้องด้วยสถานะ 0 ฉันพยายามเข้าร่วมกระบวนการกับกลุ่มหนึ่ง แต่ดูเหมือนจะไม่ทำงาน พวกฉันข้ามอะไรไป ช่วยฉันด้วย!


dupe ที่เป็นไปได้ของserverfault.com/questions/735328/ …
ibotty

คำตอบ:


8

ฉันแก้ไขปัญหากับผู้จัดงานEventlistener :

[program:worker]
command=/start.sh
priority=2
process_name=worker
numprocs=1
stopasgroup=true
killasgroup=true
stdout_logfile=/dev/stdout
stdout_logfile_maxbytes=0
stderr_logfile=/dev/stderr
stderr_logfile_maxbytes=0

[eventlistener:worker_exit]
command=/kill.py
process_name=worker
events=PROCESS_STATE_EXITED

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**

การจัดการกระบวนการบทความที่ดีในคอนเทนเนอร์นักเทียบท่า


เนื้อหาของสคริปต์ kill.py คืออะไร
Piotr Kieszczyński

@ PiotrKieszczyńskiโพสต์ได้รับการปรับปรุงดูโปรด
Vitaly Velikodny

3

นี่เป็นเวอร์ชั่นที่มีความคล่องตัวมากกว่าเล็กน้อยซึ่งใช้เชลล์สคริปต์แทนที่จะเป็นสคริปต์ไพ ธ อนและยังครอบคลุมถึงบริการหลายบริการซึ่งจะฆ่าหัวหน้างานทั้งหมดหากล้มเหลว

supervisord.conf
$ cat /etc/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
startsecs=30
process_name=service1

[program:service2]
command=/usr/sbin/service2
user=root
autostart=true
autorestart=true
startsecs=30
process_name=service2

[eventlistener:processes]
command=stop-supervisor.sh
events=PROCESS_STATE_STOPPED, PROCESS_STATE_EXITED, PROCESS_STATE_FATAL
stop-supervisor.sh
$ 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

อ้างอิง


1
คุณไม่ลืมเหตุการณ์เหตุการณ์ในการกำหนดค่าที่นี่หรือ และ config ของคุณไม่มีการอ้างอิงถึง stop-supervisor.sh
rfay

Stop-supervisor.sh อยู่ที่ไหน
ปีเตอร์

@ ปีเตอร์ - ขอบคุณมันถูกสับเมื่อฉันวางไว้ในฉันได้แก้ไขแล้ว
slm

0

นี่เป็นวิธีง่ายๆสำหรับนักเทียบท่า ในของคุณsupervisord.confให้แทนที่สิ่งนี้:

[program:something]
command = something

ด้วยสิ่งนี้:

[program:something]
command = sh -c 'something && kill 1'
โดยการใช้ไซต์ของเรา หมายความว่าคุณได้อ่านและทำความเข้าใจนโยบายคุกกี้และนโยบายความเป็นส่วนตัวของเราแล้ว
Licensed under cc by-sa 3.0 with attribution required.