簡體   English   中英

Python 記錄器 - 具有多個級別的多個記錄器實例 - 最佳實踐

[英]Python logger - multiple logger instances with multiple levels - best practice

我有以下要求:

  1. 擁有一個可以配置的全局記錄器(設置級別、附加處理程序、..)
  2. 擁有可以配置的每個模塊記錄器(設置級別、附加處理程序、..)

換句話說,我們需要更多不同配置的日志

因此我做了以下

  1. 創建設置記錄器的方法:
def setup_logger(module_name=None, level=logging.INFO, add_stdout_logger=True):

   print("Clear all loggers")
   for _handler in logging.root.handlers:
       logging.root.removeHandler(_handler)

   if add_stdout_logger:
       print("Add stdout logger")
       stdout_handler = logging.StreamHandler(sys.stdout)
       stdout_handler.setLevel(level)
       stdout_handler.setFormatter(logging.Formatter(fmt='%(asctime)-11s [%(levelname)s] [%(name)s] %(message)s'))
       logging.root.addHandler(stdout_handler)


   print("Set root level log")
   logging.root.setLevel(level)

   if module_name:
       return logging.getLogger(module_name)
   else:
       return logging.getLogger('global')

然后我創建記錄器如下:

logger_global = setup_logger(level=logging.DEBUG)
logger_module_1 = setup_logger(module_name='module1', level=logging.INFO)
logger_module_2 = setup_logger(module_name='module2', level=logging.DEBUG)

logger_global.debug("This is global log and will be visible because it is setup to DEBUG log")

logger_module_1.debug("This is logger_module_1 log and will NOT be visible because it is setup to INFO log") 

logger_module_2.debug("This is logger_module_2 log and will be visible because it is setup to DEBUG log")

在我嘗試什么可行,什么不可行並更深入地測試之前,我想問你這是否是一種好的做法,或者你有任何其他建議如何實現我們的要求?

感謝幫助

最后我找到了如何做到這一點:

def setup_logger(module_name=None, level=logging.INFO, add_stdout_logger=True):

   custom_logger = logging.getLogger('global')
   if module_name:
       custom_logger = logging.getLogger(module_name)     

   print("Clear all handlers in logger") # prevent multiple handler creation
   module_logger.handlers.clear()

   if add_stdout_logger:
       print("Add stdout logger")
       stdout_handler = logging.StreamHandler(sys.stdout)
       stdout_handler.setLevel(level)
       stdout_handler.setFormatter(logging.Formatter(fmt='%(asctime)-11s [%(levelname)s] [%(name)s] %(message)s'))
       module_logger.addHandler(stdout_handler)

    # here you can add another handlers ,...

    # because we use custom handlers which have the different type of log level,
    # then our logger has to have the lowest level of logging
    custom_logger.setLevel(logging.DEBUG)

   return custom_logger 

然后只需調用以下

logger_module_1 = setup_logger(module_name='module1', level=logging.INFO)
logger_module_2 = setup_logger(module_name='module2', level=logging.DEBUG)

logger_module_1.debug("This is logger_module_1 log and will NOT be visible because it is setup to INFO log") 

logger_module_2.debug("This is logger_module_2 log and will be visible because it is setup to DEBUG log")

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM