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
p2pCoder
V2EX  ›  Python

Python 日志问题

  •  
  •   p2pCoder ·
    zgbgx · 2017-10-20 11:30:19 +08:00 · 2262 次点击
    这是一个创建于 2597 天前的主题,其中的信息可能已经有所发展或是发生改变。

    一个应用启动多个服务,如何使多个服务的日志输出到一个日志文件中?怎样配置,使用 logging 模块能实现吗?

    7 条回复    2017-10-24 13:19:26 +08:00
    Cooky
        2
    Cooky  
       2017-10-20 15:36:11 +08:00 via Android
    用外部日志吧,比如 syslog
    focusheart
        3
    focusheart  
       2017-10-20 16:01:17 +08:00
    楼上说的都对,logging 模块的还提供了一个例子: https://docs.python.org/2/howto/logging-cookbook.html#network-logging 很清楚。
    我们这边类似的情况,多个服务写日志,各写各的文件,然后用 logstash 收集到一起集中存储处理,也很方便的
    lolizeppelin
        4
    lolizeppelin  
       2017-10-21 10:52:21 +08:00 via Android
    可以 追加写的方式写入指定文件即可

    追加写是原子性的
    lolizeppelin
        5
    lolizeppelin  
       2017-10-21 10:57:54 +08:00 via Android
    限 Linux 下
    openstack 对多进程写日志没任何特殊处理

    为此我专门查过 你可以参考

    http://www.lolizeppelin.com/2017/08/05/linux-append-write/

    我 blog 手机浏览器显示有问题
    oneApple
        6
    oneApple  
       2017-10-23 14:44:04 +08:00
    python 的 logging 模块是线程安全的,写是追加模式可以当成是原子操作在多进程模式下也没问题。
    有问题的是在多进程切割日志,多进程下会有问题。
    参考下下面的,扩展了 logging 使 logging 进程安全。
    https://pypi.python.org/pypi/ConcurrentLogHandler/0.9.1
    chenqh
        7
    chenqh  
       2017-10-24 13:19:26 +08:00
    我是用 celery 做的,专门起一个 log 的 celery 进程来写日志
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   5144 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 63ms · UTC 05:42 · PVG 13:42 · LAX 21:42 · JFK 00:42
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.