From 72df2ce249221d8a11a09ead4e4cbe2750d5c558 Mon Sep 17 00:00:00 2001 From: Mark Zhang <46978338+MarkintoshZ@users.noreply.github.com> Date: Thu, 18 Jan 2024 21:39:10 -0600 Subject: [PATCH] Use context for process start method (#310) --- acto/runner/runner.py | 9 +++------ 1 file changed, 3 insertions(+), 6 deletions(-) diff --git a/acto/runner/runner.py b/acto/runner/runner.py index e4304a1787..a7f3f2ee1a 100644 --- a/acto/runner/runner.py +++ b/acto/runner/runner.py @@ -81,8 +81,7 @@ def __init__( "role_binding": self.rbac_authorization_v1_api.list_namespaced_role_binding, } - if multiprocessing.get_start_method() != "fork": - multiprocessing.set_start_method("fork") + self.mp_ctx = multiprocessing.get_context("fork") self._custom_system_state_f = custom_system_state_f @@ -441,13 +440,11 @@ def wait_for_system_converge(self, hard_timeout=480) -> bool: self.namespace, _preload_content=False, watch=True ) - combined_event_queue: multiprocessing.Queue = multiprocessing.Queue( - maxsize=0 - ) + combined_event_queue = self.mp_ctx.Queue(maxsize=0) timer_hard_timeout = acto_timer.ActoTimer( hard_timeout, combined_event_queue, "timeout" ) - watch_process = multiprocessing.Process( + watch_process = self.mp_ctx.Process( target=self.watch_system_events, args=(event_stream, combined_event_queue), )