必须手动配置asyncio+redis-py连接池,否则同步调用会阻塞事件循环;应使用redis.asyncio.Redis配合显式创建的ConnectionPool,避免混用同步/异步客户端,高频任务需用pipeline批量处理,消费者推荐brpoplpush实现可靠消费,并为每个consumer task添加异常捕获与重连逻辑。asyncio + redis-py 连接池必须手动配置,否则会阻塞事件循环默认的 redis.Redis() 实例是同步阻塞的,哪怕你在 async def 函数里调用 get() 或 lpush(),也会让整个 event loop 卡住。这不是 asyncio 不支持 Redis,而是 redis-py 默认没走异步路径。实操建议:立即学习"Python免费学习笔记(深入)";用 aioredis(v2.x)或 redis-py v4.2+ 的 Redis.from_url(..., decode_responses=True) 配合 connection_class=redis.asyncio.Connection连接池要显式创建:pool = redis.asyncio.ConnectionPool.from_url("redis://localhost"),再传给 Redis(connection_pool=pool)别在协程里混用 redis.Redis() 和 redis.asyncio.Redis(),类型不兼容,await 会直接报 TypeError: object XX can't be used in 'await' expression任务入队不能直接 await lpush,得用 pipeline 或 batch 提升吞吐高频发任务时,逐条 await redis.lpush("queue:tasks", payload) 会产生大量网络往返,延迟飙升,实际 QPS 可能不到 200。这不是 Redis 慢,是单命令 round-trip 拖垮了 asyncio 的并发优势。实操建议:立即学习"Python免费学习笔记(深入)";用 pipeline 批量入队:async with redis.pipeline() as pipe: pipe.lpush("queue:tasks", *payloads); await pipe.execute()如果任务来自 HTTP 请求体,优先在业务层做简单合并(比如每 10 条攒一次),而不是无脑单条 push注意 pipeline.execute() 是原子的,但失败时整个 batch 回滚,需按需加重试逻辑消费者用 brpoplpush 实现"带确认"的可靠消费纯 lpop 拿到任务后如果 worker 崩溃,任务就丢了;用 rpoplpush 中转到 processing 列表再处理完删,又得手动维护状态。更稳的做法是用 brpoplpush ------ 它能阻塞等待、自动转移、还能设超时。 Mokker AI AI产品图添加背景
相关推荐
hboot40 分钟前
AI工程师第三课 - 机器学习基础顾林海5 小时前
Agent入门阶段-编程基础-Python:流程控制呱呱复呱呱8 小时前
Django CBV 源码解读:一个请求是怎么找到你的 get() 方法的Nturmoils9 小时前
订单列表慢查询,先看 WHERE、ORDER BY 和 LIMIT曲幽13 小时前
刚部署的 LibreTranslate 频频翻车?我掏出了 20 年前的 StarDict 词典,用 FastAPI 搭了个本地词典翻译 API渣波13 小时前
拒绝 SQL 焦虑!手把手带你用 NestJS + Prisma + DTO 写出“防弹”级后端代码荣码13 小时前
用Streamlit给AI应用套个界面,10行代码出Web页面兵慌码乱1 天前
基于Python+PyQt5+SQLite的药房管理系统实现:事务一致性与界面解耦全流程解析金銀銅鐵1 天前
[Python] 体验用欧几里得算法计算最大公约数的过程FreakStudio1 天前
W55MH32L-EVB 上手测评:硬件 TCP/IP 加持的以太网单片机,MicroPython 零门槛开发