9.redis事务

tech2024-06-13  78

Redis的事务

Redis事务的介绍

一次执行多个命令,同时将事务中的命令序列化,按照顺序依次执行,执行过程中不会插入加塞其它命令

Redis事务的介绍特性

单独的隔离操作:事务中的所有命令都会序列化,按顺序的执行。事务在等待执行的时候,不会被其他客户端发送来的米命令请求打断Redis事务没有隔离级别的概念:队列中的所有命令没有提交exec之前都是不会被执行的Redis不保证原子性:redis中如果一条命令执行失败,其后的命令仍然会被执行,没有回滚

Redis事务的三个阶段:

开启事务:以multi开启事务命令入队:将多个命令入队到事务中,接到这些命令不会立刻执行,而是放到等待执行的事务队列里面执行事务:有exec命令触发事务

常用命令

命令描述multi标记一个事务的开始exec执行所有事务块内的命令 ( 一旦执行exec后,之前加的监控锁都会被取消掉 )discard取消事务,放弃执行事务块内的所有命令 ( 一旦执行discard后,之前加的监控锁都会被取消掉 )watch key [key]监视一或多个key,如果在事务执行之前,被监视的key被其他命令改动,则事务被打断 ( 类似乐观锁 )unwatch取消watch命令对所有 key 的监视。

测试练习

正常执行(成功新增key,递增key) 127.0.0.1:6379[3]> multi OK 127.0.0.1:6379[3]> set b 2 QUEUED 127.0.0.1:6379[3]> get b QUEUED 127.0.0.1:6379[3]> incr b QUEUED 127.0.0.1:6379[3]> get b QUEUED 127.0.0.1:6379[3]> exec 1) OK 2) "2" 3) (integer) 3 4) "3" 127.0.0.1:6379[3]> 放弃事务 (没有新增key,和获取key值) 127.0.0.1:6379[3]> multi OK 127.0.0.1:6379[3]> set age 1 QUEUED 127.0.0.1:6379[3]> get age QUEUED 127.0.0.1:6379[3]> discard OK 127.0.0.1:6379[3]> keys * 1) "a" 2) "b" 127.0.0.1:6379[3]> 事务打断放弃全部操作 (监听一个KEY,开启事务,在事务外部修改KEY,再提交执行事务) 127.0.0.1:6379[3]> watch b OK 127.0.0.1:6379[3]> multi OK 127.0.0.1:6379[3]> incr a QUEUED 127.0.0.1:6379[3]> incr b QUEUED 127.0.0.1:6379[3]> exec (error) EXECABORT Transaction discarded because of previous errors. 127.0.0.1:6379[3]> mget a b 1) "1" 2) "1" 127.0.0.1:6379[3]> 部分成功部分失败 (不保证原子性) 127.0.0.1:6379[3]> multi OK 127.0.0.1:6379[3]> set name username QUEUED 127.0.0.1:6379[3]> set sex 1 QUEUED 127.0.0.1:6379[3]> incr name QUEUED 127.0.0.1:6379[3]> exec 1) OK 2) OK 3) (error) ERR value is not an integer or out of range 127.0.0.1:6379[3]> mget name sex 1) "username" 2) "1" 127.0.0.1:6379[3]>
最新回复(0)