zoukankan      html  css  js  c++  java
  • canal client leader

    //选举

    RetryPolicy retryPolicy = new ExponentialBackoffRetry(1000, 3);  

            CuratorFramework client = CuratorFrameworkFactory.builder().connectString(zookeeper).sessionTimeoutMs(5000).connectionTimeoutMs(3000).retryPolicy(retryPolicy).namespace("canalClient").build();  

            client.start();  

            

            IszLogger.error("=====");

            CanalConnector connector = getCanalConnector(connectorType);

    connector.connect();

    connector.subscribe(subscribeReg);

    IszLogger.error("*****");

     

            // 选举Leader 启动  

            @SuppressWarnings("resource")

    final LeaderLatch latch = new LeaderLatch(client,"/canalClient");

              latch.addListener(new LeaderLatchListener() {        

                 public void isLeader() {

                 //启动监听

                 IszLogger.error("leader==============");

              subscribeAndDealCanal();

                 }              

                 public void notLeader() {

                 IszLogger.error("not leader==============");

                 }

             });          

             try {

             latch.start(); 

             IszLogger.error("start阻塞==============");

    latch.await();

    IszLogger.error("通过阻塞================");

    } catch (Exception e) {

    e.printStackTrace();

    }

  • 相关阅读:
    HttpApplication处理对象与HttpModule处理模块
    HttpHandler与HttpModule的用处与区别
    ASP.NET管线与应用程序生命周期
    IIS架构与HTTP请求处理流程
    构造函数的选择与服务生命周期管理
    堆排序
    WebApi异常
    Java NIO内存映射---上G大文件处理(转)
    Spring+Mybatis+SpringMVC后台与前台分页展示实例(附工程)(转)
    redis入门(转)
  • 原文地址:https://www.cnblogs.com/lovlos/p/7237957.html
Copyright © 2011-2022 走看看