Python 日志记录开销

标签 python python-3.x asynchronous python-asyncio

我正在使用 asyncio 编写代码具有大量信息/调试日志记录的模块 (logging.FileHandler)。我担心在 asyncio 中大量使用日志记录会降低我的应用程序的性能,因为日志记录会阻止操作。

最好的解决方案是什么?没有找到有关日志记录开销的任何信息。

也许使用 SocketHandlerMemoryHandler会有帮助吗?对于我使用的指标 statsd (这也是阻塞操作,但必须非常快),但我更关心非阻塞日志记录。

代码示例:

@asyncio.coroutine
def creator_worker(self):
    while not self.q.empty():
        with (yield from self.semaphore):
            sample = yield from self.q.get()
            logging.debug('Got new sample, processing')
            # start processing

我知道

import os
os.environ['PYTHONASYNCIODEBUG'] = '1'
import asyncio

但这不是我要找的。

谢谢

最佳答案

Logging 文档提供了一种解决方案,通过一个QueueHandler 进行日志记录,然后在另一个线程中使用一个QueueListener 来处理日志记录。 https://docs.python.org/3.6/howto/logging-cookbook.html#dealing-with-handlers-that-block

关于Python 日志记录开销,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35698025/

相关文章:

python - 机器学习鸡尾酒会音频应用

Python Excelwriter (xlsxwriter) 从 URL 插入图像

javascript - Request js 中的回调问题

python - 如何正确地动态关闭 Python RQ 工作进程?

java - 所有异步任务是否可以同时读取ArrayList而没有任何延迟

python - 在使用 OpenCv 进行图像处理期间保留字符顺序

javascript - Bokeh :在图像图中实现自定义 javascript

python - 总结字典的值(value)

python - 调用objects.update_or_create后,Django模型得到 "ValueError: invalid literal for int() with base 10: "

python - 在python 3中导入,请解释输出