首页 > 编程语言 >python fastapi + uvicorn 记录日志的最佳实践,结合nb_log

python fastapi + uvicorn 记录日志的最佳实践,结合nb_log

时间:2022-09-06 20:11:38浏览次数:73  
标签:log handlers python fastapi nb uvicorn access 日志

 

 

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)

 

控制台截图:

 

 

文件日志截图:

 

标签:log,handlers,python,fastapi,nb,uvicorn,access,日志
From: https://www.cnblogs.com/ydf0509/p/16663158.html

相关文章

  • ShowDialog
    PrivateSubBT_DPNO1_Click(senderAsObject,eAsEventArgs)HandlesBT_DPNO1.ClickDimLJPA003H_SELECTAsNewLJPA003H.LJPA003H_SELECTWith{......
  • 奶奶常说,黑白照片看的不清晰,还好我会Python,分分钟给她变成彩色的~
    咳咳~其实是奶奶常说,艾欧尼亚昂扬不灭,正义将指引着我们! 好吧,并不是奶奶说,只是最近回家发现一些黑白老照片,看着不够清晰,然后实验了一波用Python把老照片变成彩......
  • jenkins+python构建项目
    1.下载jenkinswindows版本2.安装:需要检验端口,因为本机8080被别的项目占用了,选择了80端口3.新建一个free风格项目  配置:github,github管理代码,相当于本地代码需要推......
  • centos 7.X 安装python3.X 使得python3.X 和 python2.x共存
    https://www.cnblogs.com/JahanGu/p/7452527.html(以亲试)https://blog.csdn.net/eastlhu/article/details/74931913https://www.cnblogs.com/FZfangzheng/p/7588944.html......
  • python(三)函数
    (六)字符串的比较is是通过比较两个对象的内存地址,查看内存地址的方法是id()in是包含==是类型和内容一致a=1b=1print(id(a))print(id(b))ifaisb: print......
  • pythonⅢ
    '''字符串的比较is:看通过id()对象的内存地址,查看内存地址的方式in:包含==:类型及内容一致'''a=1b=1print(id(a))print(id(b))ifaisb:    print('a和b内存地址都一样......
  • CentOS7 安装 python 3.7.4
     CentOS7安装python3.7.4 #安装环境(最小化安装)CentOSLinuxrelease7.0.1406(Core)#下载安装包https://www.python.org/ftp/python/3.7.4/Python-3.7.4.......
  • python struct unpack
    pythonstructunpackmsg=self.serverSocket.recv(1024)#接受服务端消息AngleSensorST,y_Angle_deg,x_Angle_deg,Z_Angle_deg,AngleDeviceTEMP,WatchdogCount=st......
  • gfology学习2
    Chapter2介绍不同类型常用于生成函数的级数1.形式幂级数定义:在形式幂级数中,\(x\)从来不指定一个数值,且对收敛和发散的问题不感兴趣,感兴趣的是系数序列\((a_0,a_1,\cdo......
  • 为了防止这个公众号被封,我连夜用Python爬取了它所有图片~
    哈喽兄弟们,今天来试试批量获取公众号文章,emmm…  虽然名义上是文章,单其实它是一篇纯图片文,至于为什么不是文字,小姐姐不比文字香?  事前准备 ......