SCRIPT KILL 只能终止未执行写命令的脚本;一旦调用 redis.call('set') 等写操作,脚本变为 UNKILLABLE,因 Redis 为保障原子性禁止中途终止,否则可能导致数据不一致。SCRIPT KILL 为什么有时不生效?直接结论:SCRIPT KILL 只能终止「尚未执行任何写命令」的脚本;一旦脚本调用了 redis.call('set', ...)、redis.call('del', ...) 等修改数据的命令,它就变成 UNKILLABLE ------ 这不是 bug,是 Redis 为保障原子性做的硬性限制。现象:执行 SCRIPT KILL 后返回 (error) UNKILLABLE Sorry the script already executed write commands...原因:Redis 要求 Lua 脚本"全有或全无",中途杀掉可能留下半写状态(比如库存扣了一半、订单建了没发券),这比挂起更危险验证方法:用 redis-cli --stat 或监控 instantaneous_ops_per_sec,若持续为 0 且客户端卡住,大概率已进入不可杀状态死循环脚本卡住后,还能做什么?当 SCRIPT KILL 失效,你只剩两个真实可行的选项,没有中间路线:SHUTDOWN NOSAVE:最常用也最激进。它会立即终止 Redis 进程,且不触发 RDB/AOF 持久化,意味着上一次快照之后的所有写入全部丢失重启进程(非优雅):比如 kill -9 <pid>,效果等同于 SHUTDOWN NOSAVE,但绕过了 Redis 自身的清理逻辑,风险略高等待脚本自然结束?别信------只要循环里没 break 或超时检查,它就不会停;而 Redis 不会主动中断已写入的脚本怎么避免下次再被死循环拖垮?预防远比抢救重要。关键不是"怎么杀",而是"不让它活过 5 秒": 灵办AI 免费一键快速抠图,支持下载高清图片
相关推荐
czlczl200209254 小时前
理解 MySQL 行锁:两阶段锁协议与热点更新优化AllData公司负责人5 小时前
通过Postgresql同步到Doris,全视角演示AllData数据中台核心功能效果,涵盖:数据入湖仓,数据同步,数据处理,数据服务,BI可视化驾驶舱哆啦A梦15885 小时前
20, Springboot3+vue3实现前台轮播图和详情页的设计Flittly6 小时前
【LangGraph新手村系列】(5)时间旅行:浏览历史、分叉时间线与修改过去渣渣盟6 小时前
Mysql入门到精通全集(SQL99)包含关系运算,软考数据库工程师复习首选dishugj6 小时前
HANA 数据库的核心进程架构2301_782040456 小时前
CSS Flex布局中如何实现导航栏与Logo的左右分布_利用justify-content- space-between.柒宇.6 小时前
Redis主从复制集群搭建详解yaoxin5211236 小时前
400. Java 文件操作基础 - 使用 Buffered Stream I/O 读取文本文件2301_808414387 小时前
MySQL中的函数