十年网站开发经验 + 多家企业客户 + 靠谱的建站团队
量身定制 + 运营维护+专业推广+无忧售后,网站问题一站解决
这篇文章主要介绍“Curator的分布式Barrier怎么实现”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Curator的分布式Barrier怎么实现”文章能帮助大家解决问题。

创新互联是一家成都做网站、成都网站建设,提供网页设计,网站设计,网站制作,建网站,按需网站开发,网站开发公司,自2013年创立以来是互联行业建设者,服务者。以提升客户品牌价值为核心业务,全程参与项目的网站策划设计制作,前端开发,后台程序制作以及后期项目运营并提出专业建议和思路。
分布式Barrier,直接看代码好了:
package curator.barrier;
import java.util.ArrayList;
import java.util.List;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
import org.apache.curator.RetryPolicy;
import org.apache.curator.framework.CuratorFramework;
import org.apache.curator.framework.CuratorFrameworkFactory;
import org.apache.curator.framework.recipes.barriers.DistributedBarrier;
import org.apache.curator.retry.ExponentialBackoffRetry;
public class BarrierDemo {
public static void main(String[] args) throws Exception {
final List barriers = new ArrayList(3);
ExecutorService service = Executors.newCachedThreadPool();
for (int i = 0; i < 3; i++) {
Runnable run = new Runnable() {
public void run() {
try {
RetryPolicy retryPolicy = new ExponentialBackoffRetry(
1000, 3);
final CuratorFramework client = CuratorFrameworkFactory
.builder().connectString("127.0.0.1:2181")
.sessionTimeoutMs(5000)
.connectionTimeoutMs(10000)
.retryPolicy(retryPolicy).namespace("text")
.build();
client.start();
DistributedBarrier barrier = new DistributedBarrier(client, "/barrier");
barriers.add(barrier);
barrier.setBarrier(); // 设置barrier
System.out.println(" : setBarrier...");
barrier.waitOnBarrier();// 等待其他进程移除barrier,此后所有的waitOnBarrier进程都将解除阻塞.
System.err.println(" : run ing...");
} catch (Exception e) {
}
}
};
service.execute(run);
}
Thread.currentThread().sleep(5000);
for (DistributedBarrier b : barriers) {
b.removeBarrier();
}
System.in.read();
}
} 关于“Curator的分布式Barrier怎么实现”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识,可以关注创新互联行业资讯频道,小编每天都会为大家更新不同的知识点。