FastAPI使用loguru时,出现重复日志打印的解决方案

发布时间:2023年12月24日

首先看图,发现每个日志都被打印了3条。其实这个和uvicorn日志打印的设计有关,在uvicorn中有多个logger,分别是uvicorn、uvicorn.error、uvicorn.access

而LOGGING默认有一个属性propagate,这个属性为True时,子日志记录器会重发到父纪录器上。

其实大家可以做个实验,我们发送请求,请求的日志是通过uvicorn.access这个logger打印的,但它却并不会出现打印三次的情况。因此我们可以从日志的配置角度去观察。

我们看下LOGGING_CONFIG:

    "loggers": {
        "uvicorn": {"handlers": ["default"], "level": "INFO"},
        "uvicorn.error": {"level": "INFO"},
        "uvicorn.access": {"handlers": ["access"], "level": "INFO", "propagate": False},
    }
可以看到,uvicorn.access的propagate是false,其他都为true,所以会出现日志传播,而正如上面所说,propagate可以控制日志传播。

我们先将propagate设置为false看下:

其实问题已经解决,确实是这个参数的问题。?

文章来源:https://blog.csdn.net/u011843342/article/details/135177632
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。