Redis——事务 & 锁机制

本文涉及的产品
Redis 开源版,标准版 2GB
推荐场景:
搭建游戏排行榜
云数据库 Tair(兼容Redis),内存型 2GB
简介: Redis——事务 & 锁机制

文章目录:


1.Redis中事务的定义

1.1 案例一:事务中组队成功、提交成功

1.2 案例二:事务中组队阶段报错、提交失败

1.3 案例三:事务中组队成功,提交有成功有失败情况

2.Redis中的锁机制

2.1 悲观锁

2.2 乐观锁

2.3 watchunwatch命令

1.Redis中事务的定义


Redis事务是一个单独的隔离操作:事务中的所有命令都会序列化、按顺序地执行。事务在执行的过程中,不会被其他客户端发送来的命令请求所打断。


Redis事务的主要作用就是串联多个命令防止别的命令插队。


Redis事务的三特性:

·       单独的隔离操作:事务中的所有命令都会序列化、按顺序地执行。事务在执行的过程中,不会被其他客户端发送来的命令请求所打断。

·       没有隔离级别的概念:队列中的命令没有提交之前都不会实际被执行,因为事务提交前任何指令都不会被实际执行。

·       不保证原子性:事务中如果有一条命令执行失败,其后的命令仍然会被执行,没有回滚。


Redis事务的相关命令主要是以下这三个:

MultiExecdiscard

从输入Multi命令开始,输入的命令都会依次进入命令队列中,但不会执行,直到输入Exec后,Redis会将之前的命令队列中的命令依次执行。

组队的过程中可以通过discard来放弃组队。

下面,我们来看一个简单的事务案例。

我将redis的安装包存到了/opt目录下,然后tar -zxvf 进行解压,之后makemake install进行安装就可以了,这个步骤我就不再多说了。


上面的截图是在linux环境下,启动redis的步骤,安装之后redis的启动命令都在/usr/local/bin 目录下,/etc/redis.conf redis的配置文件。

启动的时候,记得把防火墙关了。

下面使用 multiexecdiscard命令进行事务操作。


1.1 案例一:事务中组队成功、提交成功


上面的案例,从 multi 开启事务,之后向redis中存入两个key,之后exec 正常执行事务。discard 可以放弃事务的执行。

通过 keys * 命令可以看到目前redis中只有exec命令执行后的key,而discard放弃执行事务的keyk1k2)是不存在的。


1.2 案例二:事务中组队阶段报错、提交失败


这里multi开启事务,在第三个 set 的时候,出现了错误语法,然后再执行 exec,可以看到事务全部不执行。

也就是说,只有 multi 的组队阶段出现一个错误,那么整个事务中所有的命令全部不会执行。


1.3 案例三:事务中组队成功,提交有成功有失败情况


这里multi开启事务,然后组队阶段无任何语法错误,但是我们exec 的时候,可以看到事务命令依次执行,在第二个命令的时候出错了。

这是因为k1这个键,是String类型的,肯定不能使用 incr 进行自增1操作,所以这条命令报错,但是其他命令正常执行。

也就是说,如果 multi 组队阶段没有出现错误,而在 exec 执行阶段某个命令报出了错误,则只有报错的命令不会被执行,而其他的命令都会执行,不会回滚。


2.Redis中的锁机制


2.1 悲观锁


悲观锁(Pessimistic Lock),顾名思义,就是很悲观,每次去拿数据的时候都认为别人会修改,所以每次在拿数据的时候都会上锁,这样别人想拿这个数据就会block直到它拿到锁。传统的关系型数据库里边就用到了很多这种锁机制,比如行锁表锁读锁写锁等,都是在做操作之前先上锁。


2.2 乐观锁


乐观锁(Optimistic Lock)顾名思义,就是很乐观,每次去拿数据的时候都认为别人不会修改,所以不会上锁,但是在更新的时候会判断一下在此期间别人有没有去更新这个数据,可以使用版本号等机制。乐观锁适用于多读的应用类型,这样可以提高吞吐量Redis就是利用这种check-and-set机制实现事务的。


2.3 watch、unwatch命令

在执行multi之前,先执行watch key1 [key2],可以监视一个(或多个) key ,如果在事务执行之前这个(或这些) key 被其他命令所改动,那么事务将被打断。

unwatch命令用来取消WATCH命令对所有key 的监视。

如果在执行WATCH命令之后,EXEC命令或DISCARD命令先被执行了的话,那么就不需要再执行UNWATCH了。v


上面的截图,开启了两个redis客户端,这两个redis客户端分别对balance 这个键进行watch监控。

然后分别在这两个客户端中,multi 开启事务,之后在第一个客户端中 incrby balance 进行增加50的操作,然后exec执行事务,可以看到此时第一个客户端中的balance的值被修改为了150。然后我们来到第二个客户端中,在事务中使用 incrby balance 进行增加20的操作,然后exec执行事务,可以看到返回了nil,也就是说事务无法执行。

这是因为在第二个客户端想对balance进行增加操作时(版本号为1.0),由于balance此时已经被第一个客户端监控了,在第一个客户端对balance执行增加操作后exec执行事务,此时balance的值变成了150(版本号为1.1),当第二个客户端再次exec执行事务时,会比较版本号(1.0 ≠ 1.1),所以这里的事务不会执行。

