Redis的事务

注:Redis没有回滚(所以需要配合 watch 一起使用)

Redis的事务:一次事务操作,改成功的成功,该失败的失败。

先开启事务,执行一些列的命令,但是命令不会立即执行,会被放在一个队列中,如果你执行事务,那么这个队列中的命令全部执行,如果取消了事务,一个队列中的命令全部作废。

  • 开启事务:multi

  • 输入要执行的命令:被放入到一个队列中

  • 执行事务:exec

  • 取消事务:discard

Redis的事务想发挥功能,需要配置watch监听机制

在开启事务之前,先通过watch命令去监听一个或多个key,在开启事务之后,如果有其他客户端修改了我监听的key,事务会自动取消。

例:

1)我的客户端开起监听m:

 

2)其它客户端修改了m

 

3)我的客户端监听到到m被其他客户端修改了所以我的客户端再去修改m会修改失败

4)最后获取到的m key 的值是被其它客户端修改后的值,也就是为2

 

如果执行了事务,或者取消了事务,watch监听自动消除,一般不需要手动执行unwatch。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值