Python日志系统需兼顾可读性、可维护性、可追溯性和运行时可控性,核心是分离关注点;应使用logging.getLogger(__name__)获取命名记录器,避免污染root logger,并通过dictConfig()声明式配置,在启动早期统一管理handlers、formatters、filters及结构化日志。
Python 日志系统不是“能打印就行”,而是要兼顾可读性、可维护性、可追溯性和运行时可控性。核心在于分离关注点:谁打日志(业务代码)、怎么打(格式与级别)、输出到哪(handler)、如何过滤(filter)以及何时生效(配置时机)。
避免直接使用 logging.debug() 这类模块级函数,它们会污染 root logger,导致日志行为不可控。每个模块应通过 logging.getLogger(__name__) 获取专属记录器,形成层级结构(如 myapp.api.auth),便于统一配置和精细控制。

在应用启动早期(如 main.py 或 app init 阶段)一次性加载字典配置,清晰表达日志流向与规则。basicConfig() 只作用于 root logger 且不可逆,不适合多 handler、多 level 场景。
用 logger.info("User %s logged in from %s", user_id, ip) 替代 logger.info(f"User {user_id} logged in from {ip}")。前者延迟格式化,不触发时无性能开销;更重要的是,为未来接入 ELK、Loki 等系统预留结构化解析能力。
DEBUG:仅开发/排查时开启,含详细流程变量;INFO:用户可观测的关键状态(服务启动、任务完成、配置加载);WARNING:可能影响体验但未中断的异常(重试成功、降级生效);ERROR:功能失败,需人工介入;CRITICAL:服务不可用。