ZK分布式锁框架curator

ZK分布式框架Curator


一、导入依赖

	    <dependency>
            <groupId>org.apache.curator</groupId>
            <artifactId>curator-framework</artifactId>
            <version>5.1.0</version>
        </dependency>
        <dependency>
            <groupId>org.apache.curator</groupId>
            <artifactId>curator-recipes</artifactId>
            <version>5.1.0</version>
        </dependency>
        <dependency>
            <groupId>org.apache.curator</groupId>
            <artifactId>curator-client</artifactId>
            <version>5.1.0</version>
        </dependency>

二、 编码

package com.czm.curator;

import org.apache.curator.framework.CuratorFramework;
import org.apache.curator.framework.CuratorFrameworkFactory;
import org.apache.curator.framework.recipes.locks.InterProcessMultiLock;
import org.apache.curator.framework.recipes.locks.InterProcessMutex;
import org.apache.curator.retry.ExponentialBackoffRetry;
import org.apache.curator.shaded.com.google.common.collect.Interners;
import org.junit.jupiter.api.Test;

import java.util.concurrent.CountDownLatch;

/**
 * 使用Curator框架实现ZK分布式锁
 */
public class CuratorTest {

    private String connectAddr = "192.168.31.104:2181";
    private int timeout = 20000;

    private CuratorFramework connect(){
        CuratorFramework zkClient = CuratorFrameworkFactory.builder().connectString("192.168.31.104:2181")
                .connectionTimeoutMs(20000)
                .retryPolicy(new ExponentialBackoffRetry(2000, 3))
                .build();
        zkClient.start();
        return zkClient;

    }
    @Test
    public void main() throws InterruptedException {
        InterProcessMutex lock_1 = new InterProcessMutex(connect(), "/zk");
        InterProcessMutex lock_2 = new InterProcessMutex(connect(), "/zk");

        CountDownLatch latch = new CountDownLatch(2);
        Thread thread_1= new Thread(() -> {
            try {
                lock_1.acquire();
                System.out.println("thread1获得锁");
                lock_1.acquire();
                System.out.println("thread1再次获得锁");
                Thread.sleep(5000);
                lock_1.release();
                System.out.println("thread1释放锁");
                lock_1.release();
                System.out.println("thread1再次释放锁");
                latch.countDown();
            } catch (Exception e) {
                e.printStackTrace();
            }
        });
        Thread thread_2 = new Thread(() -> {
            try {
                lock_1.acquire();
                System.out.println("thread2获得锁");
                lock_1.acquire();
                System.out.println("thread2再次获得锁");
                Thread.sleep(5000);
                lock_1.release();
                System.out.println("thread2释放锁");
                lock_1.release();
                System.out.println("thread2再次释放锁");
                latch.countDown();
            } catch (Exception e) {
                e.printStackTrace();
            }
        });
        thread_1.start();
        thread_2.start();
        latch.await();
    }
}

总结

提示:这里对文章进行总结:
例如:以上就是今天要讲的内容,本文仅仅简单介绍了pandas的使用,而pandas提供了大量能使我们快速便捷地处理数据的函数和方法。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值