使用multi可以开启redis事务,exec提交事务,discard取消事务(redis官方并没有提供回滚的方法,只提供了取消事务的方法)。
取消事务和回滚的区别?
Mysql中开启了事务,对该行数据上行锁---
Commit 数据可以提交
回滚:对事务取消和行锁都会撤销
Redis没有回滚 单纯取消事务(不提交事务) 不上锁
演示multi工作流程
1.启动两个redis客户端A,B(事务在A客户端中,B只查询)
A:开始multi事务之后,进行set 测试,redis并没有返回成功数据条数,而是返回了一个队列,这表明了在开启了multi事务之后,数据并没有真实的保存到redis中而是放到了一个缓存队列中
B:此时我们使用B客户端进行查询为null
如果A提交事务(exec),之后B 便可以查询到数据
如果A取消事务(discard),之后B查询不到数据
存在的问题:
A 开启事务,同时set了一个key(name),B在A未提交的之前也对改key(name)进行了操作,那么A的事务依旧可以提交
在redis中还提供另一种机制watch, 可以监听一个或者多个key,在提交事务之前是否有发生了变化 如果发生边了变化就不会提交事务,没有发生变化才可以提交事务
代码演示:
客户端A 监听name字段,同时开启事务,set name 2222
此时在B客户端中对name进行修改 set name 3333
提交A的事务exec,并没有返回成功,同时查询get name返回的是B set的3333的值