使用curator实现zookeeper锁服务的示例分享
来源:互联网 发布:c语言不输出无意义的0 编辑:程序博客网 时间:2024/06/01 08:27
这篇文章主要介绍了使用curator实现zookeeper锁服务的示例,需要的朋友可以参考下
import java.util.concurrent.CountDownLatch;import java.util.concurrent.ExecutorService;import java.util.concurrent.Executors;import java.util.concurrent.TimeUnit;import com.netflix.curator.RetryPolicy;import com.netflix.curator.framework.CuratorFramework;import com.netflix.curator.framework.CuratorFrameworkFactory;import com.netflix.curator.framework.recipes.locks.InterProcessMutex;import com.netflix.curator.retry.ExponentialBackoffRetry;public class TestCuratorLock { /** * @param args * @throws InterruptedException */ public static void main(String[] args) throws InterruptedException { // TODO Auto-generated method stub CountDownLatch latch = new CountDownLatch(5); String zookeeperConnectionString = "localhost:2181,localhost:2182,localhost:2183"; RetryPolicy retryPolicy = new ExponentialBackoffRetry(1000, 3); CuratorFramework client = CuratorFrameworkFactory.newClient( zookeeperConnectionString, retryPolicy); client.start(); System.out.println("客户端启动。。。。"); ExecutorService exec = Executors.newCachedThreadPool(); for (int i = 0; i < 5; i++) { exec.submit(new MyLock("client" + i, client, latch)); } exec.shutdown(); latch.await(); System.out.println("所有任务执行完毕"); client.close(); System.out.println("客户端关闭。。。。"); } static class MyLock implements Runnable { private String name; private CuratorFramework client; private CountDownLatch latch; public MyLock(String name, CuratorFramework client, CountDownLatch latch) { this.name = name; this.client = client; this.latch = latch; } public String getName() { return name; } public void setName(String name) { this.name = name; } @Override public void run() { // TODO Auto-generated method stub InterProcessMutex lock = new InterProcessMutex(client, "/test_group"); try { if (lock.acquire(120, TimeUnit.SECONDS)) { try { // do some work inside of the critical section here System.out.println("----------" + this.name + "获得资源----------"); System.out.println("----------" + this.name + "正在处理资源----------"); Thread.sleep(10 * 1000); System.out.println("----------" + this.name + "资源使用完毕----------"); latch.countDown(); } finally { lock.release(); System.out.println("----------" + this.name + "释放----------"); } } } catch (Exception e) { // TODO Auto-generated catch block e.printStackTrace(); } } } }
0 0
- 使用curator实现zookeeper锁服务的示例分享
- 利用curator实现的zookeeper分布式锁服务
- 利用curator实现的zookeeper分布式锁服务
- 利用curator实现的zookeeper分布式锁服务
- 利用curator实现的zookeeper分布式锁服务
- 利用curator实现的zookeeper分布式锁服务
- curator实现zookeeper的分布式锁
- Curator:ZooKeeper的分布式锁
- zookeeper之Curator框架(CRUD/事务/选举/锁)的使用
- Zookeeper实例Curator API-使用Curator的异步接口
- 使用Apache Curator实现服务的注册和发现
- curator实现zookeeper的领导选举
- Curator链接zookeeper实现分布式锁
- ZooKeeper客户端框架Curator实现屏障服务(Barrier)
- 使用curator操作zookeeper
- Zookeeper学习(Curator使用)
- 使用Curator操作ZooKeeper
- [curator] Netflix Curator 使用 Zookeeper 编程
- 来自一个朋友
- UNIX中信号量
- java访问mysql数据库的方法
- 使用EMOJI表情
- 如何停止iis
- 使用curator实现zookeeper锁服务的示例分享
- 一张图看懂AR至GL数据流
- HDU 1358 Period(kmp)
- 微信分享
- 解析皇家物流系统四大特色
- 手游真是一门烂生意
- 【思维导图】数据结构第三章 栈和队列
- 解说皇家物流系统功能
- 多核编程的几个难题及其应对策略