FastAPI项目中:Loguru日志记录为何在代码启动Uvicorn时无法打印HTTP请求日志?

霞舞
发布: 2025-02-26 12:44:21
原创
1024人浏览过

fastapi项目中:loguru日志记录为何在代码启动uvicorn时无法打印http请求日志?

FastAPI项目中Loguru日志记录与Uvicorn启动方式的差异分析

本文分析了在FastAPI项目中,使用Loguru进行日志记录时,Uvicorn的不同启动方式(命令行 vs. 代码)如何影响HTTP请求日志输出的问题。

问题表现为:使用uvicorn main:app命令启动时,HTTP请求日志正常打印;而使用代码启动Uvicorn服务器时,HTTP请求日志缺失。

代码启动Uvicorn的示例:

if __name__ == "__main__":
    config = uvicorn.config("main:app", host=serveice_host_ip, port=int(service_host_port), workers=1)
    server = uvicorn.server(config)
    server.run()
登录后复制

即使添加access_log=True参数:

if __name__ == "__main__":
    config = uvicorn.config("main:app", host=serveice_host_ip, port=int(service_host_port), access_log=True, workers=1)
    server = uvicorn.server(config)
    server.run()
登录后复制

问题仍然存在。这并非access_log参数设置错误,而是代码启动方式绕过了Uvicorn的默认日志处理机制。

logger.py文件中的InterceptHandler类负责将Uvicorn的日志重定向到Loguru:

class InterceptHandler(logging.Handler):
    def emit(self, record: logging.LogRecord) -> None:  # pragma: no cover
        # ... (代码略) ...
登录后复制

它拦截了uvicorn.asgi、uvicorn.access和uvicorn这三个logger的日志。命令行启动时,Uvicorn自行处理日志,InterceptHandler能够成功捕获并重定向。

然而,代码启动时,Uvicorn的日志处理流程发生变化,InterceptHandler无法有效捕获Uvicorn内部的HTTP请求日志。这可能是因为两种启动方式在日志处理机制上存在差异。 setting.py中Loguru的handler配置本身没有问题,问题在于Uvicorn在代码启动模式下的日志处理流程改变,导致InterceptHandler失效。

解决此问题需要深入研究Uvicorn的代码启动流程,并可能需要调整InterceptHandler或Uvicorn的配置,以确保日志正确捕获和输出。

以上就是FastAPI项目中:Loguru日志记录为何在代码启动Uvicorn时无法打印HTTP请求日志?的详细内容,更多请关注php中文网其它相关文章!

全能打印神器
全能打印神器

全能打印神器是一款非常好用的打印软件,可以在电脑、手机、平板电脑等设备上使用。支持无线打印和云打印,操作非常简单,使用起来也非常方便,有需要的小伙伴快来保存下载体验吧!

下载
相关标签:
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号