基于数据库与基于ZooKeeper分布式锁的区别

本文涉及的产品
任务调度 XXL-JOB 版免费试用,400 元额度,开发版规格
服务治理 MSE Sentinel/OpenSergo,Agent数量 不受限
注册配置 MSE Nacos/ZooKeeper,118元/月
简介: 分布式锁是在分布式系统中用于实现多个节点之间的互斥访问共享资源的一种锁机制。它可以确保在分布式环境中的并发操作不会导致数据不一致或冲突。

下面是两种常见的分布式锁类型以及它们的底层原理和示例代码:

  1. 基于数据库的分布式锁:
    基于数据库的分布式锁通过数据库的事务机制来实现锁机制。它的基本思想是通过在数据库中插入一条唯一的记录作为锁,其他节点在获取锁时会尝试插入相同的记录,如果插入成功,则表示获取到了锁。
public class DatabaseLock {
    private DataSource dataSource;
    public boolean tryLock(String lockKey) {
        try (Connection connection = dataSource.getConnection()) {
            connection.setAutoCommit(false);
            PreparedStatement statement = connection.prepareStatement("INSERT INTO locks(lock_key) VALUES(?)");
            statement.setString(1, lockKey);
            try {
                statement.executeUpdate();
                connection.commit();
                return true;
            } catch (SQLException e) {
                connection.rollback();
                return false;
            }
        } catch (SQLException e) {
            return false;
        }
    }
    public void unlock(String lockKey) {
        try (Connection connection = dataSource.getConnection()) {
            connection.setAutoCommit(false);
            PreparedStatement statement = connection.prepareStatement("DELETE FROM locks WHERE lock_key = ?");
            statement.setString(1, lockKey);
            try {
                statement.executeUpdate();
                connection.commit();
            } catch (SQLException e) {
                connection.rollback();
            }
        } catch (SQLException e) {
            // 处理异常
        }
    }
}
  1. 基于ZooKeeper的分布式锁:
    基于ZooKeeper的分布式锁利用ZooKeeper的有序节点和监听机制来实现锁机制。每个节点在获取锁时会创建一个有序的临时节点,根据节点的顺序判断是否获取到了锁。如果节点的顺序最小,则表示获取到了锁。
public class ZooKeeperLock {
    private ZooKeeper zooKeeper;
    private String lockPath;
    private String currentPath;
    public boolean tryLock() {
        try {
            currentPath = zooKeeper.create(lockPath + "/lock_", null, ZooDefs.Ids.OPEN_ACL_UNSAFE, CreateMode.EPHEMERAL_SEQUENTIAL);
            List<String> children = zooKeeper.getChildren(lockPath, false);
            Collections.sort(children);
            String smallestPath = children.get(0);
            if (currentPath.equals(lockPath + "/" + smallestPath)) {
                return true;
            }
            CountDownLatch latch = new CountDownLatch(1);
            String previousPath = children.get(Collections.binarySearch(children, currentPath.substring(lockPath.length() + 1)) - 1);
            zooKeeper.exists(lockPath + "/" + previousPath, new Watcher() {
                @Override
                public void process(WatchedEvent event) {
                    if (event.getType() == Event.EventType.NodeDeleted) {
                        latch.countDown();
                    }
                }
            });
            latch.await();
            return true;
        } catch (Exception e) {
            return false;
        }
    }
    public void unlock() {
        try {
            zooKeeper.delete(currentPath, -1);
        } catch (Exception e) {
            // 处理异常
        }
    }
}

这两种分布式锁类型都有各自的优劣和适用场景。基于数据库的分布式锁简单易实现,但在高并发场景下性能可能不如基于ZooKeeper的分布式锁;而基于ZooKeeper的分布式锁具有高性能和强一致性的特点,但对ZooKeeper的依赖性较高。

总结起来,分布式锁是用于在分布式系统中实现互斥访问共享资源的一种锁机制。不同的分布式锁类型有不同的底层原理,可以根据实际需求选择合适的分布式锁实现。

相关实践学习
基于MSE实现微服务的全链路灰度
通过本场景的实验操作,您将了解并实现在线业务的微服务全链路灰度能力。
目录
相关文章
|
4月前
|
安全 应用服务中间件 API
微服务分布式系统架构之zookeeper与dubbo-2
微服务分布式系统架构之zookeeper与dubbo-2
|
4月前
|
负载均衡 Java 应用服务中间件
微服务分布式系统架构之zookeeper与dubbor-1
微服务分布式系统架构之zookeeper与dubbor-1
|
26天前
|
存储 SpringCloudAlibaba Java
【SpringCloud Alibaba系列】一文全面解析Zookeeper安装、常用命令、JavaAPI操作、Watch事件监听、分布式锁、集群搭建、核心理论
一文全面解析Zookeeper安装、常用命令、JavaAPI操作、Watch事件监听、分布式锁、集群搭建、核心理论。
【SpringCloud Alibaba系列】一文全面解析Zookeeper安装、常用命令、JavaAPI操作、Watch事件监听、分布式锁、集群搭建、核心理论
|
2月前
|
存储 运维 NoSQL
分布式读写锁的奥义:上古世代 ZooKeeper 的进击
本文作者将介绍女娲对社区 ZooKeeper 在分布式读写锁实践细节上的思考,希望帮助大家理解分布式读写锁背后的原理。
|
2月前
|
消息中间件 运维 数据库
Seata框架和其他分布式事务框架有什么区别
Seata框架和其他分布式事务框架有什么区别
42 1
|
2月前
|
关系型数据库 分布式数据库 数据库
PostgreSQL+Citus分布式数据库
PostgreSQL+Citus分布式数据库
87 15
|
2月前
|
存储 分布式计算 负载均衡
分布式计算模型和集群计算模型的区别
【10月更文挑战第18天】分布式计算模型和集群计算模型各有特点和优势,在实际应用中需要根据具体的需求和条件选择合适的计算架构模式,以达到最佳的计算效果和性能。
96 2
|
3月前
|
SQL 关系型数据库 分布式数据库
Citus 简介,将 Postgres 转换为分布式数据库
【10月更文挑战第4天】Citus 简介,将 Postgres 转换为分布式数据库
141 4
|
3月前
|
分布式计算 NoSQL Java
Hadoop-32 ZooKeeper 分布式锁问题 分布式锁Java实现 附带案例和实现思路代码
Hadoop-32 ZooKeeper 分布式锁问题 分布式锁Java实现 附带案例和实现思路代码
72 2
|
3月前
|
分布式计算 Hadoop
Hadoop-27 ZooKeeper集群 集群配置启动 3台云服务器 myid集群 zoo.cfg多节点配置 分布式协调框架 Leader Follower Observer
Hadoop-27 ZooKeeper集群 集群配置启动 3台云服务器 myid集群 zoo.cfg多节点配置 分布式协调框架 Leader Follower Observer
71 1

热门文章

最新文章