分布式锁的场景以及实现方案_redis分布式锁使用场景

分布式锁的场景以及实现方案_redis分布式锁使用场景分布式锁应用场景/实现方案

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

工作中用到了分布式锁,特意研究了下各种场景和实现方案。

为什么用分布式锁?

其实提到锁这个东西,我理解它有点类似现实生活中的锁。

举个例子:比如门锁,现实生活中我们为什么用门锁,因为防止更多人进去。

那结合到我们编程中来道理也是一样的,在一些特定场景,一些特定的资源是有限的。(比如库存等)这个时候我们要加上锁,其实可以理解成钥匙,有锁钥匙的人才能走下面的流程

应用场景:

1.最常见扣减库存

2.缓存击穿/缓存雪崩(也可以采用分布式锁)

3.在高并发的场景下,阻止流量打到后边等等

实现方案:

1.利用mysql实现分布式锁

1.创建锁表,利用唯一性约束,获取锁时插入数据库。

2.释放锁时,删除数据

优点:容易理解,实现简单

缺点:性能比较差,适合并发不高的场景

2.基于redis setnx实现分布式锁

1.主要设置锁的超时时间,避免死锁
2.如果锁过期了事情没干完-使用多线程(守护线程)延长过期
3.为了保证原子性操作,实现的时候采用Redisson(API实现比较简单/源码中加锁/释放锁操作都是用 Lua 脚本完成的,封装的非常完善,开箱即用)

优点:redis的性能很高,可以支撑高并发的获取、释放锁操作。

缺点:集群环境下,主节点宕机时,两个线程会拿到锁
     其实需要自己不断去尝试获取锁,比较消耗性能。

3.基于redLock实现分布式锁

1.RedLock 算法虽然是需要多个实例,但是这些实例都是独自部署的,没有主从关系。
RedLock 作者指出,之所以要用独立的,是避免了 Redis 异步复制造成的锁丢失,
比如:主节点没来的及把刚刚 Set 进来这条数据给从节点,就挂了。如上面第二点说的
问题

2.红锁算法认为,只要 2N+1 个节点加锁成功,那么就认为获取了锁。
3.集群有5台节点三个节点加锁成功并且花费时间小于锁的有效期
4.认定加锁成功了

缺点:有一台机器重启,有两个线程拿到锁(概率很低)

4.基于zookeeper实现分布式锁

加锁流程

首先在zookeeper创建根节点,也就是持久节点(rootNode),作为锁节点
在根节点(rootNode)下创建临时节点(node_x):
查询根节点的子节点列表,检查如果当前创建的节点的序号是最小话,就认定该客户端已经获得锁
如果不是最小的节点,说明获取锁失败,此时客户端就要找比自己小1的节点(node_x-1),
对其注册事件监听器(等待node_x-1的节点被删除的时候,通知当前节点获取锁)
获取锁的客户端在执行完业务就删除当前最小节点。删除最小节点后客户端会通过监听器收到通知,
然后再次判断是否自己的节点最小,是的话进行加锁,不是的话重复上述操作

释放锁流程

等待获取锁的客户端执行完业务流程,直接删除当前的最小的临时顺序节点(L)即可
这样监听L的删除事件的客户端,就会被通知到,尝试进行锁的获取

优点:zookeeper天生设计定位就是分布式协调,强一致性。锁的模型健壮、简单易用、适合做分布式锁。
如果获取不到锁,只需要添加一个监听器就可以了,不用一直轮询,性能消耗较小。

缺点:代码通过Watcher机制实现,实现相对复杂

上面介绍了目前主流做分布式锁的方案,咱们在做技术选项和对比的时候.根据实际应用场景选择合适的方案把。其实用的比较多直接单独用一台redis来做分布式锁,其实已满足大部分场景了。

其实每一种实现方案都是有它的优缺点的,我们在知道它的优缺点以后再进行选择。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/195869.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 图片外链方法大全: 免费的图床! 告别新浪图床 和 CDN

    图片外链方法大全: 免费的图床! 告别新浪图床 和 CDN今天给大家公开的是可以图片上传并获取稳定直链的方法,也就是俗称的”图床“;常用的一些免费图床,比如新浪图床可能不好用、图片访问慢;自费购买CDN价格过于昂贵,于是贫穷的我们整理出如下的方法上传图片,用于个人博客、网站等。本文仅列出可公开访问的网页,并只按正常用户操作,手动上传图片获取链接,不公开接口调用方法。防盗链可以通过网站的meta头激活成功教程,在head里插入下方代码:<metaname=”referrer”content=”never”>1、百度

    2022年6月20日
    84
  • mysql listagg函数_Oracle函数之LISTAGG「建议收藏」

    mysql listagg函数_Oracle函数之LISTAGG「建议收藏」最近在学习的过程中,发现一个挺有意思的Oracle函数,它可实现对列值的拼接。下面我们来看看其具体用法。最近在学习的过程中,发现一个挺有意思的Oracle函数,它可实现对列值的拼接。下面我们来看看其具体用法。用法:对其作用,官方文档的解释如下:Foraspecifiedmeasure,LISTAGGordersdatawithineachgroupspecifiedinth…

    2022年9月6日
    5
  • python分组聚合_python爬虫标签

    python分组聚合_python爬虫标签由于某些原因,回归和分类问题总会引起机器学习领域的大部分关注。多标签分类在数据科学中是一个比较令人头疼的问题。在这篇文章中,我将给你一个直观的解释,说明什么是多标签分类,以及如何解决这个问题。1.多标签分类是什么?让我们来看看下面的图片。如果我问你这幅图中有一栋房子,你会怎样回答?选项为“Yes”或“No”。或者这样问,所有的东西(或标签)与这幅图有什么关系?在这些类型的问题中,我们有一组目标变…

    2025年7月22日
    5
  • 关于数据库备份的定义和重要性

    关于数据库备份的定义和重要性所谓备份,就是通过特定的办法,讲数据库的必要文件复制到转储设备的过程.其中,转储设备是指用于放置数据库拷贝的磁带或磁盘    选择备份的依据是:丢失数据的代价与确保数据不丢失的代价之比.还有的时候,硬件的备份有时根本就满足不了现实需要,比如误删了一个表,又想恢复该表的时候,数据库备份就变得重要了.    Oracle提供了强大的备份与恢复策略,包括常规数据库备份(逻辑备份,冷备份与

    2022年5月14日
    29
  • SpringMVC工作流程 — 详解

    SpringMVC工作流程 — 详解SpringMVC一,SpringMVC简介二,SpringMVC的工作原理图执行流程三,SpringMVC核心组件前端控制器DispatcherServlet处理器映射器HandlerMapping处理器适配器HandlerAdapter处理器Handler视图解析器ViewResolver一,SpringMVC简介MVC:是一种架构模式,将业务逻辑和页面展示分离,使程序分层、分工合作,既相互独立,又协同合作。MVC是模型(Model)、视图(View)、控制器(Controller)的简写,是一种

    2022年6月7日
    43
  • win10快捷图标小箭头怎么恢复_win10恢复快捷方式小箭头

    win10快捷图标小箭头怎么恢复_win10恢复快捷方式小箭头regadd”HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows\CurrentVersion\Explorer\ShellIcons”/v29/d”%systemroot%\system32\imageres.dll,197″/treg_sz/f  taskkill/f/imexplorer.exe  attrib-s…

    2022年10月18日
    2

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号