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

使用 Celery + Redis + Eventlet 实现 Python 异步编程(Windows 环境)


一、环境搭建与依赖安装

1. 安装依赖包

pip install celery redis eventlet
  • celery:异步任务队列框架。
  • redis:作为消息中间件(Broker)和结果存储(Backend)。
  • eventlet:用于 Windows 环境下的协程支持(解决多进程兼容性问题)。

2. 启动 Redis 服务

  • 下载 Windows 版本 Redis
    https://github.com/tporadowski/redis/releases
    
  • 启动 Redis 服务
    redis-server.exe redis.windows.conf
    

二、代码实现

在这里插入图片描述

1. 定义 Celery 任务(tasks.py

import time
from celery import Celery# 创建 Celery 实例,指定 Broker(Redis)和结果存储(Redis)
broker = 'redis://127.0.0.1:6379/1'
backend = 'redis://127.0.0.1:6379/2'
app = Celery('tasks',broker=broker,  # Redis 队列backend=backend   # Redis 结果存储
)@app.task
def add(x, y):"""异步加法任务"""print("x+y的结果:", x+y)time.sleep(1)return x + y

2. 调用任务(demo.py

from tasks import addresult = add.delay(62, 4)  # 异步调用任务,返回 AsyncResult 对象
print(result.get())  # 阻塞等待任务结果

三、问题现象与解决方案

1. 问题:result.get() 阻塞无输出

现象描述

执行 demo.py 时,result.get() 会一直阻塞,直到启动 Celery Worker 后才输出结果。

原因分析
  • Celery 的异步执行流程
    1. add.delay(62, 4) 将任务发送到 Redis 队列(Broker)。
      在这里插入图片描述

    2. Worker 未启动 时,任务无法被消费,结果不会写入 Backend。

    3. result.get() 会尝试从 Backend 获取结果,但因结果未写入,会 无限等待

解决方案
  • 启动 Celery Worker
    celery -A tasks worker -l info -P eventlet
    
    • -P eventlet:指定使用 Eventlet 协程池(Windows 必须)。

    • 启动后,Worker 会从 Redis 队列中拉取任务并执行,结果写入 Redis Backend。
      在这里插入图片描述
      在这里插入图片描述

    • result.get() 会立即返回结果。
      在这里插入图片描述


四、Celery 异步原理详解(测试工程师友好版)

1. Celery 的核心架构

Celery 是一个 生产者-消费者 模型,由三部分组成:

  1. Broker(消息中间件)

    • 作用:存储待执行的任务队列。
    • 类比:快递公司的分拣中心,接收包裹(任务)并分发给快递员(Worker)。
  2. Worker(任务执行单元)

    • 作用:从 Broker 拿取任务并执行。
    • 类比:快递员,负责派送包裹(执行任务)。
  3. Backend(结果存储)

    • 作用:存储任务执行结果。
    • 类比:快递柜,任务完成后将结果存入,供用户(调用方)查询。

2. 异步执行流程图解

调用 add.delay(62, 4) → 任务写入 Redis(Broker)↓
Worker 启动后从 Redis 拿取任务 → 执行 add(62, 4)↓
执行结果写入 Redis(Backend)↓
调用 result.get() → 从 Redis 读取结果 → 输出 66

3. 为什么需要 Eventlet?

  • Windows 的限制
    Windows 不支持多进程(multiprocessing),而 Celery 默认使用多进程模式。
  • Eventlet 的作用
    通过 协程(Coroutine) 实现并发,模拟多线程效果,解决 Windows 环境下 Worker 启动失败的问题。

五、测试工程师的异步思维训练

1. 同步 vs 异步

场景同步(阻塞)异步(非阻塞)
发送邮件用户等待邮件发送完成再继续操作邮件在后台发送,用户可继续操作
文件处理用户必须等待文件处理完成处理完成后通知用户

2. 异步编程的核心思想

  • 事件驱动:任务遇到 I/O(如网络请求、文件读写)时,主动让出 CPU,执行其他任务。
  • 事件循环:不断检查任务状态,调度协程执行(如 asyncio 的事件循环)。

六、完整示例验证

1. 启动 Redis

可参考往期文章:Redis原理与Windows环境部署实战指南:助力测试工程师优化Celery调试

redis-server.exe redis.windows.conf

2. 启动 Celery Worker

celery -A tasks worker -l info -P eventlet

3. 运行 demo.py

python demo.py

输出结果

66

七、总结

1. 关键点回顾

  • Celery + Redis:生产者将任务写入 Redis,Worker 从 Redis 拿取任务并执行,结果存回 Redis。
  • Eventlet 的必要性:解决 Windows 环境下的多进程兼容性问题。
  • 异步的本质:通过事件驱动和协程实现高并发,避免阻塞主线程。

2. 测试工程师的实践建议

  • 验证异步任务:通过 result.get() 验证结果是否写入 Backend。
  • 监控任务状态:使用 result.status 查看任务状态(PENDING/SUCCESS/FAILURE)。
  • 调试技巧:检查 Redis 中的键值对,确认任务是否被正确处理。

通过以上步骤,你可以在 Windows 环境下轻松实现 Celery + Redis + Eventlet 的异步编程方案。异步编程的核心在于“让等待时间做其他事”,而 Celery 让你无需关心底层细节,专注于任务逻辑本身!

相关文章:

使用 Celery + Redis + Eventlet 实现 Python 异步编程(Windows 环境)

一、环境搭建与依赖安装 1. 安装依赖包 pip install celery redis eventletcelery:异步任务队列框架。redis:作为消息中间件(Broker)和结果存储(Backend)。eventlet:用于 Windows 环境下的协程…...

Selenium Web自动化测试学习笔记(二)--八大元素定位

前置设置及代码 目录结构如下,将驱动器chromedriver.exe复制粘贴到此目录下,具体环境配置参考笔记一: Selenium Web自动化测试学习笔记(一)-CSDN博客 首先和笔记(一)一样导入一些包用于设置谷…...

如何设置飞书多维表格,可以在扣子平台上使用

扣子可以链接到飞书多维表格,但很多人不知道具体如何操作,今天给大家分享下操作流程。 大家好,我是涛涛,欢迎来到我的空间。因为需要管理员审核,所以最好有管理员的手机就在旁边方便操作。 (一) 进入应用中心 https…...

C++初阶-string类的简单应用

目录 1.仅仅反转字母 2.字符串中第一个唯一字符 3.字符串最后一个单词的长度 4.验证回文串 5.字符串相加 6.总结 1.仅仅反转字母 题目链接:https://leetcode.cn/problems/reverse-only-letters/description/ 在数据结构中我们学了一种方法叫做前后指针法&…...

企业数字化转型第二课:接受不完美(1/2)

一.引言 先看一组中国企业数字化转型相关的数据: 战略认知层面:92%中国企业将数字化纳入战略核心(麦肯锡2023)执行困境层面:63%企业转型首年遭遇重大挫折(BCG 2024追踪)价值释放周期&#xff1…...

【MCP】function call与mcp若干问题整理

前言:大模型里agent 的 funcation call 是什么概念 在大模型中,Agent是一个能够理解目标、进行自主规划,并利用可用工具(包括Function Call)来执行任务以达成目标的系统或程序。Function Call是大型语言模型提供的一项…...

QT聊天项目DAY09

1. 安装Redis 直接从老师的网盘下载 链接: https://pan.baidu.com/s/1v_foHZLvBeJQMePSGnp4Ow?pwdyid3 提取码: yid3 启动Redis服务看一下,启动成功了 .\redis-server.exe .\redis.windows.conf 启动客户端看一下 2. 配置redis库,调用API 编译一下 …...

JAVA八股文

一、JAVA基础 1.面向对象: 面向对象编程是一种以对象为核心的编程,通过封装、继承、多态和抽象管理代码。 1.封装:将数据(属性)和行为(方法)绑定在一个对象中,隐藏内部细节&#…...

『深夜_MySQL』数据库操作 字符集与检验规则

2.库的操作 2.1 创建数据库 语法: CREATE DATABASE [IF NOT EXISTS] db_name [create_specification [,create_specification]….]create_spcification:[DEFAULT] CHARACTER SET charset_nam[DEFAULT] COLLATE collation_name说明: 大写的表示关键字 …...

1688拍立淘搜索相似商品API接口概述,json数据示例参考

1688拍立淘搜索相似商品API接口概述 1688拍立淘是阿里巴巴1688平台提供的以图搜图功能,允许开发者通过上传商品图片或图片URL,快速检索1688平台上的相似商品。该接口基于图像识别技术,结合1688的海量商品库,为商家、采购商或开发…...

使用 Java 11 的 HttpClient 处理 RESTful Web 服务

在现代 Web 开发中,与 RESTful Web 服务交互是一项核心任务。Java 作为一种广泛使用的编程语言,提供了多种处理 HTTP 请求的方法。在 Java 11 之前,开发者通常使用 HttpURLConnection 或第三方库(如 Apache HttpClient)。然而,这些方法要么过于底层,要么需要额外依赖。J…...

学习笔记:黑马程序员JavaWeb开发教程(2025.3.30)

11.6 案例-文件上传-阿里云OSS-集成 从程序中获取URL给前端&#xff0c;前端显示图片 拿到URL&#xff0c;但是在浏览器里面是直接下载&#xff0c;展示可以使用html中的<image>标签 Spring环境下&#xff0c;不建议再去new对象&#xff0c;将其交给IOC容器管理&#xff…...

【MySQL】-- 联合查询

文章目录 1. 简介1.1 为什么要使用联合查询1.2 多表联合查询时MySQL内部是如何进行计算的 2. 内连接2.1 语法2.2 示例 3. 外连接3.1 语法3.2 示例 4. 自连接4.1 应用场景4.2 示例4.3 表连接练习 5. 子查询5.1 语法5.2 单行子查询5.3 多行子查询5.4 多列子查询5.5 在from 子句中…...

《C++ Templates》:有关const、引用、指针的一些函数模板实参推导的例子

1.T按值传递 最简单的模板例子&#xff1a; template<typename T> void func(T x) {std::cout << typeid(T).name() << std::endl;x 20;cout << x; } 这种情况下&#xff0c;T永远不会被推导成带顶层const或引用的类型 【顶层const即变量本身不能…...

【算法】随机快速排序和随机选择算法

文章目录 1、随机快速排序1.1 什么是随机快排1.2 随机快排的好处 2、随机选择算法 前言&#xff1a; 快速排序就是每次划分前&#xff0c;通过一种方法将一个基准值的位置确定好&#xff0c;再进入不同的部分重复相同的工作以此确定好每个值的位置以达到有序。如果你之前并不了…...

si551x时钟芯片linux下调试总结

目录 前言一、依赖文档、工具二、让芯片工作的流程三、以上步骤的SOC下代码实现 前言 本文总结调试SKYWORKS芯片厂商Si5512时钟芯片时的笔记&#xff0c;基于linux5.10.xxx内核&#xff0c;在arm64架构的SOC上验证&#xff1b; 一、依赖文档、工具 文档名说明下载链接Si5518…...

5.6-DAE实现

解决问题&#xff1a; 随机缺失​​&#xff08;实验室指标未检测&#xff09;​​系统性噪声​​&#xff08;设备测量误差&#xff09;​​类别不平衡​​&#xff08;健康/患病人群比例悬殊&#xff09; 思路&#xff1a;引入可控噪声 → 重建原始数据 实现步骤 ​​(1)…...

MCU怎么运行深度学习模型

Gitee仓库 git clone https://gitee.com/banana-peel-x/freedom-learn.git项目场景&#xff1a; 解决面试时遗留的问题&#xff0c;面试官提了两个问题&#xff1a;1.单片机能跑深度学习的模型吗&#xff1f; 2.为什么FreeRTOS要采用SVC去触发第一个任务&#xff0c;只用Pend…...

背单词软件开发英语app开发,超级单词表开发,河南数匠软件开发

在数字化教育浪潮席卷全球的当下&#xff0c;英语教育行业面临着教学模式创新与教学效率提升的双重挑战。如何借助技术力量&#xff0c;为学生提供更优质、更高效的英语学习体验&#xff0c;成为众多英语教育机构亟待解决的问题。河南数匠软件开发有限公司&#xff0c;作为专注…...

AI视觉质检的落地困境与突破路径

摘要 人工智能&#xff08;AI&#xff09;视觉质检技术凭借其在提升效率、降低成本和优化质量控制方面的巨大潜力&#xff0c;正成为现代制造业转型升级的关键驱动力。然而&#xff0c;尽管前景广阔&#xff0c;AI视觉质检在实际落地过程中仍面临诸多严峻挑战&#xff0c;主要…...

检测内存条好坏有工具,推荐几款内存检测工具

检测内存条的好坏其实很重要&#xff0c;这直接就关系到计算机是不是能够稳定的运行&#xff0c;也有一部分人就会关注内存检测的工具。你应该如何来选择的&#xff0c;不如看一下以下的这几个。 MemTest86是一个比较受到大家喜欢的内存检测工具&#xff0c;会支持各种类型&…...

认识tomcat(了解)

启动 1. windows版本 解压后&#xff0c;就能用&#xff0c;启动&#xff0c;是bin路径下的startup.bat , 关闭是ctrl C . 启动后&#xff0c;可以访问 http://127.0.0.1:8080。为什么是8080&#xff0c;因为如下这个配置文件 部署 将项目放置到webapps目录下&#xff0c;即…...

[20250507] AI边缘计算开发板行业调研报告 ​​(2024年最新版)​

[20250507] AI边缘计算开发板行业调研报告 ​​(2024年最新版&#xff09;​ 一、行业背景​​ 随着物联网设备激增与AI模型轻量化&#xff0c;边缘计算成为AI落地核心场景。AI边缘计算开发板&#xff08;Edge AI Board&#xff09;作为硬件载体&#xff0c;需满足​​低延迟…...

前端实现文件下载

目录 1.说明 2.示例--excel 3.示例--csv 1.说明 在开发中经常会出现下载csv或者excel文件&#xff0c;可以通过后端下载&#xff0c;也可以通过前端下载&#xff0c;如果在前端页面中可以直接获取到要下载的数据&#xff0c;可以通过前端下载的方式&#xff0c;更加高效便捷…...

深入理解Redis缓存与数据库不一致问题及其解决方案

什么是Redis缓存数据与数据库不一致 在现代应用中&#xff0c;Redis作为一种高速缓存系统&#xff0c;被广泛用于提升系统性能。Redis缓存数据与数据库不一致&#xff0c;指的是缓存中的数据与数据库中的数据不匹配&#xff0c;导致读取缓存时得到的不是最新或正确的数据。 R…...

六级阅读———2024.12卷一 仔细阅读2

文章 An awakening has been taking place in the physical world against the beauty model that has been dictated to us for years.But in the digital arena,social media determines what is considered beautiful.(51) The two opposing struggles are taking place i…...

【Python】字符串 转为 JSON 格式的注意事项

1. 字符串转json 我们如果使用sql存储json格式&#xff0c;要将json转为字符串才能转。 存入sql前&#xff0c;字典格式转json字符串可以用这个&#xff1a; Table_ [{"id": 1,"name": "Alice","task": 25,"work": &quo…...

镜像和容器的管理

一、镜像的管理 获取镜像并生成相关容器 # 拉取镜像 docker pull alpine # 默认是latest&#xff0c;也就是最新版本&#xff0c;也可指定版本&#xff08;在镜像名后边加“:版本号”&#xff09; # 或者 # 从主机中导入镜像到docker中 docker image load -i /test#生成容器 …...

Scrapy框架之Scrapyd部署及Gerapy分布式爬虫管理框架的使用

Scrapyd Scrapyd 是一个用于部署和运行 Scrapy 爬虫的服务器。 1.安装 Scrapyd服务端&#xff1a;pip install scrapyd Scrapyd客户端&#xff1a;pip install scrapyd-client 运行scrapyd 浏览器输入http://127.0.0.1:6800/ 2.配置 安装完成后&#xff0c;需要对 Scra…...

【uniapp】errMsg: “navigateTo:fail timeout“

项目场景&#xff1a; 在点击编辑的时候不能跳转的编辑的页面&#xff0c;然后直接报错errMsg: "navigateTo:fail timeout" 解决方案&#xff1a; 看看是否是出现了盒子的冒泡事件导致了两次调用跳转路径 tap.stop...

亿级流量系统架构设计与实战(五)

高并发写场景方案 1 : 数据分片之数据库分库分表 数据分片思想:可以将资源拆开分为多份,拆分的多份小的资源一起构成完整资源。 分库和分表 分库: 分库指的是将数据库拆分为多个小数据库,原来存储在单个数据库中的数据被分开存储到各个小数据库中。 分表:分表指的是将…...

机器学习——逻辑回归ROC练习

一、 题目要求&#xff1a; 给定以下二分类模型的预测结果&#xff0c;手动绘制ROC曲线并计算AUC值&#xff1a; y_true [0, 1, 0, 1, 0, 1] # 真实标签&#xff08;0负类&#xff0c;1正类&#xff09; y_score [0.2, 0.7, 0.3, 0.6, 0.1, 0.8] # 模型预测得分 代码展示…...

Kubernetes学习笔记

云计算三层模型 IaaS&#xff08;基础设施即服务&#xff09;&#xff1a;提供虚拟化计算资源&#xff08;如虚拟机、存储、网络&#xff09;。 PaaS&#xff08;平台即服务&#xff09;&#xff1a;提供应用开发和部署环境&#xff08;如数据库、中间件、运行时&#xff09;。…...

【DB2】DB2启动失败报错SQL1042C

在本地某次启动db2时报错SQL1042C&#xff0c;具体报错如下 [db2inst1standby ~]$ db2start 05/07/2025 16:32:53 0 0 SQL1042C An unexpected system error occurred. SQL1032N No start database manager command was issued. SQLSTATE57019在网上百度到说是需要…...

Redis相关命令详解与原理

Redis是什么&#xff1f; Redis 是Remote Dictionary Server(Redis) 的缩写&#xff0c;是一个使用 C语言编写、遵守BSD协议、支持网络、可基于内存亦可持久化的日志型的Key-Value数据库&#xff0c;并提供多种语言的API。 它是一种 NoSQL&#xff08;not-only sql&#xff0c;…...

[吾爱出品][Windows] 产品销售管理系统2.0

[Windows] 产品销售管理系统 链接&#xff1a;https://pan.xunlei.com/s/VOPej1bHMRCHy2np9w3TBOyKA1?pwdgjy7# 使用方法&#xff1a;1、先设置一下图片保存路径 2、维护产品。客户等基础信息。例如&#xff1a;销售类型&#xff1a;一次性 销售编码&#xff1a;RCX。 3、销…...

基于OpenTelemetry的分布式链路追踪Trace‌实现(PHP篇)

目录 引言一、OpenTelemetry是一套可观测性标准协议二、分布式追踪&#xff08;‌Trace‌&#xff09;是OpenTelemetry的核心功能之一三、OpenTelemetry的架构原理四、OpenTelemetry的分布式追踪&#xff08;‌Trace‌&#xff09;实践1、准备PHP环境2、下载SDK3、编写实例代码…...

电气工程中漏源电压Vds的平台电压是什么?

在MOSFET&#xff08;金属 - 氧化物 - 半导体场效应晶体管&#xff09;中&#xff0c;漏源电压 VDS 的平台电压是其输出特性曲线中的一个关键概念。 定义 在MOSFET的输出特性曲线里&#xff0c;当器件工作于饱和区时&#xff0c;漏源电流ID对漏源电压VDS​的变化不太敏感&…...

第35周Zookkeeper+Dubbo Dubbo

Dubbo 详解 一、Dubbo 是什么 官网与定义 Dubbo 是一款高性能、轻量级的开源服务框架&#xff0c;其官网为 double.apache.org&#xff0c;提供中文版本&#xff08;网址含 “zh”&#xff09;。 核心能力 Dubbo 具备六大核心能力&#xff1a; 面向接口代理的高性能 RPC …...

allegro出gerber时,单击Artwork并没有弹窗的问题

使用allegro出gerber时&#xff0c;有时点击 Artwork图标并未如愿以偿的弹出窗口。。。 可按下面尝试恢复&#xff0c;注&#xff0c;删除前可先备份该两支文件。。。 看时间戳&#xff0c;删除最近的下面标红两支文件即可。...

【神经网络与深度学习】VAE 中的先验分布指的是什么

VAE 中的先验分布是什么&#xff1f; 在 变分自编码器&#xff08;VAE&#xff09; 中&#xff0c;先验分布指的是对潜在空间中随机变量的概率分布假设。通常情况下&#xff0c;VAE 设定潜在变量服从 标准正态分布 ( N(0, I) )&#xff0c;其中 ( 0 ) 代表均值为零的向量&…...

信息革命对经济、货币体系及权力结构的颠覆性影响

一、地理束缚的瓦解与权力转移 生产要素去实体化 思想、知识与数据取代实物资产成为核心价值来源&#xff0c;光速传播特性使经济活动突破物理边界。跨境远程医疗、跨国虚拟企业等新形态挑战传统管辖权概念&#xff0c;政府难以通过地域垄断攫取超额收益。 管辖权竞争白热化 …...

leetcode文件级全局变量会在测试用例之间相互影响

背景&#xff1a;在做Leetcode 743使用文件级全局变量idx&#xff0c;不同用例之间idx一直在。参考leetcode的文档&#xff1a; 解决办法&#xff1a;我选择在核心函数的开头&#xff0c;加入初始化代码&#xff08;每次用例调用都会重新初始化至原始状态&#xff09;...

如何查看电脑显卡配置参数 一文读懂

显卡是电脑的重要硬件之一&#xff0c;尤其对于游戏玩家、设计师、视频编辑等用户来说&#xff0c;显卡的性能直接影响电脑的使用体验。如果您想知道电脑的显卡信息&#xff0c;或者打算升级显卡&#xff0c;那么了解如何查看显卡配置是非常必要的。本文将为您提供多种简单实用…...

获取嵌入(Embeddings)的方法与实践

获取嵌入(Embeddings)的方法与实践 摘要 本文详细介绍了获取嵌入(Embeddings)的多种方法&#xff0c;包括降维技术和神经网络训练方法。通过具体的实例和可视化展示&#xff0c;我们将了解如何将高维数据转换为有意义的低维表示&#xff0c;以及如何根据具体任务需求选择合适…...

【国产化】在银河麒麟ARM环境下离线安装docker

1、前言 采用离线安装的方式。 关于离线安装的方式官网有介绍&#xff0c;但是说的很简单&#xff0c;网址&#xff1a;Binaries | Docker Docs 官网介绍的有几种主流linux系统的安装方式&#xff0c;但是没有kylin的&#xff0c;所以在此记录一下。 在安装过程中也遇到了些…...

基于大模型的子宫平滑肌瘤全周期预测与诊疗方案研究

目录 一、引言 1.1 研究背景与意义 1.2 研究目的与创新点 二、大模型技术原理与应用现状 2.1 大模型概述 2.2 相关技术原理 2.3 医疗领域应用现状 三、子宫平滑肌瘤术前预测 3.1 预测指标与数据收集 3.2 大模型预测模型构建 3.3 预测结果分析与应用 四、子宫平滑肌…...

SpringBoot 集成 Ehcache 实现本地缓存

SpringBoot 集成 Ehcache 实现本地缓存_springboot ehcache-CSDN博客...

linux下MySql的安装与配置

一键三联&#xff0c;把mysql的安装与配置也写了&#xff0c;供各位参考。 --------------------------------------MySql的安装与配置-------------------------------------- 1 将下载的 压缩包解压到指定目录 tar -zxvf mysql-5.7.26-linux-glibc2.12-x86_64.tar.gz 卸载…...

普通IT的股票交易成长史--20250507晚复盘

声明&#xff1a;本文章的内容只是自己学习的总结&#xff0c;不构成投资建议。价格行为理论学习可参考简介中的几位&#xff0c;感谢他们的无私奉献。 送给自己的话&#xff1a; 仓位就是生命&#xff0c;绝对不能满仓&#xff01;&#xff01;&#xff01;&#xff01;&…...