Redis的事务及乐观锁扩展

Redis对事务的支持比较简单,它是一组命令的集合,命令被顺序的执行;Redis
也可以放弃事务的执行,此时所有事务里面的命令都不会执行。

Redis只能保证一个client发起的事务中的命令可以连续的执行,中间不会插入其
他client的命令,因为Redis是单线程架构,所以在执行完事务内所有指令前是不可能
再去同时执行其他客户端的请求的。

Redis的事务 没有隔离级别 的概念,因为事务提交前任何指令都不会被实际执
行,也就不存在“事务内的查询要看到事务里的更新,在事务外查询不能看到”这种问
题了。

Redis的事务 不保证原子性,也就是不保证所有指令同时成功或同时失败,只有
决定是否开始执行全部指令的能力,没有执行到一半进行回滚的能力。
Redis集群不支持事务操作 ;

Redis事务的相关命令

multi : 开启事务

exec : 执行事务

discard : 取消事务

watch : 监控键值

unwatch : 取消监控

Redis事务的基本过程
  1. 发送一个事务的命令multi给redis;
  2. 依次把要执行的命令发送给redis,redis接到这些命令,并不会立即执行,而是放到
    等待执行的事务队列里面;
  3. 发送执行事务的命令exec给redis;
  4. redis会保证一个事务内的命令依次执行,而不会被其它命令插入;
Redis事务过程中的错误处理

redis的事务非常简单,当然会存在一些问题。

redis只能保证事务的每个命令连续执行,但是如果事务中的一个命令失败了,并 不回滚其他命令,下面举例看错误处理;

1. 如果是某个命令执行错误(使用方式错了),那么其它的命令仍然会正常执行,然后在执行后返回错误信息;

在这里插入图片描述

2. 如果任何一个命令的语法有错,redis会直接返回错误,所有的命令都不会执行

在这里插入图片描述
**注意**: redis不提供事务回滚的功能,开发者必须在事务执行出错后,自行恢复数据库状态;

Redis事务扩展 - 乐观锁

Redis使用 watch 来提供乐观锁定;

exec 被调用后,所有的之前被监视的键会被取消监视,不管事务是否被取消
或执行。并且当客户端连接丢失的时候,所有键都会被取消监视。

乐观锁介绍

乐观锁大多是基于 数据版本(version) 的记录机制实现的。
什么是数据版本?

数据版本就是为数据增加一个版本标识version,更新数据时,对此版本号加 1,当线
程A要更新数据值时,在读取数据的同时也会读取version值,在提交更新时,若刚才读取
到的version值大于当前数据库中的version值时才更新,否则更新失败。

乐观锁举例

小明的账户有余额1000;
1、操作员A将小明的信息读出(此时 version=1),并准备从其帐户余额中扣除
100(1000-100); 剩余900

2、在操作员A操作的过程中,操作员B也读入小明的信息(此时 version=1),并准备
从其帐户余额中扣除500(1000-500); 剩余500

3、A完成了修改工作后,将数据版本号加 1(此时 version=2),帐户扣除后余额为 900,提交至数据库更新,此时由于提交数据版本大于数据库记录当前版本(2>1),
数据被更新,数据库记录 version 更新为 2;

4、在A完成更新操作之后,B也完成了操作,她也将版本号加 1(version=2)并试图
向数据库提交数据(此时小明的余额为500),但比对数据库记录版本时发现,B提
交的数据版本号为 2,数据库记录当前版本也为 2,不满足 提交版本必须大于记录当前 版本才能执行更新 的乐观锁策略,因此,B的提交被驳回;

Redis的乐观锁测试

在这里插入图片描述

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
悲观锁和乐观锁是在数据库操作中常见的两种并发控制机制,而Redis也提供了乐观锁的实现方式。 悲观锁是一种悲观的思想,每次在获取数据之前都会认为其他人会修改数据,所以在获取数据时就会上锁,其他人需要等待直到锁被释放才能获取数据。传统的关系型数据库中常用的行锁、表锁等都属于悲观锁的实现方式。悲观锁适用于对数据的强一致性要求较高的场景,但效率相对较低,特别是在读的并发较高的情况下。 乐观锁则是一种乐观的思想,认为在大多数情况下并发冲突是较少发生的,所以在读取数据时不会立即上锁。而是在更新数据时会先检查数据是否被其他人修改过,如果没有则更新成功,如果有则需要进行重试或者放弃操作。乐观锁适用于读多写少,并发冲突较少的场景。在Redis中,可以使用watch机制实现乐观锁。 总的来说,乐观锁适用于并发冲突较少的情况下,可以减少锁的开销,提高系统的吞吐量。而悲观锁适用于并发冲突较多的情况下,可以保证数据的强一致性。在Redis中,可以根据实际场景选择使用悲观锁还是乐观锁。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [大数据之Redis:悲观锁和乐观锁](https://blog.csdn.net/weixin_43597208/article/details/118465556)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* *3* [Redis中的乐观锁和悲观锁](https://blog.csdn.net/qq_39612954/article/details/107470999)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值