您的位置 首页 编程知识

Nameko框架下,Logger的handlers为空时,日志信息为何还能输出到标准输出?

nameko日志输出机制探究:空也能打印日志? 本文将探讨一个关于nameko框架日志输出的疑问:一个logg…

nameko日志输出机制探究:空也能打印日志?

本文将探讨一个关于nameko框架日志输出的疑问:一个logger的handlers为空,却仍然可以将日志信息输出到标准输出?

问题描述如下:代码使用nameko框架,通过nameko.runners._log模块记录日志信息。代码运行后,尽管_log.handlers返回空列表,日志信息“哈哈哈哈”却依然打印到了标准输出。而直接使用运行该脚本则没有任何输出。这引发了疑问:nameko是如何在handlers为空的情况下实现日志输出的?是否还有其他无需配置handlers即可输出到标准输出的方式?

代码片段如下:

from nameko.timer import timer  class keywordservice:     name = 'keyword_service'      @timer(1)     def print_log_ingo(self):         from nameko.runners import _log         _log.info('哈哈哈哈')         print(_log.handlers)
登录后复制

使用nameko run 101运行时,输出结果为:

starting services: keyword_service 哈哈哈哈 [] 哈哈哈哈 [] 哈哈哈哈 [] 哈哈哈哈 []
登录后复制

而直接使用python 101.py运行时,没有任何输出。

问题的关键在于nameko框架本身的日志处理机制。nameko run命令在启动服务时,会进行额外的日志配置,即使代码中_log.handlers为空,nameko也会利用其内部机制将日志信息输出到标准输出。这与直接使用python运行脚本的情况不同,后者不会执行nameko的日志配置步骤。

为了验证这一点,我们可以通过python的logging模块进行基本的日志配置,即使handlers为空,也能打印日志信息:

from nameko.timer import timer from nameko.runners import _log import logging  logging.basicConfig(level=logging.INFO, format='%(message)s')  _log.info('哈哈哈哈') print(_log.handlers)
登录后复制

这样修改后,即使直接使用python运行脚本,也能打印日志信息“哈哈哈哈”,同时_log.handlers仍然返回空列表。这说明nameko并非依赖于_log.handlers来进行日志输出,logging.bconfig设置了默认的日志处理器,即使_log.handlers为空,也能保证日志的输出。

这解释了为什么在nameko run命令下,即使handlers为空,也能将日志信息输出到标准输出。nameko内部的日志配置优先于代码中对_log.handlers的访问。

以上就是Nameko框架下,Logger的handlers为空时,日志信息为何还能输出到标准输出?的详细内容,更多请关注php中文网其它相关文章!

本文来自网络,不代表四平甲倪网络网站制作专家立场,转载请注明出处:http://www.elephantgpt.cn/8021.html

作者: nijia

发表回复

您的电子邮箱地址不会被公开。 必填项已用*标注

联系我们

联系我们

18844404989

在线咨询: QQ交谈

邮箱: 641522856@qq.com

工作时间:周一至周五,9:00-17:30,节假日休息

关注微信
微信扫一扫关注我们

微信扫一扫关注我们

关注微博
返回顶部