分布式锁的概念、应用场景、实现方式和优缺点对比

一:什么是分布式锁

分布式锁是一种用于协调分布式系统中多个节点对共享资源的访问的机制。在分布式系统中,由于多个节点的并发执行,可能会导致对共享资源的竞争,而分布式锁的目的就是确保在任何时刻,只有一个节点能够持有锁,从而避免对共享资源的冲突访问

分布式锁的设计考虑到以下问题:

  • 互斥性(Mutual Exclusion): 任意时刻只有一个节点能够持有锁。
  • 安全性(Safety): 即使持有锁的节点崩溃或发生其他故障,系统仍能够继续正常工作。
  • 活性(Liveness): 在没有故障发生的情况下,最终会有一个节点成功获取到锁。

二:使用分布式锁的场景

多台服务器中,同一套代码,只需要执行一次【定时任务等】

不同的节点可能会同时对共享资源进行操作,如果没有有效的措施,就会发生数据不一致的情况。例如,两个节点同时对同一个数据进行修改,如果没有严格的同步机制,就会导致数据出现覆盖或冲突的情况。

三:分布式锁的实现类型

  1. 基于数据库 (MySql等) 实现;
  2. 基于缓存(Redis等)实现;
  3. 基于Zookeeper 实现;
    ps:每种实现类型中都有不同实现方式 ,比如mysql有悲观锁和乐观锁的两种实现方式

基于zookeeper分布式锁,使用InterProcessMutex对象代码案例

相关依赖

<dependency>
    <groupId>org.apache.curator</groupId>
    <artifactId>curator-framework</artifactId>
    <version>4.3.0</version> <!-- 使用最新版本 -->
</dependency>
<dependency>
    <groupId>org.apache.curator</groupId>
    <artifactId>curator-recipes</artifactId>
    <version>4.3.0</version> <!-- 使用最新版本 -->
</dependency>
import org.apache.curator.framework.CuratorFramework;
import org.apache.curator.framework.CuratorFrameworkFactory;
import org.apache.curator.retry.ExponentialBackoffRetry;
import org.apache.curator.framework.recipes.locks.InterProcessMutex;

public class DistributedLockExample {

    private static final String ZOOKEEPER_CONNECTION_STRING = "localhost:2181"; // 替换为实际的 ZooKeeper 服务器地址
    private static final String LOCK_PATH = "/example/lock"; //用于获取锁的zookeeper临时目录

    public static void main(String[] args) {
    
        CuratorFramework curatorFramework = createCuratorFramework();
        // 创建分布式锁对象
        InterProcessMutex lock = new InterProcessMutex(curatorFramework, LOCK_PATH);
        boolean acquice=false;
        try {
            // 尝试获取锁,阻塞直到获取锁成功  参数1 等待时间   参数2 等待时间单位 
            acquice=lock.acquire(1,TimeUnit.SECONDS);
            if(!acquice){
				return;
			}
            // 在这里执行需要加锁的业务逻辑
            System.out.println("Locked code block");

        } catch (Exception e) {
            e.printStackTrace();
        } finally {
          // 关闭 CuratorFramework 客户端
            curatorFramework.close();
            try {
               if(acquice){
               		 // 释放锁
                	lock.release();
               }
            } catch (Exception e) {
                e.printStackTrace();
            }
        }
    }
	//获取zookeeper连接
    private static CuratorFramework createCuratorFramework() {
        return CuratorFrameworkFactory.newClient(
                ZOOKEEPER_CONNECTION_STRING,
                new ExponentialBackoffRetry(1000, 3));
    }
}

四:优缺点对比

从性能角度(从高到低)来看:“缓存方式>Zookeeper方式>=数据库方式”。

  • 基于数据库实现分布式锁:
    优点:
    简单易实现,不需要引入额外的组件。
    使用数据库的事务特性,可以保证原子性。
    缺点:
    性能相对较差,因为每次加锁都要涉及到数据库的操作。
    可能会有死锁风险,需要谨慎处理事务隔离级别。
    对数据库的压力较大。

  • 基于缓存(Redis等)实现分布式锁:
    优点:
    性能较高,因为缓存系统通常能够提供快速的读写操作。
    可以设置锁的过期时间,避免死锁。
    缺点:
    对于分布式环境,需要确保缓存的高可用性。
    在某些情况下,可能会发生锁失效或过期的问题。
    不同缓存系统的实现方式和性能特性有差异。

  • 基于 ZooKeeper 实现分布式锁:
    优点:
    具备较好的一致性和可靠性,适用于需要高一致性的场景。
    可以利用 ZooKeeper 的顺序节点和监听机制实现较为复杂的锁管理。
    缺点:
    相对较为复杂,需要引入额外的组件。
    性能相对较低,ZooKeeper 的写入操作开销较大。
    部署和维护 ZooKeeper 集群可能较为复杂。

