redis的Lua脚本事务注意

虽然lua脚本的执行具有原子性,但是如果一个脚本存在错误,那么可能不会回滚。因为redis中的事务和我们理解的数据库中的事务不太一样。

redis事务中的错误

在事务期间可能会遇到两种命令错误:

  • (1)命令可能无法排队,因此在调用EXEC之前可能会出现错误。例如,命令可能在语法上是错误的(参数数量错误,命令名称错误,...),或者可能存在一些关键情况,例如内存不足情况(如果服务器被配置为使用maxmemory指令具有内存限制))。
  • (2)调用EXEC后, 命令可能会失败,例如,因为我们对具有错误值的键执行了操作(例如对字符串值调用列表操作)

第一种错误显然整个事务不会执行,因为语法出现了错误。

第二种错误是,语法没错,但是命令有问题,比如你要set一个不存在的key。这种,同一个脚本中的错误的命令不会执行,但是其他正确脚本会继续执行。所以使用Lua脚本,必须保证语句语法和命令都是对的,否则可能达不到预期(要么全执行,要么全不执行)

posted @ 2021-09-15 10:15  jiafeng  阅读(1100)  评论(0编辑  收藏  举报