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 免费一键快速抠图,支持下载高清图片
相关推荐
Devin~Y1 小时前
大厂Java面试:Spring Boot + Redis/Kafka + Spring Cloud + JVM + RAG/向量检索(小Y翻车实录)寻道模式1 小时前
【开发心得】给私有部署OpenClaw添加PDF阅读技能2401_846339561 小时前
mysql如何确保主从数据完全同步_开启半同步复制机制Aray12341 小时前
向量数据库核心解析及ChromaDB实操指南流年viv1 小时前
投稿_电价预测优化实践zxrhhm1 小时前
PostgreSQL 分页性能优化 FETCH WITH TIES 与传统 LIMIT/OFFSET 的对比m0_741481781 小时前
mysql如何设置定时自动备份脚本_编写shell脚本与cron任务m0_631529821 小时前
如何用 cache 参数控制 Fetch 是否读取浏览器自带的缓存HalvmånEver1 小时前
MySQL事务(二)