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中文网其它相关文章!