首页 > 其他 > 详细

Curator实现分布式锁

时间:2015-09-09 17:46:07      阅读:342      评论:0      收藏:0      [点我收藏+]
public static void main (String[] args) {
    String servers = "10.128.7.20:2181,10.128.7.20:2182,10.128.7.20:2183";
    CuratorFramework curator = CuratorFrameworkFactory.builder().retryPolicy(new ExponentialBackoffRetry(10000, 3)).connectString(servers).build();
    curator.start();
    final InterProcessMutex lock = new InterProcessMutex(curator, "/global_lock");

    Executor pool = Executors.newFixedThreadPool(10);
    for (int i = 0; i < 10; i ++) {
        pool.execute(new Runnable() {
            public void run() {
                try {
                    lock.acquire();
                    System.out.println(Thread.currentThread().getName());
                    TimeUnit.SECONDS.sleep(5);
                } catch (Exception e) {
                    e.printStackTrace();
                }finally{
                    try {
                        lock.release();
                    } catch (Exception e) {
                        e.printStackTrace();
                    }
                }
            }
        });
    }


}


Curator实现分布式锁

原文:http://my.oschina.net/u/2250599/blog/503807

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!