set_blocking_signal_threshold equivalent for asyncio?
data:image/s3,"s3://crabby-images/7d2f9/7d2f9d1ae55729198886f84f1f85760205c5309f" alt=""
Hi, In tornado, there's a really nice feature called set_blocking_signal_threshold, which sets a signal that fires if a coroutine has been running for too long without returning control back to the main loop: https://www.tornadoweb.org/en/stable/ioloop.html?highlight=signal#tornado.io... In tornado this will then log the traceback of the coroutine in question. This has been a very valuable tool when a developer accidentally introduces code that blocks the event loop for way too long of a time. Is there an equivalent in asyncio? I have a sketch in my head of how to implement that, but wanted to see if it existed somewhere first. Thanks! -Yusuke
data:image/s3,"s3://crabby-images/9a3c3/9a3c3f6959c69c5b58268da7041c0674f0e9c76d" alt=""
Asyncio's debug mode does this (and a few more things). Call `asyncio.get_event_loop().set_debug()` to enable it. https://docs.python.org/3/library/asyncio-dev.html#debug-mode -Ben On Fri, Feb 8, 2019 at 5:10 PM Yusuke Tsutsumi <yusuke@tsutsumi.io> wrote:
Hi,
In tornado, there's a really nice feature called set_blocking_signal_threshold, which sets a signal that fires if a coroutine has been running for too long without returning control back to the main loop:
https://www.tornadoweb.org/en/stable/ioloop.html?highlight=signal#tornado.io...
In tornado this will then log the traceback of the coroutine in question. This has been a very valuable tool when a developer accidentally introduces code that blocks the event loop for way too long of a time.
Is there an equivalent in asyncio? I have a sketch in my head of how to implement that, but wanted to see if it existed somewhere first.
Thanks! -Yusuke _______________________________________________ Async-sig mailing list Async-sig@python.org https://mail.python.org/mailman/listinfo/async-sig Code of Conduct: https://www.python.org/psf/codeofconduct/
data:image/s3,"s3://crabby-images/7d2f9/7d2f9d1ae55729198886f84f1f85760205c5309f" alt=""
Great, thank you! I'll try it out, looks promising. On Fri, Feb 8, 2019 at 5:37 PM Ben Darnell <ben@bendarnell.com> wrote:
Asyncio's debug mode does this (and a few more things). Call `asyncio.get_event_loop().set_debug()` to enable it.
https://docs.python.org/3/library/asyncio-dev.html#debug-mode
-Ben
On Fri, Feb 8, 2019 at 5:10 PM Yusuke Tsutsumi <yusuke@tsutsumi.io> wrote:
Hi,
In tornado, there's a really nice feature called set_blocking_signal_threshold, which sets a signal that fires if a coroutine has been running for too long without returning control back to the main loop:
https://www.tornadoweb.org/en/stable/ioloop.html?highlight=signal#tornado.io...
In tornado this will then log the traceback of the coroutine in question. This has been a very valuable tool when a developer accidentally introduces code that blocks the event loop for way too long of a time.
Is there an equivalent in asyncio? I have a sketch in my head of how to implement that, but wanted to see if it existed somewhere first.
Thanks! -Yusuke _______________________________________________ Async-sig mailing list Async-sig@python.org https://mail.python.org/mailman/listinfo/async-sig Code of Conduct: https://www.python.org/psf/codeofconduct/
data:image/s3,"s3://crabby-images/7d2f9/7d2f9d1ae55729198886f84f1f85760205c5309f" alt=""
hi, followup question: Is there an impact to performance when using debug mode? On Tue, Feb 12, 2019 at 11:08 PM Yusuke Tsutsumi <yusuke@tsutsumi.io> wrote:
Great, thank you! I'll try it out, looks promising.
On Fri, Feb 8, 2019 at 5:37 PM Ben Darnell <ben@bendarnell.com> wrote:
Asyncio's debug mode does this (and a few more things). Call `asyncio.get_event_loop().set_debug()` to enable it.
https://docs.python.org/3/library/asyncio-dev.html#debug-mode
-Ben
On Fri, Feb 8, 2019 at 5:10 PM Yusuke Tsutsumi <yusuke@tsutsumi.io> wrote:
Hi,
In tornado, there's a really nice feature called set_blocking_signal_threshold, which sets a signal that fires if a coroutine has been running for too long without returning control back to the main loop:
https://www.tornadoweb.org/en/stable/ioloop.html?highlight=signal#tornado.io...
In tornado this will then log the traceback of the coroutine in question. This has been a very valuable tool when a developer accidentally introduces code that blocks the event loop for way too long of a time.
Is there an equivalent in asyncio? I have a sketch in my head of how to implement that, but wanted to see if it existed somewhere first.
Thanks! -Yusuke _______________________________________________ Async-sig mailing list Async-sig@python.org https://mail.python.org/mailman/listinfo/async-sig Code of Conduct: https://www.python.org/psf/codeofconduct/
participants (2)
-
Ben Darnell
-
Yusuke Tsutsumi