ZooKeeper共享锁怎么创建
发表于:2025-02-03 作者:千家信息网编辑
千家信息网最后更新 2025年02月03日,这篇文章主要介绍"ZooKeeper共享锁怎么创建",在日常操作中,相信很多人在ZooKeeper共享锁怎么创建问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答"ZooKe
千家信息网最后更新 2025年02月03日ZooKeeper共享锁怎么创建
这篇文章主要介绍"ZooKeeper共享锁怎么创建",在日常操作中,相信很多人在ZooKeeper共享锁怎么创建问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答"ZooKeeper共享锁怎么创建"的疑惑有所帮助!接下来,请跟着小编一起来学习吧!
众所周知,在Java开发中,要创建一个单进程锁非常简单,使用JDK中自带的java.util.concurrent.locks.Lock接口即可实现锁的功能。
如今已经到了大数据、云的时代,而这种锁已经无法满足集群服务间锁的需求了,本文将简单说下如何使用ZooKeeper来实现共享锁功能。至于什么是共享锁呢?理解起来也很简单:就是指在多个实例中使用同一把锁。(我好像废话了……)
同样闪亮登场的还是我们的Curator Framework,它封装了各种场景的锁,比如:共享锁、读写锁、可撤销锁等。
LockStartup.java
package org.bigmouth.common.zookeeper.shared; import java.util.concurrent.TimeUnit; import org.apache.curator.framework.CuratorFramework;import org.apache.curator.framework.recipes.locks.InterProcessSemaphoreMutex;import org.bigmouth.common.zookeeper.config.ZooKeeperFactory; public class LockStartup { public static void main(String[] args) throws Exception { CuratorFramework client = ZooKeeperFactory.get(); // ZooKeeperFactory在上一篇文章《ZooKeeper学习笔记-配置管理》中有 final InterProcessSemaphoreMutex processSemaphoreMutex = new InterProcessSemaphoreMutex(client, "/lock"); printProcess(processSemaphoreMutex); System.out.println("Starting get lock..."); boolean flag = processSemaphoreMutex.acquire(12, TimeUnit.SECONDS); System.out.println(flag ? "Getting lock successful." : "Getting failed!"); printProcess(processSemaphoreMutex); Thread.sleep(20 * 1000); if (processSemaphoreMutex.isAcquiredInThisProcess()) { processSemaphoreMutex.release(); } printProcess(processSemaphoreMutex); client.close(); } private static void printProcess(final InterProcessSemaphoreMutex processSemaphoreMutex) { // 在本进程中锁是否激活(是否正在执行) System.out.println("isAcquiredInThisProcess: " + processSemaphoreMutex.isAcquiredInThisProcess()); } }
启动LockStartup,得到如下结果:
接着再启动一个LockStartup实例,结果是无法获取到锁。程序还是会等待12秒,如果12秒后仍然无法获取到锁则结束:
如果我们把处理时间设置为10秒,等待时间为12秒。那么当第一个进程释放后,第二个进程将会获取到锁。
Thread.sleep(10 * 1000);
还有适合其他场景的共享锁就不一一做例子了,使用起来都类似。可以看下接口org.apache.curator.framework.recipes.locks.InterProcessLock的实现类。
到此,关于"ZooKeeper共享锁怎么创建"的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注网站,小编会继续努力为大家带来更多实用的文章!
学习
进程
功能
场景
实例
接口
时间
更多
篇文章
结果
还是
帮助
实用
众所周知
接下来
例子
多个
就是
废话
数据
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
数据库英文名叫什么
ML视频软件开发
健康生活APP软件开发
西安电视台网络安全宣传周
餐饮软件开发公司名字
非上市公司 数据库
ncbi数据库如何下载
艾马尔视频软件开发
数据库基础第三版课后习题答案
沈逸网络安全知乎
metascape数据库使用
数据库索引desc
医疗器械软件开发招聘
每日网络安全巡查记录表
桓台县网络安全与信息化办公室
拟退休人员数据库
数据库不安全因素有哪些
菏泽高速服务器
维普数据库二次检索步骤
无锡节能刀片服务器施工
广州顺志通网络技术有限公司
晴空服务器
网络安全全部教程
广联达net软件开发面试
数据库主机名怎么查
网络安全专业教师招聘
中专工资计算机网络技术
关于维护网络安全正确的说法是
l根服务器
育碧 服务器