EVAL并发高导致Redis CPU突增是因为其单线程执行Lua脚本,大量请求串行等待而非算力瓶颈;常见表现为CPU使用率高但延迟不明显、evicted_keys上升;根本原因包括全量KEYS扫描、未预热EVALSHA、大结果返回及纯计算循环。为什么 EVAL 并发高会导致 Redis CPU 突增Redis 是单线程执行 Lua 脚本的,EVAL 和 EVALSHA 都会阻塞主线程直到脚本跑完。哪怕脚本只耗时几毫秒,100 个并发进来,就等于排队等 100 × 几毫秒------CPU 不是被算力压垮的,是被「串行等待」拖满的。常见现象:INFO cpu 里 used_cpu_sys 或 used_cpu_user 持续 >80%,但 redis-cli --latency 显示延迟不高;监控看到 instantaneous_ops_per_sec 没爆,但 evicted_keys 或 expired_keys 反而上升(说明其他命令在排队)。脚本里用了 for 循环遍历大集合(比如 redis.call('KEYS', 'user:*'))------这比单纯多请求更伤用 EVAL 发送重复脚本(没预热 EVALSHA),每次都要重解析,额外消耗 CPU脚本返回超大结果(如 return redis.call('LRANGE', 'list:100k', 0, -1)),序列化+网络拷贝也占 CPU怎样让 EVALSHA 真正生效,而不是假装优化EVALSHA 本身不省计算,只省解析。但很多人漏掉关键两步:预加载 + 容错 fallback,结果线上还是走 EVAL 白忙活。启动时用 SCRIPT LOAD 提前加载脚本,拿到 sha1 值缓存到应用层(别每次运行时现场 SCRIPT LOAD)调用 EVALSHA 后必须检查返回是否为 NOAUTH 或 NOSCRIPT 错误,遇到就自动 fallback 到 EVAL 并重新 SCRIPT LOAD集群模式下,SCRIPT LOAD 必须发到对应 slot 的节点,不能随便连一个 proxy 就 load ------ 否则其他节点根本没这个 sha1示例伪代码:sha = cache.get("my_script_sha")<br>if not sha:<br> sha = redis.eval("SCRIPT LOAD", script_content)<br> cache.set("my_script_sha", sha)<br>res = redis.eval("EVALSHA", sha, keys, args)<br>if res == "NOSCRIPT":<br> # 重试逻辑,不是直接 panic</br> sha = redis.eval("SCRIPT LOAD", script_content)<br> res = redis.eval("EVALSHA", sha, keys, args)哪些 Lua 操作最该砍掉,优先级最高不是所有脚本都适合留在 Redis 里。以下三类操作,CPU 开销和风险远大于收益,应第一时间移出: 通义听悟 阿里云通义听悟是聚焦音视频内容的工作学习AI助手,依托大模型,帮助用户记录、整理和分析音视频内容,体验用大模型做音视频笔记、整理会议记录。
相关推荐
这个DBA有点耶3 分钟前
云上运维新挑战:当数据库不再“看得见摸得着”程序大视界15 分钟前
【Python系列课程】Python正则表达式(下):环视、命名分组与日志实战TickDB25 分钟前
美股行情 API 接入避坑:REST 快照、WebSocket 推送、盘前盘后数据的边界枫叶v.1 小时前
Agent 分层存储架构设计:从记忆方法到中间件选型水兵没月1 小时前
逆向实战小记——某ToB商城网站分析学习AskHarries1 小时前
系统提示词、开发者指令和用户输入的优先级程序员小远1 小时前
Python自动化测试框架及工具详解消失在人海中1 小时前
oracle 数据库多表关联查询九皇叔叔1 小时前
PostgreSQL/openGauss pg_stats 视图从入门到精通:统计信息、执行计划与慢 SQL 优化实战gsls2008082 小时前
JVM 堆内存参数 & Docker 容器适配,一次讲清楚