我有一个简单的 fastApi 演示应用程序,它实现了一个功能:通过调用名为 changeResponse 的 post api 获取不同的响应 json。 changeResponse api 只是改变了一个全局变量,另一个 api 通过同一个全局变量返回不同的响应。在本地环境中,它工作正常,但是当我在 docker 上构建它时,我只调用 changeResponse 一次后响应总是改变。代码如下如下:
from typing import Optional
from fastapi import FastAPI
from util import read_json
import enum
app = FastAPI()
type = "00"
@app.post("/changeResponse")
async def handle_change_download_response(param:Optional[str]):
global type
type = param
print("type is "+type)
return {"success":"true"}
@app.post("/download")
async def handle_download(param:Optional[str]):
print("get download param: "+param)
if legalDownload(param):
print("type is "+type)
return read_json.readDownloadSuccessRes(type)
else:
return read_json.readDownloadFailRes()
def legalDownload(data:str)->bool:
return True
dockerfile 如下:
FROM tiangolo/uvicorn-gunicorn-fastapi:python3.7
COPY ./app /app
我除了:调用 changeResponse 参数为 7,获得响应 7,调用 changeResponse 参数为 8,获得响应 8。我得到的:调用 changeResponse 参数为 7,获得响应 7,调用 changeReponse 8,有时响应为 7 , 有时是 8, 无法预测
原文由 rookie 发布,翻译遵循 CC BY-SA 4.0 许可协议
tiangolo/uvicorn-gunicorn-fastapi
基于 uvicorn-gunicorn-docker 镜像,默认创建多个 worker。摘自 gunicorn_conf.py :default_web_concurrency = workers_per_core * cores
因此,出现所描述的情况是因为请求由 不同的工作者(进程)处理。每个都有自己的全局变量副本
更新:如果要更改工作人员数量,请使用以下环境变量:
您可以将其设置为:
此处 对这些变量和示例进行了更详细的描述
如果你想在 Worker 之间共享数据,请关注这个 话题。