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 免费一键快速抠图,支持下载高清图片
相关推荐
2301_817672262 小时前
SQL中RIGHT JOIN真的很少用吗_数据完整性检查与反向关联分析2501_914245932 小时前
mysql如何进行表空间传输恢复_mysql transport tablespace实战qq_330037992 小时前
MongoDB的聚集索引怎么用_Clustered Collections的插入性能优化qq_334563552 小时前
html标签怎么表示用户输入_kbd标签键盘快捷键标注【介绍】.txt小陈工2 小时前
数据库Operator开发实战:以PostgreSQL为例weixin_586061462 小时前
SQL报表星型模型优化_事实表索引设计耿雨飞2 小时前
Python 后端开发技术博客专栏 | 第 07 篇 元类与类的创建过程 -- Python 最深层的魔法慕涯AI2 小时前
Agent 30 课程开发指南 - 第21课源码之家2 小时前
计算机毕业设计:Python城市天气数据挖掘与预测系统 Flask框架 随机森林 K-Means 可视化 数据分析 大数据 机器学习 深度学习(建议收藏)✅