您当前的位置:首页 > 电脑百科 > 数据库 > Redis

Redis分布式锁,绝对问烂了吧

时间:2023-07-12 14:21:54  来源:微信公众号  作者:轻松面试

这个玩意儿问的太多,现在很多面试官已经避开了这个面试题

我这里也不讲太多,而是在实现上做一些总结和分析

看看有没有帮助

 

1. 什么是分布式锁?

锁大家已经很清楚了,就是避免线程竞争出现问题,那分布式锁,自然在分布式环境下避免线程或进程竞争出现问题了。

一句话回答: 分布式下,对共享资源进行互斥访问的一种处理机制

列几个应用场景(工作中实际用到的):

1. 定时任务

定时任务写在服务里时,同时启动了多个服务,这个时候就需要用到分布式锁,保证只有一个服务去执行定时任务。(即便定时任务有幂等性,但是也要考虑并发带来的问题)

2. 三方认证信息维护

我们要接入第三方系统(例如:微信公众平台),通过Token进行访问,Token失效时,需要去更新Token,这个时候只允许一个服务去更新,其他服务使用旧的token访问(微信拿到新token时,旧的token还有5分钟有效期),其他第三方系统我们也是用到了分布式锁处理。


上面两个例子,公司至今还有系统在使用,大部分定时任务已经移植到了统一调度中心,三方信息维护目前还在应用,至于网上经常看到的秒杀,抢购的案例,我是不赞同用分布式锁的,分布式锁也要解决单点问题,其次分布式锁性能也较低。


 

 

2. redis如何实现分布式锁?【极速回答版】

这个面试题我真的不想说了,不知道问了多少次,这里我简单快速的回顾一下,不像网上的长篇大论去讨论,而是说一些关键注意事项,这些事项说完,面试基本没有问题,没有谁面试真的让你去代码实现分布式锁。

1. 原子性
设置获取锁的命令一定要原子性,不能分多个命令进行,如果确实需要多个命令,则使用Lua脚本去完成。

2. 持有线程
因为要保证锁的安全性,要求记录持有锁的线程,允许重入和解锁,也避免其他线程未持有锁释放该锁。

3. 锁释放
如果获取锁的服务自身挂掉,也要保证锁能够释放掉,这个时候通常用超时(key有效期)来处理。

4. 超时检查
如果应用没有挂,结果锁超时释放了,这也是一个问题,这个时候就可以通过检查持锁线程状态的方式去解决,另起检查线程(我是不理解了,另起检查线程,万一它也挂了呢,所以多此一举嘛,也可以自身检查后延长时间,这个就更不靠谱了,自己执行任务都超时了,还来得及延长锁么)

5. 单点性
如果Redis服务自身挂了,也要考虑锁是否还能被使用,这个时候就需要集群处理了。


通过上面几点看,自身去实现一个分布式锁,太繁琐,所以Redis官方给了建议,使用Redlock(也有一些其它的框架实现Redis分布式锁);那么新的面试题又来了,Redlock的实现原理。

这里先不去对比其他方式实现分布式锁(例如zookeeper和数据库等)


 

3. Redlock实现原理?问题分析

Redlock的实现原理如下:

  1. 获取当前时间戳

  2. 尝试在多个Redis节点上获取锁,每个节点使用相同的keyvalue,并设置一个过期时间。

  3. 统计成功获取锁的节点数量,根据1的时间计算获取锁花费的时间,判断锁是否过期

  4. 如果大多数节点获取锁成功,并在有效期内,则获取成功

  5. 如果获取锁失败,则在所有成功获取锁的节点上释放锁。

Redlock也存在一些问题,例如:

1. 时钟偏移

  • 如果每个节点时间戳不一样,过期时间可能计算错误

2. 锁提前释放

  • 和第一道题的一样,如果还没有释放锁,锁已经过期了,导致其他客户端可以获取锁

3. 分布式系列问题,用例子说明

  • 1 2 3 4 5 台服务,A线程在 1 2 3 设置键成功,A持有锁,B线程在4 5 设置键,此时 3 挂了,重启后丢失A创建的键,B线程又设置键成功了,那就AB均获取到锁了,可以通过持久化解决。

  • 1 2 3 4 5 台服务,A线程在 1 2 设置键成功,B线程在 3 4 设置键成功,C线程在 5 设置键成功,导致都获取不到锁,只能都释放重新来了,很难完全解决。

