Python logging 日志配置,如何不输出到控制台

2018-08-16 09:19:30 +08:00
 p2pCoder

我的日志配置如下,运行时自动输出到控制台,用 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)

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

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

大佬这个也是个解决方法
Sylv
2018-08-16 10:08:59 +08:00
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
2018-08-16 11:09:27 +08:00
logging.basicConfig()试试
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
2018-08-18 08:19:33 +08:00
读下相关源码也就个把小时

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

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

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

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

© 2021 V2EX