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


今天小编给大家分享一下docker部署fastapi项目及日志挂载的方法是什么的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。最近在尝试用docker部署fastapi项目他的基本架构是由nginx+guvicorn+uvicorn+fastapi项目组成的nginx起到反向代理的作用可能有人会问,为什么要用nginx反向代理,我直接访问项目不行吗?其实nginx不只是反向代理的功能,还有很多像负载均衡、请求拦截、静态文件访问等等功能,而且他还隐藏了web服务的地址。uvicorn是什么呢?大家都知道,fastapi使用的是ASGI协议,它是WSGI协议的一种升级版而uvicorn是一个高性能的ASGI服务器,它建立在uvloop和httptools之上,我们在本地开发时可以使用uvicorn来做服务器,不过虽然uviorn也可以启动和运行多个进程,但是在处理工作进程的能力上更有限。所以我使用gunicorn来做进程管理器,虽然gunicorn是一个WSGI服务器,本身与fastapi不兼容,但是你只要告诉它使用哪个特定的工作进程类,他就可以使用这个类启动一个或多个工作进程这不就巧了吗?uvicorn就有一个gunicorn兼容的worker类下面我们来讲一下究竟怎么启动首先我们需要下载uvicorn和gunicorn然后我们就可以启动了不过官方展示的是命令行启动:并没有展示文件启动的方式,我们还是习惯配置文件启动,其实也很简单。我们只需要在项目根路径下建立一个config.py文件作免费云主机域名为配置文件即可。这里我们只要把worker_class 工作模式设置成’uvicorn.workers.UvicornWorker’,他就可以启动我们的uvicorn服务器了。注意设置好执行路径和日志文件然后执行启动命令其中main为项目的初始化文件关键是本地服务器没有写入的权限关键看这里吧(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.(FileOutputStream.java:213)
at at ch.qos.logback.core.recovery.ResilientFileOutputStream.(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)
尝试好多遍,才真正看懂原因也是从网上看到的一点启发,希望大家也能注意到,我用如下命令完美解决挂载宿主机已存在目录后,在容器内对其进行操作,报“Permission denied”可通过两种方式解决:1> 关闭selinux。临时关闭:# setenforce 0永久关闭:修改/etc/sysconfig/selinux文件,将SELINUX的值设置为disabled。2> 以特权方式启动容器指定–privileged参数如:以上就是“docker部署fastapi项目及日志挂载的方法是什么”这篇文章的所有内容,感谢各位的阅读!相信大家阅读完这篇文章都有很大的收获,小编每天都会为大家更新不同的知识,如果还想学习更多的知识,请关注百云主机行业资讯频道。

相关推荐: C#变量是什么C# 变量

这篇文章主要介绍了C#变量是什么的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇C#变量是什么文章都会有所收获,下面我们一起来看看吧。一个变量只不过是一个供程序操作的存储区的名字。在 C# 中,每个变量都有一个特定的类型,类型决定了…

免责声明:本站发布的图片视频文字,以转载和分享为主,文章观点不代表本站立场,本站不承担相关法律责任;如果涉及侵权请联系邮箱:360163164@qq.com举报,并提供相关证据,经查实将立刻删除涉嫌侵权内容。

Like (0)
Donate 微信扫一扫 微信扫一扫
Previous 05/22 09:02
Next 05/22 09:02

相关推荐