Redis事务基本操作,以及乐观锁

从输入Multi命令开始,输入的命令都会依次进入命令队列中,但不会执行,直到输入Exec后,Redis会将之前的命令队列中的命令依次执行。组队的过程中可以通过discard来放弃组队。

127.0.0.1:6379> multi##队列开始
OK
127.0.0.1:6379> flushdb
QUEUED
127.0.0.1:6379> set k1 v1
QUEUED
127.0.0.1:6379> exec##执行队列
1) OK
2) OK
127.0.0.1:6379> multi
OK
127.0.0.1:6379> set k1 v1
QUEUED
127.0.0.1:6379> get k1
QUEUED
127.0.0.1:6379> discard##放弃队列
OK
127.0.0.1:6379>

错误处理:

组队中某个命令出现了报告错误,执行时整个的所有队列都会被取消。

如果组队过程没有出现错误,执行阶段某个命令报出了错误,则只有报错的命令不会被执行,而其他的命令都会执行,不会回滚

乐观锁

  1. 第一步:插入一个数据,并watch(监视version),进行incrby操作(更改数值,并修改自动versio)
###################客户端1#############################
127.0.0.1:6379> set k1 100
OK
127.0.0.1:6379> watch k1
OK
127.0.0.1:6379> multi
OK
127.0.0.1:6379> incrby k1 10
QUEUED
  1. 第二部:在第二个客户端,对同样的数据进行同样的操作
###################客户端2#############################
127.0.0.1:6379> watch k1
OK
127.0.0.1:6379> multi
OK
127.0.0.1:6379> incrby k1 20
QUEUED
  1. 第三步在客户端1进行exec,数值被成功更改
127.0.0.1:6379> set k1 100
OK
127.0.0.1:6379> watch k1
OK
127.0.0.1:6379> multi
OK
127.0.0.1:6379> incrby k1 10
QUEUED
127.0.0.1:6379> exec
1) (integer) 110
127.0.0.1:6379>
  1. 第四步在客户端2进行exec,数值无法更改,由于version被改变,导致更新失败
127.0.0.1:6379> watch k1
OK
127.0.0.1:6379> multi
OK
127.0.0.1:6379> incrby k1 20
QUEUED
127.0.0.1:6379> exec
(nil)
127.0.0.1:6379>

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值