当前位置: 首页 > news >正文

Flask应用中处理异步事件(后台线程+事件循环)的方法(2)

在上一节,我们讲述了最简单最基础的后线程的建立,现在我们将进行拓展
Flask应用中处理异步事件(后台线程+事件循环)的方法(1)
在我们的实际应用当中,我们需要定义三个东西

  1. 一个多线程的信号旗,这里的信号旗指的是多线程编程中一个非常基础且重要的同步工具
    它只有两种状态:
    Clear (清除/未设置): 信号灯是红色的,旗子是放下的。
    Set (设置): 信号灯是绿色的,旗子是举起的。
    当进程调用event.wait(),如果此时事件是 “Clear” 状态(红灯),那么这个线程就会停下来,进入等待状态,被阻塞。

  2. 一个 循环的对象

  3. 一个新线程

接下来在这里我们看到了,有一个target参数,这个就是调用我们的一个说明书

# 1. 创建一个线程同步工具mcp_ready_event = threading.Event()# 2. 创建一个新的 asyncio 事件循环对象background_event_loop = asyncio.new_event_loop()# 3. 创建一个新线程,目标是运行 start_event_loop 函数loop_thread = threading.Thread(target=start_event_loop, args=(background_event_loop, mcp_ready_event),daemon=Truename="name")loop_thread.start() # 启动这个新线程# 4. 主线程在这里暂停,等待后台线程通知logging.info("主线程正在等待 MCP 初始化...")is_ready = mcp_ready_event.wait(timeout=30.0) # 暂停30秒,等待加载

那么我们的说明书怎么写呢?这里举例mcp的连接初始化
初始化这里,无论成功还是失败,初始化流程走完后,调用 .set() 来释放正在 wait() 的主线程。

# ... existing code ...
async def initialize_mcp_connection(ready_event: threading.Event):"""在应用启动时启动MCP服务器并建立一个持久的会话。完成后通过 event 通知主线程。"""# ...try:# 初始化代码except Exception as e:# ... 错误处理 ...finally:logging.info("MCP 初始化过程结束,通知主线程。")ready_event.set() 

初始化完毕之后,我们就进行接下来的开始线程
这里的参数 loop: asyncio.AbstractEventLoop 和 ready_event: threading.Event 是什么意思?
这是一种现代 Python 的语法,叫做 类型提示 (Type Hinting)。它本身不强制任何东西,但它极大地增强了代码的可读性和可维护性,并且能被很多开发工具利用来进行代码检查。

  • loop: asyncio.AbstractEventLoop: 这行代码的意思是,我们期望 loop 这个参数是一个 asyncio.AbstractEventLoop 类型的对象。它告诉任何阅读或调用这个函数的人:“请给我一个 asyncio 的事件循环对象。”
  • ready_event: threading.Event: 同理,这表示我们期望 ready_event 这个参数是一个我们刚才讲的 threading.Event 类型的对象。
def start_event_loop(loop: asyncio.AbstractEventLoop, ready_event: threading.Event):"""在一个线程中启动事件循环,并在启动时安排MCP初始化。"""asyncio.set_event_loop(loop)    loop.create_task(initialize_mcp_connection(ready_event))    logging.info("后台事件循环已启动,MCP 初始化任务已安排。")loop.run_forever()

需要注意这里start_event_loop 函数中的 loop,和主线程中的 background_event_loop,虽然名字不同,但它们指向的是内存中同一个事件循环对象。

最后只需要运行一个专门用于从一个普通线程向一个正在运行 asyncio 事件循环的线程提交任务。

asyncio.run_coroutine_threadsafe(coro, loop):

相关文章:

  • 一个完整的LSTM风光发电预测与并网优化方案,包含数据处理、模型构建、训练优化、预测应用及系统集成实现细节
  • 2025软件测试面试题汇总(接口测试篇)
  • Kubernetes安全机制深度解析(四):动态准入控制和Webhook
  • 成都鼎讯短波通信信号模拟设备:短波频段的电磁模拟王者​
  • visual studio2019+vcpkg管理第三方库
  • 谷歌具身智能VLA大模型 —— Gemini Robotics : 将人工智能带入到物理世界
  • CLONE——面向长时任务的闭环全身遥操:其MoE架构可实现“蹲着走”,且通过LiDAR里程计和VR跟踪技术解决位置偏差问题
  • 数字孪生之KTV洗脚城白皮书:娱乐产业的虚实融合革命
  • Day01_C数据结构
  • 2025虚幻人物模型积累
  • 手阳明大肠经之下廉穴
  • LeetCode 2529.正整数和负整数的最大计数
  • 【C语言指南】数组作为函数参数的传递机制
  • Rust 学习笔记:关于处理任意数量的 future 的练习题
  • JS进阶 Day01
  • 多目标粒子群算法可以出pareto图
  • 2025年6月英语四级CET-4作文预测10篇7页PDF
  • 危险品运输行业观察
  • 力扣-279.完全平方数
  • 宝塔面板WordPress中使用Contact Form 7插件收不到邮件的解决方法
  • 免费建网站电话/如何做网销
  • 家庭电脑做网站/p站关键词排名
  • 宁波网站排名优化/网络营销好不好
  • 赣州北京网站建设/整合营销传播方案案例
  • 新的网站做淘宝客/深圳博惠seo
  • 做网站成都/武汉网站快速排名提升