相关实践学习
基于Redis实现在线游戏积分排行榜
本场景将介绍如何基于Redis数据库实现在线游戏中的游戏玩家积分排行榜功能。
云数据库 Redis 版使用教程
云数据库Redis版是兼容Redis协议标准的、提供持久化的内存数据库服务,基于高可靠双机热备架构及可无缝扩展的集群架构,满足高读写性能场景及容量需弹性变配的业务需求。 产品详情:https://www.aliyun.com/product/kvstore     ------------------------------------------------------------------------- 阿里云数据库体验:数据库上云实战 开发者云会免费提供一台带自建MySQL的源数据库 ECS 实例和一台目标数据库 RDS实例。跟着指引,您可以一步步实现将ECS自建数据库迁移到目标数据库RDS。 点击下方链接,领取免费ECS&RDS资源,30分钟完成数据库上云实战!https://developer.aliyun.com/adc/scenario/51eefbd1894e42f6bb9acacadd3f9121?spm=a2c6h.13788135.J_3257954370.9.4ba85f24utseFl
相关文章
|
3月前
|
缓存 NoSQL Redis
Redis 事务
10月更文挑战第18天
35 1
|
3月前
|
监控 NoSQL 算法
Redis主从切换,锁失效怎么办?
在分布式系统中,Redis因其高性能和易用性而被广泛应用于缓存、分布式锁等场景。然而,当Redis采用主从架构以实现高可用性和数据冗余时,主从切换可能带来的锁失效问题成为了一个不容忽视的挑战。本文将深入探讨Redis主从切换导致锁失效的原因、影响及解决方案,旨在为大家提供实用的技术干货。
154 5
|
11天前
|
NoSQL Redis
Redis事务长什么样?一文带你全面了解
Redis事务是一组命令的有序队列,通过MULTI、EXEC、WATCH和DISCARD等命令实现原子性操作。事务中的命令在EXEC执行前不会实际运行,而是先进入队列,确保所有命令要么全部成功,要么全部失败。此外,Redis还支持Lua脚本实现类似事务的操作,通常更简单高效。事务适用于购物车结算、秒杀活动、排行榜更新等需要保证数据一致性的场景。
35 0
|
3月前
|
存储 缓存 NoSQL
大数据-45 Redis 持久化概念 RDB AOF机制 持久化原因和对比
大数据-45 Redis 持久化概念 RDB AOF机制 持久化原因和对比
57 2
大数据-45 Redis 持久化概念 RDB AOF机制 持久化原因和对比
|
3月前
|
NoSQL Java API
美团面试:Redis锁如何续期?Redis锁超时,任务没完怎么办?
在40岁老架构师尼恩的读者交流群中,近期有小伙伴在面试一线互联网企业时遇到了关于Redis分布式锁过期及自动续期的问题。尼恩对此进行了系统化的梳理,介绍了两种核心解决方案:一是通过增加版本号实现乐观锁,二是利用watch dog自动续期机制。后者通过后台线程定期检查锁的状态并在必要时延长锁的过期时间,确保锁不会因超时而意外释放。尼恩还分享了详细的代码实现和原理分析,帮助读者深入理解并掌握这些技术点,以便在面试中自信应对相关问题。更多技术细节和面试准备资料可在尼恩的技术文章和《尼恩Java面试宝典》中获取。
美团面试:Redis锁如何续期?Redis锁超时,任务没完怎么办?
|
3月前
|
设计模式 NoSQL 网络协议
大数据-48 Redis 通信协议原理RESP 事件处理机制原理 文件事件 时间事件 Reactor多路复用
大数据-48 Redis 通信协议原理RESP 事件处理机制原理 文件事件 时间事件 Reactor多路复用
46 2
|
3月前
|
SQL 分布式计算 NoSQL
大数据-42 Redis 功能扩展 发布/订阅模式 事务相关的内容 Redis弱事务
大数据-42 Redis 功能扩展 发布/订阅模式 事务相关的内容 Redis弱事务
33 2
|
3月前
|
NoSQL 关系型数据库 MySQL
Redis 事务特性、原理、具体命令操作全方位诠释 —— 零基础可学习
本文全面阐述了Redis事务的特性、原理、具体命令操作,指出Redis事务具有原子性但不保证一致性、持久性和隔离性,并解释了Redis事务的适用场景和WATCH命令的乐观锁机制。
429 0
Redis 事务特性、原理、具体命令操作全方位诠释 —— 零基础可学习
|
5月前
|
缓存 NoSQL Java
SpringBoot整合Redis、以及缓存穿透、缓存雪崩、缓存击穿的理解、如何添加锁解决缓存击穿问题?分布式情况下如何添加分布式锁
这篇文章介绍了如何在SpringBoot项目中整合Redis,并探讨了缓存穿透、缓存雪崩和缓存击穿的问题以及解决方法。文章还提供了解决缓存击穿问题的加锁示例代码,包括存在问题和问题解决后的版本,并指出了本地锁在分布式情况下的局限性,引出了分布式锁的概念。
SpringBoot整合Redis、以及缓存穿透、缓存雪崩、缓存击穿的理解、如何添加锁解决缓存击穿问题?分布式情况下如何添加分布式锁
|
5月前
|
NoSQL 关系型数据库 Redis
Redis6入门到实战------ 九、10. Redis_事务_锁机制_秒杀
这篇文章深入探讨了Redis事务的概念、命令使用、错误处理机制以及乐观锁和悲观锁的应用,并通过WATCH/UNWATCH命令展示了事务中的锁机制。
Redis6入门到实战------ 九、10. Redis_事务_锁机制_秒杀