ZooKeeper和Reids做分布式锁的区别?

Reids:

  1. Redis只保证最终一致性,副本间的数据复制是异步进行(Set是写,Get是读,Reids集群一般是读写分离架
    构,存在主从同步延迟情况),主从切换之后可能有部分数据没有复制过去可能会 **「丢失锁」**情况,故强一
    if redis.call("get", KEYS[1])==ARGV[1] then
    return redis.call("del", KEYS[1])
    else
    return 0
    end
    致性要求的业务不推荐使用Reids,推荐使用zk。
  2. Redis集群各方法的响应时间均为最低。随着并发量和业务数量的提升其响应时间会有明显上升(公网集群影
    响因素偏大),但是极限qps可以达到最大且基本无异常
    ZooKeeper:
  3. 使用ZooKeeper集群,锁原理是使用ZooKeeper的临时顺序节点,临时顺序节点的生命周期在Client与集群的
    Session结束时结束。因此如果某个Client节点存在网络问题,与ZooKeeper集群断开连接,Session超时同样
    会导致锁被错误的释放(导致被其他线程错误地持有),因此ZooKeeper也无法保证完全一致。
  4. ZK具有较好的稳定性;响应时间抖动很小,没有出现异常。但是随着并发量和业务数量的提升其响应时间和
    qps会明显下降。
    总结:
  5. Zookeeper每次进行锁操作前都要创建若干节点,完成后要释放节点,会浪费很多时间;
  6. 而Redis只是简单的数据操作,没有这个问题。
相关推荐
岸边的风1 天前
用Logseq与cpolar:构建开源笔记的分布式协作系统
笔记·分布式·开源
鲸屿1951 天前
zookeeper
分布式·zookeeper·云原生
你我约定有三1 天前
分布式微服务--单体架构 ,垂直架构 ,分布式架构 ,SOA ,微服务 以及他们之间的演变过程
分布式·微服务·架构
codergjw1 天前
RabbitMQ篇
分布式·rabbitmq
半桶水专家1 天前
Kafka Topic(主题)详解
分布式·kafka
蜡笔小柯南1 天前
每秒扛住10万请求?RedissonRateLimiter 分布式限流器详解
分布式·redisson·滑动窗口·ratelimiter
一行•坚书1 天前
Redisson分布式锁会发生死锁问题吗?怎么发生的?
java·分布式·后端
半桶水专家2 天前
kafka Partition(分区)详解
分布式·kafka
何双新2 天前
第一讲、Kafka 初识与环境搭建
分布式·kafka·linq
阿登林2 天前
如何使用Kafka处理高吞吐量的实时数据
分布式·kafka