[New-bugs-announce] [issue44764] Handling interruption in async tasks
Ilian Iliev
report at bugs.python.org
Wed Jul 28 12:18:43 EDT 2021
New submission from Ilian Iliev <ilian at ilian.io>:
The idea is to provide a way for graceful shutdown so that if an interruption occurs all async tasks are given a certain time to finish before we exit the process.
Please take a look at the provided example -> https://gist.github.com/IlianIliev/9aba04a74a4faddf0749533205d3b001
If the interruption happens during an await (if we use `await asyncio.sleep(5)`), all works correctly. The exception is raised to the root level and we do the graceful shutdown on line 37.
But if the interruption happens during a normal execution (`time.sleep()`) it is raised at the currently running line and this way breaks the function without any chances or recovery.
While `time.sleep` is not that widely used, the same problem occurs if we have any other long-running code e.g. iterating over a big list.
This was found while looking for a way to provide a graceful shutdown for the grpcio server -> https://github.com/grpc/grpc/issues/26123
Is it possible to change the behaviour so the exception is raised on a higher level when sync tasks are executed in async context?
----------
hgrepos: 407
messages: 398400
nosy: ilian
priority: normal
severity: normal
status: open
title: Handling interruption in async tasks
type: behavior
versions: Python 3.9
_______________________________________
Python tracker <report at bugs.python.org>
<https://bugs.python.org/issue44764>
_______________________________________
More information about the New-bugs-announce
mailing list