Redis 解决事务冲突之乐观锁和悲观锁
文章目录
- 一、Redis的事务冲突问题
- 二、悲观锁
- 三、乐观锁
- 四、乐观锁的使用
- 五、Redis 事务三特性
一、Redis的事务冲突问题
例子:
比如说,3个人有你的账户:你有10000元
一个人请求想给金额减 8000
一个人请求想给金额减 5000
一个人请求想给金额减 1000
二、悲观锁
悲观锁(Pessimistic Lock),顾名思义,就是很悲观,每次去拿数据的时候都认为别人会修改,所以每次在拿数据的时候都会上锁(上锁后不允许其他事务操作),这样别人想拿这个数据就会block直到它拿到锁。传统的关系型数据库里边就用到了很多这种锁机制,比如行锁,表锁等,读锁,写锁等,都是在做操作之前先上锁
缺点是效率低,只能串行操作
三、乐观锁
乐观锁(Optimistic Lock), 顾名思义,就是很乐观,每次去拿数据的时候都认为别人不会修改,所以不会上锁,所以所有人都可以拿到数据,但是在更新的时候会判断一下在此期间别人有没有去更新这个数据,可以使用版本号等机制。
读数据的时候畅通无阻,更新数据的时候需要匹配读出来的数据的版本号和数据库内数据的版本号,一致则可修改,修改后写回数据库;若更新数据时,和数据库内数据的版本号不一致,就不允许更新,需要读出新版本号的数据继续操作
乐观锁适用于多读的应用类型,这样可以提高吞吐量。Redis就是利用这种check-and-set机制实现事务的。
四、乐观锁的使用
在执行 multi 开启事务之前,先执行 watch key1 [key2],可以监视一个(或多个) key ,如果在事务执行之前这个(或这些) key 被其他命令所改动,那么事务将被打断
unwatch 取消 WATCH 命令对所有 key 的监视:如果在执行 WATCH 命令之后,EXEC 命令或DISCARD 命令先被执行了的话,那么就不需要再执行UNWATCH 了
watch监视功能通过乐观锁实现
两个终端都监视balance并开启事务
终端1对balance加10
终端1对balance加20
终端1 exec执行事务成功
终端2 exec执行事务失败
分析: 乐观锁导致终端2事务执行失败;2个终端都得到balance这个数据,都对它监视,第一个终端先加10,然后就更新了版本号了,第二个终端执行加20,判断读取出来的balance的版本号和数据库里balance版本号,发现不一样了,就不能执行操作了
五、Redis 事务三特性
单独的隔离操作:事务中的所有命令都会序列化、按顺序地执行。事务在执行的过程中,不会被其他客户端发送来的命令请求所打断
没有隔离级别的概念:开启事务后,没有exec提交之前命令只是存放在队列中,都不会实际被执行
不保证原子性:事务中如果有一条命令执行失败,其后的命令仍然会被执行,没有回滚(这点和MySQL的原子性不一样)
Redis 解决事务冲突之乐观锁和悲观锁相关推荐
- mysql悲观锁和乐观优缺点_乐观锁、悲观锁和MVCC各是什么?各自优缺点是什么?...
在数据库的实际使用过程中,我们常常会遇到不希望数据被同时写或者读的情景,例如秒杀场景下,两个请求同时读到系统还有库存1个,然后又先后把库存更新为0,这时候就会出现超卖的情况,这时候货物的实际库存和我们 ...
- Redis的事务和锁机制(乐观锁和悲观锁)
Redis学习笔记(四) 1,Redis事务的定义 2,Redis事务操作的三个基本命令 3,解决Redis中的事务冲突(乐观锁和悲观锁) 3.1,悲观锁 3.2,乐观锁 3.3,Redis中使用乐观 ...
- 乐观锁与悲观锁——解决并发问题
引言 在多用户环境中,在同一时间可能会有多个用户更新相同的记录,这会产生冲突.这就是著名的并发性问题. 典型的冲突有: 丢失更新:一个事务的更新覆盖了其它事务的更新结果,就是所谓的更新丢失.例如: ...
- Redis锁,悲观锁和乐观锁
乐观锁 开启事务前,设置对数据的监听(watch),EXEC时,如果发生数据发生过修改,作用于改数据的事务会自动取消(DISCARD),事务EXEC后,无论成败,监听会被移除 悲观锁 每次去拿数据的时 ...
- mysql乐观锁与事务_[数据库事务与锁]详解七: 深入理解乐观锁与悲观锁
注明: 本文转载自http://www.hollischuang.com/archives/934 在数据库的锁机制中介绍过,数据库管理系统(DBMS)中的并发控制的任务是确保在多个事务同时存取数据库 ...
- MySql事务4种隔离级别以及悲观锁和乐观锁
前言:在那鬼公司呆着发现自己居然把事务给搞明白了. 缘由:公司做的一个项目在进行首页内容显示的时候发现查询结果特别慢,有时候需要一到五分钟才能显示出结果.于是乎,我就顺着SQL语句查询慢的原因找了下去 ...
- 乐观锁 与 悲观锁 来解决数据库并发问题
乐观锁 与 悲观锁 来解决数据库并发问题 参考文章: (1)乐观锁 与 悲观锁 来解决数据库并发问题 (2)https://www.cnblogs.com/xudong-bupt/p/8614997. ...
- Redis有事务冲突吗
1.写在前面 最近在看尚硅谷的Redis视频,里面的老师说到了事务冲突,我寻思Redis是单线程的,而且事务还有隔离性,哪来的事务冲突,于是上网搜答案,结果清一色复制粘贴,最后在看官网文档后才想明白这 ...
- MySQL 乐观锁与悲观锁
悲观锁 悲观锁(Pessimistic Lock),顾名思义,就是很悲观,每次去拿数据的时候都认为别人会修改,所以每次在拿数据的时候都会上锁,这样别人想拿这个数据就会block直到它拿到锁. 悲观锁: ...
最新文章
- 读样章、写评语,即有机会获赠《编程大师访谈录》!
- Delphi的内存管理及内存泄露问题
- 成功解决AttributeError: module tensorflow.image has no attribute resize
- mfc调取摄像头显示并截图_前摄后录,让行车安全再次提升:70迈智能后视镜后摄像头体验...
- Spring Integration Framework简介
- vue-环境变量和模式
- 微信公众号php提交表单,PHP教程:使用YII2框架实现微信公众号中表单提交功能...
- Interrupted Exception异常可能没你想的那么简单!
- SFTP环境搭建及客户代码调用公共方法封装
- 三种Fibonacci数列第n项计算方法及其优劣分析
- 20190801每日一句
- 什么是 jsp,什么是Servlet?jsp 和Servlet 有什么区别?
- Podfile、Podfile.lock、Manifest.lock、Podspec
- Word参考文献交叉引用——连续多项引用
- 【ONNX】使用 C++ 调用 ONNX 格式的 PyTorch 深度学习模型进行预测(Windows, C++, PyTorch, ONNX, Visual Studio, OpenCV)
- 网站服务器的10G内存,10G网站空间
- prgrmz的作品集
- 华为服务体系:ITR流程体系详解
- Foxmail添加gmail账号
- 问答系统QA的评价指标MAP、MRR、Accuracy@N