国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > Java > 正文

使用curator實現zookeeper鎖服務的示例分享

2019-11-26 15:40:20
字體:
來源:轉載
供稿:網友

復制代碼 代碼如下:

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();
   }
   }
 }
 }

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 隆安县| 石嘴山市| 革吉县| 新化县| 凌海市| 迁安市| 漾濞| 噶尔县| 额济纳旗| 东平县| 沙雅县| 九江县| 纳雍县| 吐鲁番市| 平顶山市| 若羌县| 杭州市| 金堂县| 樟树市| 镇平县| 景泰县| 西乌珠穆沁旗| 囊谦县| 河间市| 霍林郭勒市| 东阿县| 丹阳市| 乡宁县| 扎鲁特旗| 时尚| 卢氏县| 青神县| 洪雅县| 五家渠市| 龙海市| 林州市| 星子县| 盐亭县| 九龙坡区| 安乡县| 宜川县|