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]>