Commit 03221ee9 authored by David Wilson's avatar David Wilson

ansible: gracefully shut down the service thread at exit.

parent afc86972
...@@ -188,10 +188,12 @@ class StrategyModule(ansible.plugins.strategy.linear.StrategyModule): ...@@ -188,10 +188,12 @@ class StrategyModule(ansible.plugins.strategy.linear.StrategyModule):
self.listener = mitogen.unix.Listener(self.router) self.listener = mitogen.unix.Listener(self.router)
os.environ['MITOGEN_LISTENER_PATH'] = self.listener.path os.environ['MITOGEN_LISTENER_PATH'] = self.listener.path
# TODO: gracefully shutdown and join on this at exit. def _setup_services(self):
"""
Construct a ContextService and a thread to service requests for it.
"""
self.service = ContextService(self.router) self.service = ContextService(self.router)
self.service_thread = threading.Thread(target=self.service.run) self.service_thread = threading.Thread(target=self.service.run)
self.service_thread.setDaemon(True)
self.service_thread.start() self.service_thread.start()
def _run_with_master(self, iterator, play_context, result): def _run_with_master(self, iterator, play_context, result):
...@@ -201,11 +203,13 @@ class StrategyModule(ansible.plugins.strategy.linear.StrategyModule): ...@@ -201,11 +203,13 @@ class StrategyModule(ansible.plugins.strategy.linear.StrategyModule):
""" """
mitogen.utils.log_to_file() mitogen.utils.log_to_file()
self._setup_master() self._setup_master()
self._setup_services()
try: try:
return super(StrategyModule, self).run(iterator, play_context) return super(StrategyModule, self).run(iterator, play_context)
finally: finally:
self.router.broker.shutdown()
os.unlink(self.listener.path) os.unlink(self.listener.path)
self.router.broker.shutdown()
self.service_thread.join(timeout=10)
def _install_wrappers(self): def _install_wrappers(self):
""" """
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment