Zookeeper与Redis 对比

这篇具有很好参考价值的文章主要介绍了Zookeeper与Redis 对比。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

1. 为什么使用分布式锁?

        使用分布式锁的目的,是为了保证同一时间只有一个 JVM 进程可以对共享资源进行操作。

根据锁的用途可以细分为以下两类:

        1、 允许多个客户端操作共享资源,我们称为共享锁

               这种锁的一般是对共享资源具有幂等性操作的场景,主要是为了避免重复操作共享                 资源频繁加锁带来的性能开销。

        2、 只允许一个客户端操作共享资源,我们成为排他锁

               这种锁一般是用在对共享资源操作具有非幂等性操作的场景,也就是需要保证在同                 一时刻只有一个进程或者线程能够访问这个共享资源。


2. 目前实现分布式锁最常用的中间件是 Redis和Zookeeper      

a、第一种,Redis 可以通过两种方式来实现 

                i. 利用 Redis 提供的`SET key value NX PX milliseconds `指令,这个指令是设                           置一个 key-value,如果 key 已经存在,则返回 0,否则返回 1, 我们基于这个                     返回值来判断锁的占用情况从而实现分布式锁。

                ii. 基于 Redission 客户端来实现分布式锁,Redisson 提供了分布式锁的封装方                          法,我们只需要调用 api 中的`lock()`和`unlock()`方法。它帮我们封装锁实现                      的细节和复杂度

                                1. redisson 所有指令都通过 lua 脚本执行并支持 lua 脚本原子性执行

                                2. redisson 中有一个 watchdog 的概念,翻译过来就是看门狗,它会在                                      你获取锁之后,每隔 10 秒帮你把 key 的超时时间设为 30s,就算一                                        直持有锁也不会出现 key 过期了。

                                    “看门狗”的逻辑保证了没有死锁发生。

b. 第二种,基于 ZK 实现分布式锁的落地方案

        Zookeeper 实现分布式锁的方法比较多,我们可以使用有序节点来实现。

                 i. 每个线程或进程在 Zookeeper 上的`/lock`目录下创建一个临时有序的节点表示                        去抢占锁,所有创建的节点会按照先后顺序生成一个带有序编号的 节点。

                 ii. 线程创建节点后,获取/lock 节点下的所有子节点,判断当前线程创建的节点是                       否是所有的节点的序号最小的。

                 iii. 如果当前线程创建的节点是所有节点序号最小的节点,则认为获取锁成功。

                 iv. 如果当前线程创建的节点不是所有节点序号最小的节点,则对节点序号的前一                       个节点添加一个事件监听,当前一个被监听的节点释放锁之后,触发回调通                            知,从而再次去尝试抢占锁。


3. 两种方案都有各自的优缺点

对于 redis 的分布式锁而言,它有以下缺点:

1、它获取锁的方式简单粗暴,如果获取不到锁,会不断尝试获取锁,比较消耗性能

2、Redis 是 AP 模型,在集群模式中由于数据的一致性会导致锁出现问题,即便使用                  Redlock 算法来实现,在某些复杂场景下,也无法保证其实现 100%的可靠性。 不过在          实际开发中使用 Redis 实现分布式锁还是比较常见,而且大部分场情况下不会遇 到”极端        复杂的场景“,更重要的是 Redis 性能很高,在高并发场景中比较合适。

补充:

        明显AP结构选择了高可用和分区容错性,此时,那个失去联系的节点依然可以向系统提供服务,不过它的数据就不能保证是同步的了(失去了C属性)。Eureka就是一个AP架构的例子,当Eureka客户端心跳消失的时候,那Eureka服务端就会启动自我保护机制,不会剔除该EurekaClient客户端的服务,依然可以提供需求;

对于 zk 分布式锁而言

1、zookeeper 天生设计定位就是分布式协调,强一致性。锁的模型健壮、简单易用、 适合          做分布式锁。

2、 如果获取不到锁,只需要添加一个监听器就可以了,不用一直轮询,性能消耗较小。 如       果要在两者之间做选择,就个人而言的话,比较推崇 ZK 实现的锁,因为对于分布 式             锁言,它应该符合 CP 模型,但是 Redis 是 AP 模型,所以在这个点上,Zookeeper 会更       加合适。文章来源地址https://www.toymoban.com/news/detail-644635.html

到了这里,关于Zookeeper与Redis 对比的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包赞助服务器费用

相关文章

  • java操作zookeeper

    创建一个maven项目在pom文件里引入如下依赖: 创建一个测试类进行相关操作的测试 连接客户端 关闭客户端 创建节点 获取节点数据 查询子节点 查询节点状态信息 更新节点数据 更新节点数据,带版本号 删除节点 删除节点,必须成功 删除节点,回调函数 监听节点的创建、修

    2024年02月16日
    浏览(13)
  • Java——《面试题——Zookeeper篇》

    Java——《面试题——Zookeeper篇》

    全文章节 Java——《面试题——基础篇》 Java——《面试题——JVM篇》 Java——《面试题——多线程并发篇》 Java——《面试题——Spring篇》 Java——《面试题——SpringBoot篇》 Java——《面试题——MySQL篇》​​​​​​ Java——《面试题——SpringCloud》 Java——《面试题——Dob

    2024年02月11日
    浏览(12)
  • Java中的ZooKeeper是什么?

    Java中的ZooKeeper是一个开源的分布式协调服务,它可以帮助我们管理分布式系统中的数据和配置信息。ZooKeeper是由Facebook开发的一个开源项目,它被广泛用于Facebook的分布式系统。 ZooKeeper的名称来源于动物园管理员(Zookeeper),它可以帮助我们管理动物园中的动物,比如猴子、

    2024年02月14日
    浏览(9)
  • 六、ZooKeeper Java API操作

    六、ZooKeeper Java API操作

    目录 1、引入maven坐标 2、节点的操作 这里操作Zookeeper的JavaAPI使用的是一套zookeeper客户端框架 Curator ,解决了很多Zookeeper客户端非常底层的细节开发工作 。 Curator包含了几个包:

    2024年02月04日
    浏览(9)
  • windows下 java使用zookeeper案例,神策数据java面试题

    windows下 java使用zookeeper案例,神策数据java面试题

    public class BaseZookeeper implements Watcher { private ZooKeeper zookeeper; /** * 超时时间 */ private static final int SESSION_TIME_OUT = 2000; private CountDownLatch countDownLatch = new CountDownLatch(1); @Override public void process(WatchedEvent event) { if (event.getState() == KeeperState.SyncConnected) { System.out.println(“Watch received event”

    2024年04月16日
    浏览(8)
  • windows下 java使用zookeeper案例

    windows下 java使用zookeeper案例

    countDownLatch.await(); System.out.println(“zookeeper connection success”); } /** * 创建节点 * @param path * @param data * @throws Exception */ public String createNode(String path, String data) throws Exception { return this.zookeeper.create(path, data.getBytes(), Ids.OPEN_ACL_UNSAFE, CreateMode.PERSISTENT); } /** * 获取路径下所有子节点 *

    2024年04月28日
    浏览(7)
  • java面试常问,zookeeper常见面试题

    java面试常问,zookeeper常见面试题

    什么是 Spring Boot? 为什么要用 Spring Boot? Spring Boot 的核心配置文件有哪几个?它们的区别是什么? Spring Boot 的配置文件有哪几种格式?它们有什么区别? Spring Boot 的核心注解是哪个?它主要由哪几个注解组成的? 开启 Spring Boot 特性有哪几种方式? Spring Boot 需要独立的容器

    2024年03月15日
    浏览(17)
  • zookeeper入门书籍,Java工作经验6年

    zookeeper入门书籍,Java工作经验6年

    上一份Spring的手绘思维脑图(就像是个知识大纲总结),预览一下Spring的知识点,心里有个谱。不过这边我是采用的截图方式,为了把全部的内容都截取出来,所以整个就比较小,可能不是很清晰。 Spring面试真题(七大模块:一般问题+IOC+Beans+注解+数据访问+AOP+MVC) 一般问题

    2024年03月22日
    浏览(11)
  • golang 和java对比

    Java的优点: 跨平台性:Java程序可以在不同的操作系统上运行,只需安装相应的Java虚拟机即可。 面向对象:Java是一种面向对象的语言,具有封装、继承和多态等特性,使得代码更加易于维护和扩展。 大量的第三方库和框架:Java拥有丰富的第三方库和框架,可以加速开发速

    2024年02月11日
    浏览(6)
  • java + opencv对比图片不同

    java + opencv对比图片不同

    1,去官网下载opencv,下载的时候需要注册一个 Oracle 账户,分分钟就能注册。然后安装。我下的是4.7的。 2,找到jar包放进项目里 3,项目结构,比较简单 4,把下载的文件放进C盘 5,主类代码 6,工具类 7,效果图。如果是一张彩色和一张黑白的图片,效果就不太理想了。 资

    2024年02月11日
    浏览(11)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包