关于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为项目的初始化文件

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值