1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33
   | package com.bai.curator.scene;
  import org.apache.curator.framework.CuratorFramework; import org.apache.curator.framework.CuratorFrameworkFactory; import org.apache.curator.framework.recipes.leader.LeaderSelector; import org.apache.curator.framework.recipes.leader.LeaderSelectorListenerAdapter; import org.apache.curator.retry.ExponentialBackoffRetry;
  import java.util.concurrent.TimeUnit;
 
 
 
  public class MasterSelector {
      private final static String CONNECTSTRING = "";     private final static String MASTER_PATH="/curator_master_path";
      public static void main(String[] args) {         CuratorFramework curatorFramework = CuratorFrameworkFactory.builder().connectString(CONNECTSTRING).retryPolicy(new ExponentialBackoffRetry(1000,3)).build();         LeaderSelector leaderSelector=new LeaderSelector(curatorFramework, MASTER_PATH, new LeaderSelectorListenerAdapter() {             @Override             public void takeLeadership(CuratorFramework curatorFramework) throws Exception {                 System.out.println("获得leader成功");                 TimeUnit.SECONDS.sleep(2);             }         });                  leaderSelector.autoRequeue();                  leaderSelector.start();     } }
   |