Ignore SIGINT/TERM at kas level, let sub-processes handle it

This seems to be the cleanest and simplest way of properly terminating
kas while one or more sub-processes are running: just ignore the signal.
The sub-processes will get it as well, and they will terminate
themselves properly. kas will get an error then and shut down. Problem
solved.

Forwarding the signal didn't work reliably anyway because we couldn't
count on kas being a process group leader in all cases.

Signed-off-by: Jan Kiszka <jan.kiszka@siemens.com>
This commit is contained in:
Jan Kiszka 2017-07-03 11:34:33 +02:00 committed by Daniel Wagner
parent 264be71ebe
commit dd04836896

View File

@ -83,18 +83,15 @@ def create_logger():
def interruption(): def interruption():
""" """
Handle SIGINT/SIGTERM Ignore SIGINT/SIGTERM in kas, let them be handled by our sub-processes
""" """
sys.exit(1) pass
def _atexit_handler(): def _atexit_handler():
""" """
Close event loop and terminate the whole process group Wait for completion of the event loop
""" """
signal.signal(signal.SIGTERM, signal.SIG_IGN)
os.killpg(os.getpid(), signal.SIGTERM)
loop = asyncio.get_event_loop() loop = asyncio.get_event_loop()
pending = asyncio.Task.all_tasks() pending = asyncio.Task.all_tasks()
loop.run_until_complete(asyncio.gather(*pending)) loop.run_until_complete(asyncio.gather(*pending))