企业级FastAPI后端模板搭建(三)整合日志Log

整合日志Log

下载loguru

shell 复制代码
pip install loguru

创建log/log.py文件,代码如下:

python 复制代码
import os
import sys

from loguru import logger as loguru_logger

from settings import settings

class LoggingConfig:
  """统一日志配置管理"""

  def __init__(self) -> None:
    self.debug = settings.DEBUG
    self.level = "DEBUG" if self.debug else "INFO"
    self.log_dir = "logs"
    self.ensure_log_dir()

  def ensure_log_dir(self):
    """确保日志目录存在"""
    if not os.path.exists(self.log_dir):
      os.makedirs(self.log_dir, exist_ok=True)

  def get_log_format(self):
    """获取统一的日志格式"""
    return (
      "<green>{time:YYYY-MM-DD HH:mm:ss.SSS}</green> | "
      "<level>{level: <8}</level> | "
      "<cyan>{name}</cyan>:<cyan>{function}</cyan>:<cyan>{line}</cyan> | "
      "<level>{message}</level>"
    )

  def get_file_format(self):
    """获取文件日志格式(无颜色)"""
    return (
      "{time:YYYY-MM-DD HH:mm:ss.SSS} | "
      "{level: <8} | "
      "{name}:{function}:{line} | "
      "{message}"
    )

  def setup_logger(self):
    """配置日志输出"""
    # 清除默认处理器
    loguru_logger.remove()

    # 控制台输出(带颜色)
    loguru_logger.add(
      sink=sys.stdout,
      level=self.level,
      format=self.get_log_format(),
      colorize=True,
      backtrace=True,
      diagnose=True,
    )

    # 文件输出 - 所有级别日志
    loguru_logger.add(
      sink=f"{self.log_dir}/backend_{{time:YYYY-MM-DD}}.log",
      level="DEBUG",
      format=self.get_file_format(),
      rotation="100 MB",
      retention="30 days",
      compression="zip",
      encoding="utf-8",
      backtrace=True,
      diagnose=True,
    )

    # 错误日志单独文件
    loguru_logger.add(
      sink=f"{self.log_dir}/backend_error_{{time:YYYY-MM-DD}}.log",
      level="ERROR",
      format=self.get_file_format(),
      rotation="50 MB",
      retention="90 days",
      compression="zip",
      encoding="utf-8",
      backtrace=True,
      diagnose=True,
    )

    # 为所有日志添加默认上下文
    # 注意:这里重新绑定会创建新的logger实例

    # 记录日志系统启动
    loguru_logger.info("日志系统已启动")

    return loguru_logger

# 全局日志配置实例
logging_config = LoggingConfig()
logger = logging_config.setup_logger()

创建log/__init__.py文件,代码如下:

python 复制代码
from .log import logger, logging_config

__all__ = [
  "logger",
  "logging_config",
]

修改main.py文件:

python 复制代码
from fastapi import FastAPI
from core.init_app import register_routers

from log import logger

app = FastAPI()

logger.info("log test")

register_routers(app, prefix="/api")
相关推荐
wuxinyan1231 小时前
工业级大模型学习之路031:Streamlit 高级功能多会话管理和知识库管理
python·学习·智能体
小江的记录本1 小时前
【Spring AI】Spring AI中RAG误触发与系统提示词泄露问题解决方案(完整版+代码方案)
java·人工智能·spring boot·后端·python·spring·面试
勇往直前plus2 小时前
Python 属性访问与操作全解析:内置函数、魔法方法与描述符深度指南
java·网络·python
treacle田2 小时前
使用达梦DTS迁移Oracle数据到达梦数据库过程步骤-记录总结
数据库·dts 迁移oracle到达梦
Arenaschi2 小时前
关于GPT的版特点
java·网络·人工智能·windows·python·gpt
就叫飞六吧2 小时前
MySQL 驱动里那个 `cj` 到底是什么?
数据库·mysql
MageGojo2 小时前
短链还原 API 怎么接入:展开跳转链路、查看状态码和最终落地页
数据库·redis·缓存
llilay2 小时前
企业级FastAPI后端模板搭建(一)初始化项目
fastapi
蚰蜒螟2 小时前
从mkdir命令到磁盘:Linux内核目录创建过程深度解析
linux·运维·数据库