I'm creating a thread manager class that handles executing tasks as threads and passing the results to the next process step. The flow works properly upon the first execution of receiving a task, but the second execution fails with the following error :
...python3.8/concurrent/futures/thread.py", line 179, in submit
raise RuntimeError('cannot schedule new futures after shutdown')
RuntimeError: cannot schedule new futures after shutdown
The tasks come from Cmd.cmdloop
user input - so, the script is persistent and meant to not shutdown. Instead, run
will be called multiple times, as input is received from the user.
I've implemented a ThreadPoolExecutor
to handle the work load and trying to gather the results chronologically with concurrent.futures.as_completed
so each item is processed to the next step in order of completion.
The run
method below works perfect for the first execution, but returns the error upon second execution of the same task (that succeeded during the first execution).
def run ( self, _executor=None, _futures={}, ) -> bool :
task = self.pipeline.get( )
with _executor or self.__default_executor as executor :
_futures = { executor.submit ( task.target.execute, ), }
for future in concurrent.futures.as_completed ( _futures, ) :
print( future.result ( ) )
return True
So, the idea is that each call to run
will create and teardown the executor
with the context. But the error suggests the context shutdown properly after the first execution, and cannot be reopened/recreated when run
is called during the second iteration... what is this error pointing to? .. what am I missing?
Any help would be great - thanks in advance.
run
method to keep it persistent? – Impose