文档章节

利用zookeeper 实现分布式锁

w
 wannshan
发布于 2017/02/23 15:25
字数 379
阅读 48
收藏 1

利用Curator(流行的 zk 客户端工具包) 的 InterProcessMute 类


import org.apache.curator.framework.CuratorFramework;
import org.apache.curator.framework.CuratorFrameworkFactory;
import org.apache.curator.framework.recipes.locks.InterProcessLock;
import org.apache.curator.framework.recipes.locks.InterProcessMutex;
import org.apache.curator.retry.ExponentialBackoffRetry;

import java.util.Random;
import java.util.concurrent.CountDownLatch;

/**
 * 文件功能:zookeeper分布式锁
 * 故事:5个线程(模拟分布式进程)争夺分布式锁
 */
public class CuratorLocksExample {

    private static  InterProcessLock distributeLock=null;
    private static CountDownLatch count=new CountDownLatch(5);

    public static void main(String[] args) {
        CuratorFramework client = CuratorFrameworkFactory.newClient("192.168.64.128:2181", new ExponentialBackoffRetry(1000, 3));
        client.start();
        distributeLock=new InterProcessMutex(client,"/mylock");
        for(int i=0;i<5;i++){
            new Thread(new MyHostThread("线程"+i,client,distributeLock,count)).start();
        }

        try {
            count.await();
        } catch (InterruptedException e) {
            e.printStackTrace();
        }finally {
            System.out.println("释放客户端,断开zk连接");
            client.close();
        }

    }
}


class MyHostThread implements Runnable{

    private String name;
    private CuratorFramework client;
    private InterProcessLock lock;
    private  CountDownLatch count;
    public MyHostThread(String name,CuratorFramework client,InterProcessLock lock,CountDownLatch count){
        this.name=name;
        this.client=client;
        this.lock=lock;
        this.count=count;
    }

    @Override
    public void run() {
        System.out.println(this.name + "开始竞争锁");
        try {
            lock.acquire();//阻塞等待..
            System.out.println(this.name + "获取到锁");
            Thread.sleep(new Random().nextInt(2000));//模拟业务处理2s内
        } catch (Exception e) {
            e.printStackTrace();
        }finally {
            try {
                System.out.println(this.name + "业务处理完,释放锁");
                lock.release();//释放锁
                count.countDown();
            } catch (Exception e) {
                e.printStackTrace();
            }
        }
    }
}

预期输出:

线程3开始竞争锁
线程0开始竞争锁
线程4开始竞争锁
线程1开始竞争锁
线程2开始竞争锁
线程0获取到锁
线程0业务处理完,释放锁
线程4获取到锁
线程4业务处理完,释放锁
线程1获取到锁
线程1业务处理完,释放锁
线程3获取到锁
线程3业务处理完,释放锁
线程2获取到锁
线程2业务处理完,释放锁
释放客户端,断开zk连接

© 著作权归作者所有

共有 人打赏支持
w
粉丝 19
博文 42
码字总数 79122
作品 0
浦东
技术主管
分布式锁与实现(二)基于ZooKeeper实现

引言 ZooKeeper是一个分布式的,开放源码的分布式应用程序协调服务,是Google的Chubby一个开源的实现,是Hadoop和Hbase的重要组件。它是一个为分布式应用提供一致性服务的软件,提供的功能包...

rechardchensir
10/08
0
0
分布式设计与开发(三)------高一致性服务ZooKeeper

分布式环境中大多数服务是允许部分失败,也允许数据不一致,但有些最基础的服务是需要高可靠性,高一致性的,这些服务是其他分布式服务运转的基础,比如naming service、分布式lock等,这些分...

山哥
2012/03/19
0
0
分布式锁与实现(二)——基于ZooKeeper实现

ZooKeeper是一个分布式的,开放源码的分布式应用程序协调服务,是Google的Chubby一个开源的实现,是Hadoop和Hbase的重要组件。它是一个为分布式应用提供一致性服务的软件,提供的功能包括:配...

刘祖鹏
05/08
0
0
分布式利器Zookeeper(三)

前言 《分布式利器Zookeeper(一)》 《分布式利器Zookeeper(二):分布式锁》 本篇博客是分布式利器Zookeeper系列的最后一篇,涉及的话题是:Zookeeper分布式锁的代码实现、zkclient的使用、...

zfz_linux_boy
07/01
0
0
ZooKeeper学习第四期---构建ZooKeeper应用

一、配置服务 配置服务是分布式应用所需要的基本服务之一,它使集群中的机器可以共享配置信息中那些公共的部分。简单地说,ZooKeeper可以作为一个具有高可用性的配置存储器,允许分布式应用的...

卯金刀GG
2017/10/25
0
0

没有更多内容

加载失败,请刷新页面

加载更多

使用JavaScript ES6的新特性计算Fibonacci(非波拉契数列)

程序员面试系列 Java面试系列-webapp文件夹和WebContent文件夹的区别? 程序员面试系列:Spring MVC能响应HTTP请求的原因? Java程序员面试系列-什么是Java Marker Interface(标记接口) 使...

JerryWang_SAP
8分钟前
0
0
docker安装redis、mongodb、mysql等

一、启动docker服务,设置镜像: systemctl start dockervi /etc/docker/daemon.json{ "registry-mirrors": ["https://registry.docker-cn.com"]} 二、下拉镜像: 在镜像中心h...

狼王黄师傅
32分钟前
0
0
deepin系统使用deepin-wine安装exe程序

deepin自带原生deepin-wine使用命令如下: deepin-wine QQBrowser.exedeepin-wine QQMusicSetup.exe 默认安装的快捷方式位置: /root/.wine/drive_c/'Program Files'/Tencent/QQBrowser/......

临江仙卜算子
56分钟前
4
0
快速get到学习Linux操作系统的点

快速get到学习Linux操作系统的点 Linux是一套免费使用和自由传播的类Unix操作系统,是一个基于POSIX和UNIX的多用户、多任务、支持多线程和多CPU的操作系统。Linux能够运行主要的UNIX工具软件...

linuxCool
今天
3
0
聊聊:Linux分区的那些方案

安装linux的整体步骤其实比较简单,唯一可能值得说明的地方,大概就是linux的分区了。 下面来给大家推荐一些分区方案。 1 分两个区 实际上,很多时候我们只需要分两个区:`/`和交换分区,日常...

Linux就该这么学
今天
3
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部