python fastapi + uvicorn 记录日志的最佳实践,结合nb_log
python fastapi + uvicorn 记录日志的最佳实践,要记录对fastapi什么时候请求了什么url和入参,只需要记录uvicorn命名空间的日志就可以了。
文章使用nb_log 五彩日志来记录web后台的控制台日志 + 多进程安全切割的文件日志。
fastapiweb222.py 文件内容。
from pathlib import Path import uvicorn from fastapi import FastAPI import nb_log import requests logger = nb_log.get_logger('fastapi_demo',) nb_log.get_logger('urllib3') app = FastAPI() @app.get("/") def read_root(): logger.debug('绿色') logger.info('蓝色') logger.warning('黄色') logger.error('粉红色') logger.critical('血红色') requests.get('http://www.baidu.com') # 日志回自动记录requests包发的任何请求,因为requests调用urllib3,而nb_log.get_logger('urllib3')对urllib3的日志命名空间添加了handler。 return {"Hello": "World"} if __name__ == '__main__': # log_config = uvicorn.config.LOGGING_CONFIG # log_config["handlers"]["access"]["class"] = "nb_log.handlers.ColorHandler" # log_config["handlers"]["default"]["class"] = "nb_log.handlers.ColorHandler" LOG_FILE_PATH = '/pythonlogs' LOGGING_CONFIG: dict = { "version": 1, "disable_existing_loggers": False, "formatters": { "default": { "()": "uvicorn.logging.DefaultFormatter", "fmt": "%(asctime)s %(levelprefix)s %(message)s", # 这里日志格式加了时间显示 "use_colors": False, }, "access": { "()": "uvicorn.logging.AccessFormatter", "fmt": '%(asctime)s %(levelprefix)s %(client_addr)s - "%(request_line)s" %(status_code)s', # 这里日志格式加了时间显示 }, }, "handlers": { "default": { "formatter": "default", "class": "logging.StreamHandler", "stream": "ext://sys.stderr", }, "default_file": { "formatter": "default", "class": "nb_log.handlers.ConcurrentRotatingFileHandler", # 注意这里是多进程安全切割日志 'filename': Path(LOG_FILE_PATH) / 'uvicorn_default.log', 'maxBytes': 1000 * 1000 * 100, 'backupCount': 3, }, "access": { "formatter": "access", "class": "nb_log.handlers.ColorHandler", # 这里用了nb_log的彩色控制台handler。 }, "access_file": { "formatter": "access", "class": "nb_log.handlers.ConcurrentRotatingFileHandler", # 注意这里是多进程安全切割日志 'filename': Path(LOG_FILE_PATH) / 'uvicorn_access.log', 'maxBytes': 1000 * 1000 * 100, 'backupCount': 3, }, }, "loggers": { "uvicorn": {"handlers": ["default", "default_file"], "level": "INFO"}, "uvicorn.error": {"level": "INFO"}, "uvicorn.access": {"handlers": ["access", "access_file"], "level": "INFO", "propagate": False}, }, } uvicorn.run(app="fastapiweb222:app", host="127.0.0.1", port=8082, reload=True, debug=True, log_config=LOGGING_CONFIG)
控制台截图:
文件日志截图:
反对极端面向过程编程思维方式,喜欢面向对象和设计模式的解读,喜欢对比极端面向过程编程和oop编程消耗代码代码行数的区别和原因。致力于使用oop和36种设计模式写出最高可复用的框架级代码和使用最少的代码行数完成任务,致力于使用oop和设计模式来使部分代码减少90%行,使绝大部分py文件最低减少50%-80%行的写法。