解决一个问题,分享一个库 LoggerServer。

2017-11-16 15:18:51 +08:00
 kehr

实现 Python 多进程日志采用 logging 模块打印到同一个文件的需求。

logging 模块是线程安全的,支持多线程打印,所以多个线程向同一个日志文件打日志完全没问题。最近开发的项目为了利用多核(用的 CPython ),起了多个实例并向同一个文件打日志,后续发现有日志丢失的情况。

查文档,找到了官方说明:logging cookbook

虽然官方给了示例,但考虑到客户端日志量大,过高的 QPS 可能会导致日志服务处理不过来。正好对 Tornado 比较熟悉,就用 Tornado 的 TCPServerioloop 写了一个日志服务器,文档和说明都整理好了,公司的项目也在用,拿出来大家看看还有什么问题和优化的地方。

文档参见:LoggerServer Documentaion

觉得还不错的同学,点个 star 吧: https://github.com/kehr/LoggerServer

1257 次点击
所在节点    Python
0 条回复

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/406945

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX