V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
推荐学习书目
Learn Python the Hard Way
Python Sites
PyPI - Python Package Index
http://diveintopython.org/toc/index.html
Pocoo
值得关注的项目
PyPy
Celery
Jinja2
Read the Docs
gevent
pyenv
virtualenv
Stackless Python
Beautiful Soup
结巴中文分词
Green Unicorn
Sentry
Shovel
Pyflakes
pytest
Python 编程
pep8 Checker
Styles
PEP 8
Google Python Style Guide
Code Style from The Hitchhiker's Guide
kehr
V2EX  ›  Python

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

  •  1
     
  •   kehr ·
    kehr · 2017-11-16 15:18:51 +08:00 · 1257 次点击
    这是一个创建于 2573 天前的主题,其中的信息可能已经有所发展或是发生改变。

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

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

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

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

    文档参见:LoggerServer Documentaion

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

    目前尚无回复
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   980 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 22ms · UTC 21:39 · PVG 05:39 · LAX 13:39 · JFK 16:39
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.