本文主要是介绍FastAPI使用loguru时,出现重复日志打印的解决方案,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
首先看图,发现每个日志都被打印了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看下:
其实问题已经解决,确实是这个参数的问题。
这篇关于FastAPI使用loguru时,出现重复日志打印的解决方案的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!