PS:文章如有不当之处,烦请后台私信,第一时间处理

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Springcloud和dubbo都是常用的微服务框架,它们各有优缺点。Springcloud具有更完整的生态系统,提供了更多的组件和工具,支持更多的协议和编程语言,适用于大型分布式系统的构建。而dubbo则更加轻量级,性能更好,适用于中小型分布式系统的构建。此外,Springcloud更加注重开发者的体验和易用性,而dubbo则更加注重性能和稳定性。因此,选择哪个框架应该根据具体的需求和场景来决定。 ### 回答2: Spring Cloud和Dubbo是当前比较流行的微服务框架,它们在很多方面有着相似之处,但也存在一些差异。 首先,就优点而言,Spring Cloud提供了众多的组件和库,可以轻松地构建和管理微服务架构。它基于Spring框架,具有较高的灵活性和开发效率,同时还支持各种服务注册和发现机制,如Eureka、Consul等。另外,Spring Cloud还提供了多种负载均衡、断路器、配置管理及分布式追踪等功能,方便开发人员进行服务治理和监控。此外,Spring Cloud与Spring Boot紧密集成,简化了配置和部署操作。 相比之下,Dubbo是一款由阿里巴巴开源的Java RPC框架,具有较高的性能和可靠性。Dubbo支持多种传输和协议,可根据需求选择最佳的通信方式,同时还提供了诸如负载均衡、集群容错、路由等高级特性,能够保证服务的高可用性和可扩展性。此外,Dubbo还支持服务治理和监控,可通过管理控制台进行服务的动态注册和查看。另外,Dubbo支持多种开发语言,适用于跨语言的分布式应用开发。 然而,Spring Cloud在某些方面也有优势。首先,Spring Cloud具有更广泛的社区支持,相关文档和教程较多,开发者可以更容易地找到解决方案。其次,Spring Cloud对于Spring系列已有的成熟技术栈有很好的整合,开发者可以无缝地切换模块。最后,Spring Cloud可以更好地与其他云原生技术结合使用,例如Kubernetes、Docker等。 综上所述,Spring Cloud和Dubbo都是优秀的微服务框架,各自在不同方面有所优势。选择合适的框架需要根据项目需求和团队技术栈来决定。 ### 回答3: Spring Cloud和Dubbo都是目前非常流行的分布式微服务框架,但它们在设计思想、特点和使用方式上有一些区别。 首先,Spring Cloud是基于Spring框架的开源微服务框架,它提供了一整套开发分布式系统的解决方案,包括服务注册与发现、服务调用、负载均衡、断路器、配置管理等。它采用的是HTTP协议作为通信协议,REST风格的接口设计。Spring Cloud具有更加灵活的架构,可以与各种开发语言和技术栈集成,适用于大部分的企业应用场景。 而Dubbo是阿里巴巴开源的高性能微服务框架,它基于RPC(Remote Procedure Call)协议进行通信,适用于Java开发。Dubbo除了提供了服务注册与发现、负载均衡等基本的功能,还支持分布式事务、服务治理、限流、降级等高级特性。Dubbo的性能非常高,适用于大规模、高并发的分布式系统。 对比两者的优点,Spring Cloud具有更高的灵活性和通用性,可以与各种技术栈集成,适用于不同的企业应用场景。它基于Spring框架,具有广泛的社区支持,生态系统更加成熟。而Dubbo在性能方面更加出色,适用于大规模的高并发系统。 缺点方面,Spring Cloud的学习曲线相对较陡峭,因为它的架构相对复杂,需要掌握更多的组件和概念。而Dubbo对于非Java语言的支持较弱,限制了它的适用场景。 综上所述,选择使用哪个微服务框架需要根据实际情况来决定。如果项目需要高性能、大规模并发处理的能力,适合选择Dubbo;如果需要更高的灵活性和通用性,适合选择Spring Cloud。当然,根据实际情况也可以将两者结合使用,根据需求场景灵活选择。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值