手写Zookeeper分布式锁

zookeeper版本:zookeeper-3.4.13,该版本原生api不支持递归创建节点

依赖
<dependency><groupId>org.apache.zookeeper</groupId><artifactId>zookeeper</artifactId><version>3.4.13</version>
</dependency>
Zookeeper分布式锁编写
import org.apache.zookeeper.*;import java.io.IOException;
import java.util.concurrent.CountDownLatch;/*** zk实现分布式锁*/
public class ZkLock {// zk实例private ZooKeeper zooKeeper;// 计数器,启动一个线程private static final CountDownLatch downLatch = new CountDownLatch(1);/*** 加锁操作** @param id*/public void lock(Integer id) {// 节点路径String path = "/fluyi-product-lock-" + id;// 创建节点,一定要是临时节点,防止宕机无法释放节点try {zooKeeper.create(path, "".getBytes(), ZooDefs.Ids.OPEN_ACL_UNSAFE, CreateMode.EPHEMERAL);} catch (Exception e) {// 加锁失败,再次尝试while (true) {// 休眠5秒try {Thread.sleep(5000);} catch (Exception ex) {ex.printStackTrace();}// 进行重连try {zooKeeper.create(path, "".getBytes(), ZooDefs.Ids.OPEN_ACL_UNSAFE, CreateMode.EPHEMERAL);} catch (Exception ex) {continue;}break;}}}/*** 解锁操作** @param id*/public void unlock(Integer id) {String path = "/fluyi-product-lock-" + id;// 任何版本try {zooKeeper.delete(path, -1);} catch (Exception e) {e.printStackTrace();}}// 获取实例public static ZkLock getInstance() {return Sington.getInstance();}// 初始化private ZkLock() {try {zooKeeper = new ZooKeeper("xxx.xxx.xxx.xxx:2181", 50000, new zkWatch());try {downLatch.await();} catch (InterruptedException e) {e.printStackTrace();}System.out.println("建立连接=》" + zooKeeper.getState());} catch (IOException e) {e.printStackTrace();}}private static class zkWatch implements Watcher {@Overridepublic void process(WatchedEvent watchedEvent) {System.out.println("接受监听事件" + watchedEvent);// 进行连接if (watchedEvent.getState() == Event.KeeperState.SyncConnected) {// 连接成功downLatch.countDown();}}}// 单例private static class Sington {private static ZkLock zkLock;static {zkLock = new ZkLock();}private static ZkLock getInstance() {return zkLock;}}
}
测试使用
public class UnSafeThread {private static int num = 0;private static ZkLock zkLock = ZkLock.getInstance();/*** 创建10个线程*/private static CountDownLatch countDownLatch = new CountDownLatch(10);public static void incr() {zkLock.lock(1);num++;System.out.println(num);zkLock.unlock(1);}public static void main(String[] args) {for (int i = 0; i < 10; i++) {new Thread(() -> {for (int j = 0; j < 100; j++) {incr();// 短暂休眠try {Thread.sleep(10);} catch (InterruptedException e) {throw new RuntimeException(e);}countDownLatch.countDown();}}).start();}while (true) {if (countDownLatch.getCount() == 0) {System.out.println(num);break;}}}
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/pingmian/15670.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

深入理解Nginx try_files:用途、使用场景、注意事项和示例

Nginx 是高性能的 HTTP 和反向代理服务器&#xff0c;而 try_files 是其功能强大的模块之一。try_files 指令用于定义一组文件或 URI&#xff0c;Nginx 将依次检查这些文件或 URI&#xff0c;直到找到一个存在并可访问的文件或 URI。本文将深度解析 try_files 的用途、使用场景…

11.jenkins调整上线的脚本实现tag方式上线

jenkins调整上线的脚本实现tag方式上线 多次打标签重新提交到gitlab远程仓库-基于multi-line string parameter 修改脚本html_deploy_tar.sh #!/usr/bin/bashDate$(date %F-%H-%M) web_server"192.168.111.22 192.168.111.23" Name${Date}-${git_version} code_t…

网络模型-路由策略

一、路由策略 路由策略(Routing Policy)作用于路由&#xff0c;主要实现了路由过滤和路由属性设置等功能&#xff0c;它通过改变路由属性(包括可达性)来改变网络流量所经过的路径。目的:设备在发布、接收和引入路由信息时&#xff0c;根据实际组网需要实施一些策略&#xff0c…

Spring Boot 3.3新特性发布

Spring Boot 3.3 现已正式发布&#xff01;此版本包含大量更新&#xff0c;包括多项新功能。我们决定进行一些挑选&#xff0c;并查看最重要的变化&#xff0c;其中包括对类数据共享 (CDS) 的支持&#xff0c;以加快应用程序启动速度。 1.新的服务连接 Spring Boot 中改进或添…

MathType安装以及要点和难点

MathType是一款专业的数学公式编辑器,主要用于在文档中输入复杂的数学、物理公式和符号。以下是关于MathType的一些主要特点和功能: 1.定义设置:在MathType的“样式-定义”中,可以对数学、文本、函数、变量等不同类型进行定义。定义好之后,后续在公式编辑的时候,可以根据…

笔记89:LeetCode_135_分发糖果

前言&#xff1a; 注&#xff1a;代码随想录中没有很清楚的提起想出方法的思路&#xff0c;只是给出了解决这个问题的大致思路和代码&#xff1b;下面我将介绍一下我的思考过程&#xff0c;并贴出实现代码&#xff1b; a a a a 思考过程&#xff1a; 思路1&#xff1a;为了…

【实际项目精选源码】ehr人力资源管理系统实现案例(java,vue)

一、项目介绍 一款全源码可二开&#xff0c;可基于云部署、私有部署的企业级数字化人力资源管理系统&#xff0c;涵盖了招聘、人事、考勤、绩效、社保、酬薪六大模块&#xff0c;解决了从人事招聘到酬薪计算的全周期人力资源管理&#xff0c;符合当下大中小型企业组织架构管理运…

Gateway配置教程

Spring Cloud Gateway 是 Spring Cloud 的一个全新项目&#xff0c;它基于 Spring 5.0、Spring Boot 2.x 和 Project Reactor 等技术开发的网关&#xff0c;旨在提供一种简单、有效、统一的 API 路由管理方式。以下是 Spring Cloud Gateway 的基本配置步骤&#xff1a; 1. 添加…

Spring Boot 如何使用 AOP 防止重复提交

在 Spring Boot 中&#xff0c;可以使用 AOP&#xff08;面向切面编程&#xff09;来防止重复提交。通过 AOP&#xff0c;可以在方法调用前后添加额外的逻辑&#xff0c;而不需要修改方法本身的代码。下面是一个基于 AOP 的解决方案&#xff1a; 使用 AOP 防止重复提交 步骤&…

docker-compose Install homer

homer前言 一个非常简单的静态主页,为您的服务器保持您的服务在手,从一个简单的yaml配置文件。 前提要求 安装 docker docker-compose 参考创建一键安装homer 脚本 homer安装位置/homerhomer 脚本位置/homer/assetshomer logo 图标/home/assets/iconshomer 端口80homer 颜色…

运维 之 大文件分片刻录光盘

需求 因有些企业中涉及设备只能通过光盘介质方式拷贝文件&#xff0c;然而采购的单张光盘又不能确保存放下一些较大的文件&#xff0c;所以只能通过分片的方式逐个光盘存储。 Windows处理 1、安装压缩软件&#xff08;自行选择&#xff0c;这里使用WinRAR&#xff09;、Ultr…

vue项目input框使用lodash的debounce防抖

1、安装lodash工具 npm install lodash2、引入 import _ from lodash3、使用debounce处理防抖 // template <el-input placeholder"请输入名称" v-model"key" input"handleInput"> </el-input>methods:{handleInput: _.debounce…

HTML静态网页成品作业(HTML+CSS)——企业酒店官网网页(5个页面)

&#x1f389;不定期分享源码&#xff0c;关注不丢失哦 文章目录 一、作品介绍二、作品演示三、代码目录四、网站代码HTML部分代码 五、源码获取 一、作品介绍 &#x1f3f7;️本套采用HTMLCSS&#xff0c;未使用Javacsript代码&#xff0c;共有5个页面。 二、作品演示 三、代…

FuTalk设计周刊-Vol.053

#AI漫谈 热点捕手 1.Midjourney推出新功能Room 用户可在聊天室中一起创作图像 Midjourney最近推出了一个有趣的新功能——Room&#xff0c;为用户提供了一个协作和社交平台&#xff0c;用户可以一起创建和分享图像&#xff0c;并参与实时聊天。Room促进了用户之间的互动和合作…

C语言 | Leetcode C语言题解之第111题二叉树的最小深度

题目&#xff1a; 题解&#xff1a; typedef struct {int val;struct TreeNode *node;struct queNode *next; } queNode;void init(queNode **p, int val, struct TreeNode *node) {(*p) (queNode *)malloc(sizeof(queNode));(*p)->val val;(*p)->node node;(*p)->…

CentOS 7安装alertmanager

说明&#xff1a;本文介绍如何在CentOS 7安装alertmanager&#xff1b; Step1&#xff1a;下载安装包 访问Github仓库&#xff0c;下载对应版本的alertmanager安装包 https://github.com/prometheus/alertmanager/releases 如何查看自己系统的信息&#xff0c;可参考下图中的…

AI播客下载:The Logan Bartlett Show Podcast(AI创业投资主题)

Logan Bartlett Show Podcast是一个播客&#xff0c;主持人Logan Bartlett与科技界的领导者以及投资者进行对话&#xff0c;讨论他们在运营或投资企业中学到的经验教训&#xff0c;主要集中在科技创投领域。 Logan Bartlett 是 Redpoint Ventures 的投资人&#xff0c;并且在该…

LVGL里tileview的使用与隐藏滚动条

使用环境&#xff1a; LVGLV8.3 vs2019模拟器。与freertos集成。去我上传的资源里找。 解决方法&#xff1a; /** 需要实现的功能&#xff1a; 使用tileview控件&#xff0c;并创建两个tile&#xff0c;左右排列。通过左右滑动&#xff0c;可以相互切换。 **/ /************…

【DZ模板】克米设计APP手机版本地化+完美使用

模版介绍 【DZ模板】价值288克米设计APP手机版DZ模板 数据本地化完美使用 腾讯官方出品discuz论坛DIY的后台设置&#xff0c;功能齐全&#xff0c;论坛功能不亚于葫芦侠&#xff0c;自定义马甲&#xff0c;自定义认证&#xff0c;自定义广告&#xff0c;完全可以打造出自己想…

SW 弯曲找方向

当旋转弯曲轴的时候,半径和角度 越和理论的接近,越接近(只要输入角度,然后旋转弯曲轴,看半径跟随的变化值)