首页   注册   登录
V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
推荐学习书目
Learn Python the Hard Way
Python 学习手册
Python Cookbook
Python 基础教程
Python Sites
PyPI - Python Package Index
http://www.simple-is-better.com/
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
Coding
V2EX  ›  Python

Python logging 日志按天轮换问题

  •  
  •   feihuxiongdi · 139 天前 · 1594 次点击
    这是一个创建于 139 天前的主题,其中的信息可能已经有所发展或是发生改变。

    我使用 flask 开发 python 应用,下面是 logging 模块的配置:

    handlers:
      file_api:
        class: logging.handlers.TimedRotatingFileHandler
        level: INFO
        formatter: simple
        when: midnight
        filename: /data/log/api.log
    root:
      level: DEBUG
      handlers: [file_api]
    
    

    按理说,应该生成如下文件

    • /data/log/api.log
    • /data/log/api.log.2019-07-28
    • /data/log/api.log.2019-07-27
    • ...

    事实上,2019-07-29 的部分日志居然存到了 /data/log/api.log.2019-07-28 文件中。 某天的部分日志都会存到前一天的日志文件中。

    请问这是为什么?

    7 回复  |  直到 2019-07-30 11:23:38 +08:00
        1
    RRRoger   139 天前
    1. 可能时区问题
    2. 好像默认分割并不是按照每日来的
        2
    keakon   139 天前
    代码中是先检查是否需要 rotating,然后再 format 时间的,这里存在时间差。
    另外,官方的实现比较低效,自己实现比较好。
        3
    WanKang   139 天前
    自己重写 FileHandler 吧,这问题和时区这些没什么关系,python 的 logger 日志仅仅保证线程安全,不管你是时间分割还是大小分割最后都会遇到这个问题,你可以查查多进程 python 的 logger 日志写入混乱的相关资料。
        4
    txy3000   139 天前
    "class": "cloghandler.ConcurrentRotatingFileHandler"
    进程安全的 Handler 检索一下
        5
    wd   139 天前 via iPhone
    多进程吧?写一个文件然后通过 logrotate 啥的轮转吧
        7
    jesnridy   139 天前
    分割的逻辑是按照 modify time 来做的
    关于   ·   FAQ   ·   API   ·   我们的愿景   ·   广告投放   ·   感谢   ·   实用小工具   ·   3433 人在线   最高记录 5043   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.3 · 23ms · UTC 05:02 · PVG 13:02 · LAX 21:02 · JFK 00:02
    ♥ Do have faith in what you're doing.