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 logging 日志配置,如何不输出到控制台

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

    我的日志配置如下,运行时自动输出到控制台,用 nohup 挂起,相应的输出也会输出 nohup.out 同时 my.log 也会有正确的日志输出 my.log 的日志输出格式是正确的,输出到控制台的日志和 ide ( pychram )调试时产生的日志一样

    logHandler = TimedRotatingFileHandler("logs/my.log", when="midnight")
    logFormatter = logging.Formatter('%(asctime)s %(name)-12s %(levelname)-8s %(message)s')
    logHandler.setFormatter(logFormatter)
    logger = logging.getLogger('myapp')
    logger.addHandler(logHandler)
    logger.setLevel(logging.INFO)
    

    具体应该怎么修改才能保证日志不输出两次?大佬们指导下

    7 条回复    2018-08-18 08:19:33 +08:00
    itskingname
        1
    itskingname  
       2018-08-16 09:29:29 +08:00   ❤️ 1
    你添加一个 StreamHandler,然后把他的 level 设置为 Fatal,这样就不会自动输出了。
    wyce2007
        2
    wyce2007  
       2018-08-16 09:32:52 +08:00 via iPhone
    nohup 把输出流定向到 null 设备,这样就只有你 log 文件的那部分日志输出
    参考资料: http://linux.vbird.org/linux_basic/0320bash.php#redirect_redirect
    p2pCoder
        3
    p2pCoder  
    OP
       2018-08-16 09:38:12 +08:00
    @itskingname
    找到个
    ```
    logger.propagate = False
    ```
    这样就不会输出到控制台,也不会输出到 nohup.out

    大佬这个也是个解决方法
    Sylv
        4
    Sylv  
       2018-08-16 10:08:59 +08:00 via iPhone   ❤️ 1
    logger 是有继承关系的,子 logger 会把日志向上传给父 logger 的 handlers 处理。
    你的 'myapp' logger 上面还有个 root logger (logging.getLogger(name=None)),因为在某个地方设置了 root logger 输出到控制台,所以 'myapp' logger 的日志也会输出到控制台。
    logger.propagate = False 是让子 logger 不把日志向上传给父 logger。但是如果 root logger 还有其它子 logger (例如其它第三方库的 logger ),它们的日志仍会输出到控制台。
    更为根本的解决方法是设置 root logger 不再输出到控制台(移除 StreamHandler )。
    zjb861107
        5
    zjb861107  
       2018-08-16 11:09:27 +08:00
    logging.basicConfig()试试
    princelai
        6
    princelai  
       2018-08-16 11:38:40 +08:00
    logging.basicConfig(
    format='%(asctime)s : %(levelname)s : %(message)s',
    level=logging.INFO,
    filename='/dev/null',
    filemode='w')
    lolizeppelin
        7
    lolizeppelin  
       2018-08-18 08:19:33 +08:00 via Android
    读下相关源码也就个把小时
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   我们的愿景   ·   实用小工具   ·   4354 人在线   最高记录 6543   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 40ms · UTC 04:08 · PVG 12:08 · LAX 21:08 · JFK 00:08
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.