Redis 事物、悲观、乐观锁 (详细)
1,概论
事物这东西相信大家都不陌生吧,在学习Spring,Mybatis等框架中,
只要是涉及到数据存储和修改的,都会有事物的存在,
废话就不多说了下面我们来简单的介绍下Redis事物以及锁。
2,Redis事物简介?
Redis 事务可以一次执行多个命令, 并且我们来了解几个重要的知识点:
- 开启事物后,一切命令都会放入队列当中,当执行EXEC以后才会挨个执行。
- 当执行EXEC命令后,如果队列中有命令出错,那么此队列中的全部命令将不会执行(这里有两种可能),后面会举例介绍。
- 当事物执行以后,其他客户端提交的命令请求不会插入到事务执行命令序列中。
事物执行的三个阶段:
- 开始事务。
- 命令入队。
- 执行事务。
3,Redis事物(Transaction)命令?
| DISCARD | 取消事务,放弃执行事务块内的所有命令。 |
| EXEC | 执行所有事务块内的命令。 |
| MULTI | 开启事物 |
| UNWATCH | 取消 WATCH 命令对所有 key 的监视。 |
| WATCH key | 监视一个(或多个) key ,如果在事务执行之前这个(或这些) key 被其他命令所改动,那么事务将被打断。 |
4,Redis事物使用?
下面我们来通过几个例子认识下
1.正常执行

2.放弃事物
放弃事物,队列里面的命令将不会执行。

3.全体连坐
一个命令出错,队列中的全部命令将不会执行。

4.冤头债主
这个例子跟上面的差不多,只不过这个例子是执行了以后再报错,他两不同的地方就是
上面是先知道错误,这个是执行后才知道错误了,举个例子吧,
比如 我要让我的Redis数据数值增一操作,我在控制台执行命令,INCR key 当事物还没执行的时候,
也就是说这个命令还在队列中,还没执行,它是不知道我这个key到底是个数值还是个字符串,
假设key不是个数值类型那么当执行事物后,这条命令将会报错,其他的命令正常执行。

5.WATCH监控
在了解WATCH监控前我们先来聊聊乐观锁和悲欢锁,
①悲观锁:我很悲观,我觉得我每次去拿数据的时候都会被人修改,所以我每次拿数据的时候我就会上锁,
别人想拿这个数据的时候就会block,直到别人拿到锁。传统的关系型数据库里面就会用到很多这种机制,
比如 行锁,表锁,读锁,写锁等,都是在操作前加上锁,防止多人修改同一条数据。这样的话就成功提高了数据的一致性,降低了并发性。
②乐观锁:我很乐观,我觉得我每次去拿数据的时候别人都不会修改,所以不会上锁,但是我在更新数据的时候,
我就会判断一下,有没有别人去更新这个数据,这里我们可以使用版本号等机制来实现判断。
乐观锁适用于多读的应用类型,这样可以提高吞吐量和并发性。
乐观锁策略:提交版本必须大于记录当前版本才能更新数据
下面来看看WATCH怎么使用的
一,无加塞篡改
我这里就拿个花呗额度来举例,假设我的balance为余额,arrears为欠下的余额,下面这张图为
无加塞篡改,先监控在开启multi,保证两笔金额变动在同一事物内,一起执行。

二,有加塞篡改
类似于我在修改这个数据的时候,被其他用户已经修改了,已经被加上锁了,我自己就修改不了了,要等被人修改完才能够修改,这跟上面的乐观锁很相似,
我开启两个控制台,一个用来正常操作,一个用来中途篡改数据。
WATCH 监视一个(或多个) key ,如果在事务执行之前这个(或这些) key 被其他命令所改动,那么事务将被打断。
下面我们来看图.

我还没执行这些命令之前我根本不知道我的数据已经在被人修改了,当我要修改数据的时候已经被人先改了。
这时候我们UNWATCH命令就派上用场了,相当于当我修改数据的时候我就把锁加上,修改完成后就把锁解开,让下一个人继续修改数据,
取消 WATCH 命令对所有 key 的监视,一旦我们执行EXEC以后所有监控锁都会被取消掉。
下面我们来看图

