利用curator实现的zookeeper分布式锁服务
来源:互联网 发布:java未来 编辑:程序博客网 时间:2024/05/16 12:34
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();
}
}
}
}
- 利用curator实现的zookeeper分布式锁服务
- 利用curator实现的zookeeper分布式锁服务
- 利用curator实现的zookeeper分布式锁服务
- 利用curator实现的zookeeper分布式锁服务
- 利用curator实现的zookeeper分布式锁服务
- curator实现zookeeper的分布式锁
- Curator:ZooKeeper的分布式锁
- Curator链接zookeeper实现分布式锁
- 使用curator实现zookeeper锁服务的示例分享
- 利用ZooKeeper服务实现分布式系统的Leader选举
- curator框架对zookeeper分布式的锁全局同步的实现
- zookeeper实现分布式锁服务
- zookeeper分布式共享锁curator案例
- Zookeeper实例Curator API-分布式锁
- Zookeeper框架Curator之分布式锁-yellowcong
- redis 实现 curator 分布式锁
- 五.Curator实现分布式锁
- zookeeper第三方库curator即可方便地实现分布式锁
- cocos setPosition 之坑
- 深度学习:Imagenet Object Classification方法
- 深度解析gRPC以及京东分布式服务框架跨语言实战
- APP定制开发的完整流程
- $.each遍历对象、数组的属性值并进行处理
- 利用curator实现的zookeeper分布式锁服务
- PowerDesigner(四)-业务处理模型使用
- 将某列合并成字符串
- ubuntu 挂在smb服务器的方法
- PAT乙级 部分A+B
- 怎么解决BarTender因为未检测到IIS安装失败的问题
- Android WebRTC 音视频开发(二)-- webrtcdemo介绍
- 代码分析
- myeclipse序列号注册码生成Java代码 MyEclipseGen