首先看图,发现每个日志都被打印了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看下:
其实问题已经解决,确实是这个参数的问题。