5,结尾
后面还会更新如何使用RedisTemplate来操作Redis命令,如何解决Redis穿透/雪崩等。
文章就写到这里了,如果文章有需要改进的地方请大佬们在评论区里留言,谢谢点评。
Redis 事物、悲观、乐观锁 (详细)的更多相关文章
- 五分钟学会悲观乐观锁-java vs mysql vs redis三种实现
1 悲观锁乐观锁简介 乐观锁( Optimistic Locking ) 相对悲观锁而言,乐观锁假设认为数据一般情况下不会造成冲突,所以在数据进行提交更新的时候,才会正式对数据的冲突与否进行检测,如果 ...
- php+redis 学习 三 乐观锁
<?php header('content-type:text/html;chaeset=utf-8'); /** * redis实战 * * 实现乐观锁机制 * * @example php ...
- redis事务和乐观锁
1 MULTI/EXEC 执行本事务. MULTI set foo bar get foo set foo hello EXEC 在EXEC执行前,三条命令都放入队列中,然后EXEC触发执行.没有回滚 ...
- redis的hmset乐观锁的实现
1.lua脚本(集成实现了乐观锁,hmset ,expire等) local key=KEYS[1]; local oldVerion=tonumber(ARGV[1]); local seconds ...
- Redis分布式锁----乐观锁的实现,以秒杀系统为例
本文使用redis来实现乐观锁,并以秒杀系统为实例来讲解整个过程. 乐观锁 大多数是基于数据版本(version)的记录机制实现的.即为数据增加一个版本标识,在基于数据库表的版本解决方案中, ...
- 悲观锁 vs 乐观锁 vs Redis
企业面对高并发场景采用的方案. 比如 产品抢购高并发时的超发现象. 1 悲观锁悲观锁 需要数据库本身提供支持(Oracle和MySQL都是支持的).实现细节:当前 数据库事务 读取到产品后, 就将目标 ...
- redis 事务(悲观锁和乐观锁)
MULTI 开启事务,后续的命令会被加入到同一个事务中 事务中的操作会发送给客服端,但是不会立即执行,而是将操作放到了该事务对应的一个队列中,服务端返回QUEQUD EXEC 执行EXEC后,事务中的 ...
- 基于Django的乐观锁与悲观锁解决订单并发问题的一点浅见
订单并发这个问题我想大家都是有一定认识的,这里我说一下我的一些浅见,我会尽可能的让大家了解如何解决这类问题. 在解释如何解决订单并发问题之前,需要先了解一下什么是数据库的事务.(我用的是mysql数据 ...
- Mysql悲观锁乐观锁区别与使用场景
本人免费整理了Java高级资料,涵盖了Java.Redis.MongoDB.MySQL.Zookeeper.Spring Cloud.Dubbo高并发分布式等教程,一共30G,需要自己领取.传送门:h ...
随机推荐
- Juniper srx新增接口IP,使PC直连srx(转)
转自:https://www.jianshu.com/p/bc27134bde3d Juniper srx新增接口IP,使PC直连srx 2018.11.19 14:24:15字数 424 概述 需求 ...
- 吴裕雄--天生自然Linux操作系统:Linux vi/vim
Linux vi/vim 所有的 Unix Like 系统都会内建 vi 文书编辑器,其他的文书编辑器则不一定会存在. 但是目前我们使用比较多的是 vim 编辑器. vim 具有程序编辑的能力,可以主 ...
- ZJNU 1538 - YN!ngC的取子游戏--高级
Nim博弈 因为移动到第0阶会消失 所以可以得到从最后一个人操作必定是把第1阶所有子全部移动到第0阶 递推可得,最后一个能把奇数阶的子移动到偶数阶上的人将会必胜 所以这个必胜条件就是奇数阶上的子全部为 ...
- 使用Spring Boot和OAuth构建安全的SPA
最近一段时间都在闭关学习,过程还是有点艰辛的,幸运的是还有优锐课老师带着,少走了很多弯路.很久也没有更新文章了,这篇想和大家分享的是,了解如何在使用Spring Boot入门程序的同时使用Spring ...
- 6.windows-oracle实战第六课 --数据管理
数据库管理员: 每个oracle数据库应该至少有一个数据库管理员(dba),对于一个小的数据库,一个dba就够了,但是对于一个大的数据库可能需要多个dba分担不同的管理职责. 对于dba来说,会权限管 ...
- 吴裕雄--天生自然 pythonTensorFlow图形数据处理:读取MNIST手写图片数据写入的TFRecord文件
import numpy as np import tensorflow as tf from tensorflow.examples.tutorials.mnist import input_dat ...
- 14 微服务电商【黑马乐优商城】:day03-springcloud(Zuul网关)
本项目的笔记和资料的Download,请点击这一句话自行获取. day01-springboot(理论篇) :day01-springboot(实践篇) day02-springcloud(理论篇一) ...
- 初识数据库MySQL
一.认识数据库 1:什么是数据(Data) 描述事物的符号记录被称为数据,这个符号可以是数字,文字,图片,声音,语言等 2:什么是数据库(DataBase,简称DB) 数据库是存放数据的仓库,库一般 ...
- TPO4-2 Cave Art in Europe
Perhaps, like many contemporary peoples, Upper Paleolithic men and women believed that the drawing o ...
- Codeforces 1292A/1293C - NEKO's Maze Game
题目大意: 有一个2*n的图 NEKO#ΦωΦ要带领mimi们从(1,1)的点走到(2,n)的点 每次会操作一个点,从可以通过到不可以通过,不可以通过到可以通过 每操作一次要回答一次NEKO#ΦωΦ能 ...