4. 性能问题

  • 节点越多,获取锁的时间就越长,情况也会越复杂

所以Redlock也不能很好的解决分布式锁的系列问题, 这个时候又来个Redlock++,它可以解决一部分问题,更复杂了,没有必要再深入了,通常情况下,使用分布式锁也得取舍,因为它本身为了解决互斥问题,却带来了更多的问题,要么直接使用开源的分布式锁框架,要么直接改变业务方式。



Tags:Redis   点击:()  评论:()
声明:本站部分内容及图片来自互联网,转载是出于传递更多信息之目的,内容观点仅代表作者本人,不构成投资建议。投资者据此操作,风险自担。如有任何标注错误或版权侵犯请与我们联系(Email:2595517585@qq.com),我们将及时更正、删除。
▌相关推荐
哈喽大家好,我是咸鱼。今天这篇文章介绍如何在一台服务器(以 CentOS 7.9 为例)上通过 redis-trib.rb 工具搭建 Redis cluster (三主三从)。redis-trib.rb 是一个基于 Ruby 编写的...【详细内容】
2023-09-05  Tags: Redis  点击:(1)  评论:(0)  加入收藏
在《一台服务器上部署 Redis 伪集群》这篇文章中,咸鱼在创建 Redis 集群时并没有明确指定哪个 Redis 实例将担任 master,哪个将担任 slave,然而 Redis 却自动完成了主从节点的...【详细内容】
2023-09-05  Tags: Redis  点击:(1)  评论:(0)  加入收藏
在王者荣耀中,我们会打排位赛,而且大家最关注的往往都是你的段位,还有在好友中的排名。作为程序员的你,思考过吗,这个段位排行榜是怎么实现的?了解它的实现原理,会不会对上分有所帮...【详细内容】
2023-09-01  Tags: Redis  点击:(6)  评论:(0)  加入收藏
一、简介 单个Redis的读写能力是有限的,并且存在不稳定性。当唯一的Redis服务宕机了,就没有可用的Redis服务了,另外当硬件出现问题,单机的数据便无法恢复。Redis集群的出...【详细内容】
2023-08-31  Tags: Redis  点击:(0)  评论:(0)  加入收藏
Redis是一款高性能的key-value型数据库,它经常被用于缓存、队列、实时数据处理等场景中。由于Redis的高性能和可靠性,它在互联网领域得到了广泛的应用。然而,任何一种软件都难...【详细内容】
2023-08-31  Tags: Redis  点击:(8)  评论:(0)  加入收藏
现如今 Redis 变得越来越流行,几乎在很多项目中都要被用到,不知道你在使用 Redis 时,有没有思考过,Redis 到底是如何稳定、高性能地提供服务的? 我使用 Redis 的场景很简单,只使用...【详细内容】
2023-08-31  Tags: Redis  点击:(4)  评论:(0)  加入收藏
我们都知道,在面试的环节中,会有各种千奇百怪的问题,最经典的就是各种数据库,这种中间件,还有就是底层原理,还有就是关于缓存数据库这块,今天了不起就来说说这个某东最喜欢问的一个...【详细内容】
2023-08-29  Tags: Redis  点击:(10)  评论:(0)  加入收藏
1、了解分布式锁的特性 1、锁的互斥性 也就是说,在任意时刻,只能有一个客户端能获取到锁,不能同时有两个或多个客户端获取到锁。 简单来说,就比如上厕所,一个厕所只有一个坑位...【详细内容】
2023-08-28  Tags: Redis  点击:(8)  评论:(0)  加入收藏
大家好,我是你们的小米!今天我们要来聊聊一个在面试中经常被问到的话题:Redis的五种数据类型及其应用场景。作为一名热爱技术的小伙伴,对于这个话题,我们可是要深入挖掘一下哦!Str...【详细内容】
2023-08-28  Tags: Redis  点击:(11)  评论:(0)  加入收藏
我们将分布式锁基于缓存扩展了一版,也就是说本starter即有分布式缓存功能,又有分布式锁功能。而注解版的分布式锁能够解决大多数场景的并核问题,小粒度的Lock锁方式补全其他场...【详细内容】
2023-08-28  Tags: Redis  点击:(11)  评论:(0)  加入收藏
▌简易百科推荐
哈喽大家好,我是咸鱼。今天这篇文章介绍如何在一台服务器(以 CentOS 7.9 为例)上通过 redis-trib.rb 工具搭建 Redis cluster (三主三从)。redis-trib.rb 是一个基于 Ruby 编写的...【详细内容】
2023-09-05  咸鱼运维杂谈  微信公众号  Tags:Redis   点击:(1)  评论:(0)  加入收藏
在《一台服务器上部署 Redis 伪集群》这篇文章中,咸鱼在创建 Redis 集群时并没有明确指定哪个 Redis 实例将担任 master,哪个将担任 slave,然而 Redis 却自动完成了主从节点的...【详细内容】
2023-09-05  咸鱼运维杂谈    Tags:Redis   点击:(1)  评论:(0)  加入收藏
在王者荣耀中,我们会打排位赛,而且大家最关注的往往都是你的段位,还有在好友中的排名。作为程序员的你,思考过吗,这个段位排行榜是怎么实现的?了解它的实现原理,会不会对上分有所帮...【详细内容】
2023-09-01  哪吒编程  微信公众号  Tags:Redis   点击:(6)  评论:(0)  加入收藏
一、简介 单个Redis的读写能力是有限的,并且存在不稳定性。当唯一的Redis服务宕机了,就没有可用的Redis服务了,另外当硬件出现问题,单机的数据便无法恢复。Redis集群的出...【详细内容】
2023-08-31  程序猿小杨  微信公众号  Tags:Redis   点击:(0)  评论:(0)  加入收藏
Redis是一款高性能的key-value型数据库,它经常被用于缓存、队列、实时数据处理等场景中。由于Redis的高性能和可靠性,它在互联网领域得到了广泛的应用。然而,任何一种软件都难...【详细内容】
2023-08-31  生活是点滴    Tags:Redis断连   点击:(8)  评论:(0)  加入收藏
现如今 Redis 变得越来越流行,几乎在很多项目中都要被用到,不知道你在使用 Redis 时,有没有思考过,Redis 到底是如何稳定、高性能地提供服务的? 我使用 Redis 的场景很简单,只使用...【详细内容】
2023-08-31  水滴与银弹  微信公众号  Tags:Redis   点击:(4)  评论:(0)  加入收藏
我们都知道,在面试的环节中,会有各种千奇百怪的问题,最经典的就是各种数据库,这种中间件,还有就是底层原理,还有就是关于缓存数据库这块,今天了不起就来说说这个某东最喜欢问的一个...【详细内容】
2023-08-29  Java极客技术  微信公众号  Tags:Redis   点击:(10)  评论:(0)  加入收藏
1、了解分布式锁的特性 1、锁的互斥性 也就是说,在任意时刻,只能有一个客户端能获取到锁,不能同时有两个或多个客户端获取到锁。 简单来说,就比如上厕所,一个厕所只有一个坑位...【详细内容】
2023-08-28  IT动力  今日头条  Tags:Redisson   点击:(8)  评论:(0)  加入收藏
大家好,我是你们的小米!今天我们要来聊聊一个在面试中经常被问到的话题:Redis的五种数据类型及其应用场景。作为一名热爱技术的小伙伴,对于这个话题,我们可是要深入挖掘一下哦!Str...【详细内容】
2023-08-28  知其然亦知其所以然    Tags:Redis   点击:(11)  评论:(0)  加入收藏
一、简介 我们先思考一个常见的业务问题:如果你负责开发维护一个大型的网站,有一天老板找产品经理要某个网站每个网页每天的 UV(访客量) 数据,然后让你来开发这个统计模块,你会如...【详细内容】
2023-08-25  程序猿小杨  微信公众号  Tags:Redis   点击:(0)  评论:(0)  加入收藏
站内最新
站内热门
站内头条