Redis中的事务(transaction)是一组命令的集合。一个事务中的命令要么全部执行,要么都不执行。Redis的事务没有关系数据库事务提供的回滚(rollback)功能。
Redis通过MULTI
标记一个事务块的开始。事务块内的多条命令会按照先后顺序被放进一个队列(queued)当中,最后由EXEC
命令原子性(atomic)地执行。
Redis保证一个事务中的所有命令要么都执行,要么都不执行。如果EXEC
命令之前出现错误,则Redis会清空事务队列,事务中的所有命令都不执行。
此外,Redis的事务还能保证一个事务内的命令依次执行而不被其他命令插入。
multi # 开启事务 set name kang # 使命令进入等待执行的事务队列中 set age 18 # 使命令进入等待执行的事务队列中 exec # 按顺序执行事务块内所有的命令
Redis2.6.5之前的版本会忽略有语法错误的命令,然后执行事务中其它语法正确的命令。就之后版本而言,只要有一个命令有语法错误,执行EXEC
命令后,Redis就会直接返回错误,不执行任何命令。
示例如下:
multi set key name kang key * # 语法错误,返回值:(error) ERR unknown command `key`, with args beginning with: `*`, exec # 返回值:(error) EXECABORT Transaction discarded because of previous errors.
运行错误指的是在命令执行中出现的错误,如果Redis中出现了运行错误,事务中其它正确的命令会继续执行。
示例如下:
multi set name kang sadd name kang set age 18 exec # 返回值: # 1) OK # 2) (error) WRONGTYPE Operation against a key holding the wrong kind of value # 3) OK
WATCH
命令用于监视一个或多个键 ,如果在事务执行之前监视的键被其他命令修改,那么事务将被打断。
set name kang watch name set name Kang multi set name kang exec # 返回值:(nil) get name # 返回值:"Kang"