【Redis】事务

数据库事务

定义:在一次跟数据库连接会话当中,所有的执行sql,要么一起成功,要么一起失败。经典案例:转账

Redis事务

官网:https://redis.io/docs/manual/transactions/

  • 定义:

    可以一次执行多个命令,本质是一组命令的集合。个事务中的所有命令都会序列化,按顺序地串行化执行而不会被其它命令插入,不许加塞

  • 作用

    一个队列中,一次性、顺序性、排他性的执行一系列命令

Redis事务VS 数据库事务

1 单独的隔离操作Redis的事务仅仅是保证事务里的操作会被连续独占的执行,redis命令执行是单线程架构,在执行完事务内所有指令前是不可能再去同时执行其他客户端的请求的
2 没有隔离级别的概念因为事务提交前任何指令都不会被实际执行,也就不存在”事务内的查询要看到事务里的更新,在事务外查询不能看到”这种问题了
3不保证原子性Redis的事务不保证原子性,也就是不保证所有指令同时成功或同时失败,只有决定是否开始执行全部指令的能力,没有执行到一半进行回滚的能力
4 排它性Redis会保证一个事务内的命令依次执行,而不会被其它命令插入

常用命令

案例:正常执行 MULTI->EXEC

案例:放弃事务 MULTI->DISCARD

案例:全体连坐(语法错误:原子性)

语法错误会打断事务,使得之前的任务全失败

案例:冤头债主(逻辑错误:不保证一起成功,一起失败)

Redis不提供事务回滚的功能,开发者必须在事务执行出错后,自行恢复数据库状态

注意和传统数据库事务区别,不一定要么一起成功要么一起失败

案例:watch监控

Redis使用Watch来提供乐观锁定,类似于CAS(Check-and-Set)

  • 悲观锁(Pessimistic Lock), 顾名思义,就是很悲观,每次去拿数据的时候都认为别人会修改,所以每次在拿数据的时候都会上锁,这样别人想拿这个数据就会block直到它拿到锁。

  • 乐观锁(Optimistic Lock), 顾名思义,就是很乐观,每次去拿数据的时候都认为别人不会修改,所以不会上锁,但是在更新的时候会判断一下在此期间别人有没有去更新这个数据。

    乐观锁策略:提交版本必须大于记录当前版本才能执行更新

案例

  • 正常情况

    初始化k1和balance两个key,先监控再开启multi保证两key变动在同一个事务内

  • 加塞情况

    watch命令是一种乐观锁的实现,Redis在修改的时候会检测数据是否被更改,如果更改了,则执行失败,相当于连坐->整个事务全体失败

  • 放弃监控unwach

  • 11
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 11
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Al6n Lee

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值