Redis_事务
Redis事务是可以一次执行多个命令,并且带有以下三个重要的保证:
1.批量操作在发送exec命令前被放入队列缓存。
2.收到EXEC命令后进入事务执行,事务中任意命令执行失败,其余的命令依然被执行。
3.在事务执行过程,其他客户端提交的命令请求不会插入到事务执行命令序列中。
一个事务从开始到执行经历以下三个阶段:
1.开始事务
2.命令入队
3.执行事务
实例
以下是一个事务的例子,multi是开启事务的命令,然后把多个要执行的命令入队到事务中,ecex命令是触发事务,一并执行事务中的所有命令。
单个redis命令的执行是原子性的(原子性就是并发操作要么一起成功提交,一个失败就所有操作失败回滚)。但Redis在事务中没有任何维持原子性的机制,所以Redis事务的执行并不是原子性的
事务可以理解为一个打包的批量执行脚本,但批量指令并非原子化的操作,中间某条指令的失败不会导致前面已做指令的回滚,也不会造成后续的指令不做。
Redis事务命令