微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

docker部署fastapi项目及日志挂载的方法是什么

今天小编给大家分享一下docker部署fastapi项目及日志挂载的方法是什么的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。

    docker部署fastapi项目以及日志挂载

    最近在尝试用docker部署fastapi项目

    他的基本架构是由Nginx+guvicorn+uvicorn+fastapi项目组成的

    Nginx

    Nginx起到反向代理的作用

    可能有人会问,为什么要用Nginx反向代理,我直接访问项目不行吗?

    其实Nginx不只是反向代理的功能,还有很多像负载均衡、请求拦截静态文件访问等等功能,而且他还隐藏了web服务的地址。

    uvicorn

    uvicorn是什么呢?大家都知道,fastapi使用的是Asgi协议,它是Wsgi协议的一种升级

    而uvicorn是一个性能的Asgi服务器,它建立在uvloop和httptools之上,

    我们在本地开发时可以使用uvicorn来做服务器,

    不过虽然uviorn也可以启动和运行多个进程,但是在处理工作进程的能力上更有限。

    gunicorn

    所以我使用gunicorn来做进程管理器,虽然gunicorn是一个Wsgi服务器,本身与fastapi不兼容,但是你只要告诉它使用哪个特定的工作进程类,他就可以使用这个类启动一个或多个工作进程

    这不就巧了吗?uvicorn就有一个gunicorn兼容的worker类

    下面我们来讲一下究竟怎么启动

    首先我们需要下载uvicorn和gunicorn

    pip install "uvicorn[standard]"
    pip install gunicorn

    然后我们就可以启动了

    不过官方展示的是命令行启动:

    gunicorn main:app --workers 4 --worker-class uvicorn.workers.UvicornWorker --bind 0.0.0.0:80

    并没有展示文件启动的方式,我们还是习惯配置文件启动,其实也很简单。

    我们只需要在项目根路径下建立一个config.py文件作为配置文件即可。

    import multiprocessing
    
    # 是否开启debug
    debug = True
    
    # 设置守护进程
    daemon = True
    
    # 绑定ip和端口号
    bind = '0.0.0.0:8000'
    
    # 超时时间
    timeout = 30
    
    # 工作模式
    worker_class = 'uvicorn.workers.UvicornWorker'
    
    # 进程数
    workers = multiprocessing.cpu_count() * 2 + 1
    
    # 设置证书
    # keyfile = ''
    # certfile = ''
    
    # 日志级别,这个日志级别指的是错误日志级别,而访问日志的级别无法设置
    loglevel = 'debug'
    
    #设置执行路径
    chdir = './sql_app'
    
    # 日志配置
    # 访问日志文件
    accesslog = "/app/sql_app/log/access.log"
    # 错误日志文件
    errorlog = "/app/sql_app/log/error.log"

    这里我们只要把worker_class 工作模式设置成’uvicorn.workers.UvicornWorker’,他就可以启动我们的uvicorn服务器了。

    注意设置好执行路径和日志文件

    后执行启动命令

    gunicorn -c config.py main:app

    其中main为项目的初始化文件

    docker日志挂载的问题

    关键是本地服务器没有写入的权限 

    关键看这里吧(Permission denied), 一直没有看正方,以为是配置日志文件 找不到有问题,下面是部分异常

    10:35:09,498 |-ERROR in ch.qos.logback.core.rolling.RollingFileAppender[FILE] - openFile(null,true) call Failed. java.io.FileNotFoundException: logs/bandwidth.log.2019-04-25.log (Permission denied)
            at java.io.FileNotFoundException: logs/bandwidth.log.2019-04-25.log (Permission denied)
            at      at java.io.FileOutputStream.open0(Native Method)
            at      at java.io.FileOutputStream.open(FileOutputStream.java:270)
            at      at java.io.FileOutputStream.<init>(FileOutputStream.java:213)
            at      at ch.qos.logback.core.recovery.ResilientFileOutputStream.<init>(ResilientFileOutputStream.java:26)
            at      at ch.qos.logback.core.FileAppender.openFile(FileAppender.java:204)
            at      at ch.qos.logback.core.FileAppender.start(FileAppender.java:127)
            at      at ch.qos.logback.core.rolling.RollingFileAppender.start(RollingFileAppender.java:100)
            at      at ch.qos.logback.core.joran.action.AppenderAction.end(AppenderAction.java:90)
            at      at ch.qos.logback.core.joran.spi.Interpreter.callEndAction(Interpreter.java:309)
            at      at ch.qos.logback.core.joran.spi.Interpreter.endElement(Interpreter.java:193)

    尝试好多遍,才真正看懂原因也是从网上看到的一点启发,希望大家也能注意到,我用如下命令完美解决

    docker run   -it --privileged=true    -v /dockerlogs:/app/logs   -d -p 5080:5080  82edb4bbc79b

    挂载宿主机已存在目录后,在容器内对其进行操作,报“Permission denied”

    可通过两种方式解决

    1> 关闭selinux。

    临时关闭:# setenforce 0

    永久关闭修改/etc/sysconfig/selinux文件,将SELINUX的值设置为disabled。

    2> 以特权方式启动容器 

    指定--privileged参数

    如:

    # docker run -it --privileged=true -v /test:/softlogs

    以上就是“docker部署fastapi项目及日志挂载的方法是什么”这篇文章的所有内容,感谢各位的阅读!相信大家阅读完这篇文章都有很大的收获,小编每天都会为大家更新不同的知识,如果还想学习更多的知识,请关注编程之家行业资讯频道。

    版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。

    相关推荐