单例日志类

本文介绍了如何使用Python创建一个LoggingSingleton类,实现在整个应用中共享日志配置,确保单例模式下日志管理的统一性。它包含了配置日志格式、处理器和根日志器的方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

logging_singleton.py

import logging
import logging.config

class LoggingSingleton:
_instance = None

def __new__(cls, *args, **kwargs):
    if not cls._instance:
        cls._instance = super(LoggingSingleton, cls).__new__(cls)
        cls._instance.configure_logging()
    return cls._instance

def configure_logging(self):
    LOGGING = {
        'version': 1,
        'disable_existing_loggers': False,
        'formatters': {
            'verbose': {
                'format': '%(levelname)s %(asctime)s %(module)s %(process)d %(thread)d %(message)s'
            },
        },
        'handlers': {
            'console': {
                'level': 'DEBUG',
                'class': 'logging.StreamHandler',
                'formatter': 'verbose'
            },
        },
        'root': {
            'handlers': ['console'],
            'level': 'DEBUG',
        },
    }
    logging.config.dictConfig(LOGGING)

def get_logger(self, name):
    return logging.getLogger(name)

创建单例并导出

logging_singleton = LoggingSingleton()

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值