我有以下问题:给定一个运行 fastapi 的后端,它有一个流式端点,用于更新前端,我想在每次调用更新后端状态的函数时发送这些更新(可以通过计划的作业或命中并导致状态更新的不同端点)。
我想实现的一个简单版本是:
from fastapi import FastAPI
from starlette.responses import StreamingResponse
class State:
def __init__(self):
self.messages = []
def update(self, new_messages):
self.messages = new_messages
# HERE: notify waiting stream endpoint
app = FastAPI()
state = State()
@app.get('/stream')
def stream():
def event_stream():
while True:
# HERE lies the question: wait for state to be update
for message in state.messages:
yield 'data: {}\n\n'.format(json.dumps(message))
return StreamingResponse(event_stream(), media_type="text/event-stream")
我希望它永远运行下去。每次状态更新时,都会event_stream
解除阻塞并发送消息。
我看过线程和异步,但我觉得我缺少一些关于如何在 python 中执行此操作的简单概念。