當前位置: 首頁>>代碼示例>>Java>>正文


Java ConnectionState.CONNECTED屬性代碼示例

本文整理匯總了Java中org.apache.curator.framework.state.ConnectionState.CONNECTED屬性的典型用法代碼示例。如果您正苦於以下問題:Java ConnectionState.CONNECTED屬性的具體用法?Java ConnectionState.CONNECTED怎麽用?Java ConnectionState.CONNECTED使用的例子?那麽, 這裏精選的屬性代碼示例或許可以為您提供幫助。您也可以進一步了解該屬性所在org.apache.curator.framework.state.ConnectionState的用法示例。


在下文中一共展示了ConnectionState.CONNECTED屬性的13個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: stateChanged

@Override
public void stateChanged(CuratorFramework client, ConnectionState newState) {
    if (newState == ConnectionState.CONNECTED) {
        isConnected.set(true);
        if (!isFirstConnection.get()) {
            for (ConnectionStateListener listener : listenerStateProxy.getListeners()) {
                listener.stateChanged(client, ConnectionState.RECONNECTED);
            }
        }
        return;
    }

    if (newState == ConnectionState.LOST) {
        isConnected.set(false);
        isFirstConnection.set(false);
        retryConnection();
    }
}
 
開發者ID:Comcast,項目名稱:redirector,代碼行數:18,代碼來源:RedirectorCuratorFramework.java

示例2: destroy

@Override
public void destroy() {
    if (connectionState == ConnectionState.CONNECTED) {
        for (ServiceDescription service : services.values()) {
            String path = pathForProvider(service.getName(), service.getId());
            try {
                client.delete().forPath(path);
            } catch (Exception ignore) {
                // ignore
            }
        }
    }
    services.clear();

    client.getConnectionStateListenable().removeListener(connectionStateListener);
    client.close();
}
 
開發者ID:dinstone,項目名稱:jrpc,代碼行數:17,代碼來源:ZookeeperServiceRegistry.java

示例3: stateChanged

@Override
public void stateChanged(CuratorFramework client, ConnectionState newState)
{
    if ( (newState == ConnectionState.RECONNECTED) || (newState == ConnectionState.CONNECTED) )
    {
        try
        {
            log.debug("Re-registering due to reconnection");
            reRegisterServices();
        }
        catch (InterruptedException ex)
        {
            Thread.currentThread().interrupt();
        }
        catch ( Exception e )
        {
            log.error("Could not re-register instances after reconnection", e);
        }
    }
}
 
開發者ID:apache,項目名稱:curator,代碼行數:20,代碼來源:ServiceDiscoveryImpl.java

示例4: stateChanged

@Override
public void stateChanged(CuratorFramework client, ConnectionState newState) {
  if(newState == ConnectionState.CONNECTED) {
    ZKClusterCoordinator.this.initialConnection.countDown();
    client.getConnectionStateListenable().removeListener(this);
  }
}
 
開發者ID:skhalifa,項目名稱:QDrill,代碼行數:7,代碼來源:ZKClusterCoordinator.java

示例5: isConnected

@Override
public boolean isConnected() {
    return client != null && client.isStarted() &&
            currentConnectionState != null &&
            (currentConnectionState == ConnectionState.CONNECTED ||
            currentConnectionState == ConnectionState.RECONNECTED);
}
 
開發者ID:Comcast,項目名稱:redirector,代碼行數:7,代碼來源:ZookeeperConnector.java

示例6: checkConnection

private void checkConnection() throws KeeperException.ConnectionLossException {
    if (client != null &&
            currentConnectionState != null &&
            currentConnectionState != ConnectionState.CONNECTED &&
            currentConnectionState != ConnectionState.RECONNECTED) {

        KeeperException.ConnectionLossException exception = new KeeperException.ConnectionLossException();
        Metrics.reportZookeeperConnectionIssue(exception);
        throw exception;
    }
}
 
開發者ID:Comcast,項目名稱:redirector,代碼行數:11,代碼來源:ZookeeperConnector.java

示例7: stateChanged

@Override
public void stateChanged(CuratorFramework client, ConnectionState newState) {
  if(newState == ConnectionState.CONNECTED) {
    ZKClusterClient.this.initialConnection.countDown();
    client.getConnectionStateListenable().removeListener(this);
  }
}
 
開發者ID:dremio,項目名稱:dremio-oss,代碼行數:7,代碼來源:ZKClusterClient.java

示例8: listen

@Override
public void listen(ServiceDescription description) throws Exception {
    if (connectionState != ConnectionState.CONNECTED) {
        listenServices.add(description);
    } else {
        internalListen(description);
    }
}
 
開發者ID:dinstone,項目名稱:jrpc,代碼行數:8,代碼來源:ZookeeperServiceDiscovery.java

示例9: register

@Override
public void register(ServiceDescription service) throws Exception {
    services.put(service.getId(), service);
    if (connectionState == ConnectionState.CONNECTED) {
        internalRegister(service);
    }
}
 
開發者ID:dinstone,項目名稱:jrpc,代碼行數:7,代碼來源:ZookeeperServiceRegistry.java

示例10: stateChanged

@Override
  public void stateChanged(CuratorFramework client, ConnectionState newState) {
      if (newState == ConnectionState.CONNECTED) {
          if (registration == null) {
              registration = bundleContext.registerService(CuratorFramework.class, curator, null);
          }
      }
      for (ConnectionStateListener listener : connectionStateListeners) {
          listener.stateChanged(client, newState);
      }
      if (newState == ConnectionState.LOST) {
          run();
      }
}
 
開發者ID:tdiesler,項目名稱:fabric8poc,代碼行數:14,代碼來源:ManagedCuratorFramework.java

示例11: stateChanged

public void stateChanged(CuratorFramework curatorFramework, ConnectionState connectionState) {
    log.info("Connection to Zookeeper toggled to state " + connectionState.toString());
    connected = connectionState == ConnectionState.CONNECTED || connectionState == ConnectionState.RECONNECTED;
    if (connectionState == ConnectionState.LOST) {
        log.error("Connection to Zookeeper toggled to state " + connectionState.toString());
        this.handleZookeeperConnectionFailed();
    } else if (connectionState == ConnectionState.RECONNECTED) {
        log.info("Reconnected to zookeeper, forcing lock scavenge");
        forceLockScavenge();
    } else {
        log.info("Connection to Zookeeper toggled to state " + connectionState.toString());
    }
}
 
開發者ID:rackerlabs,項目名稱:blueflood,代碼行數:13,代碼來源:ZKShardLockManager.java

示例12: start

@Override
public void start()
{
    log.info("Starting");
    if ( !state.compareAndSet(CuratorFrameworkState.LATENT, CuratorFrameworkState.STARTED) )
    {
        throw new IllegalStateException("Cannot be started more than once");
    }

    try
    {
        connectionStateManager.start(); // ordering dependency - must be called before client.start()

        final ConnectionStateListener listener = new ConnectionStateListener()
        {
            @Override
            public void stateChanged(CuratorFramework client, ConnectionState newState)
            {
                if ( ConnectionState.CONNECTED == newState || ConnectionState.RECONNECTED == newState )
                {
                    logAsErrorConnectionErrors.set(true);
                }
            }
        };

        this.getConnectionStateListenable().addListener(listener);

        client.start();

        executorService = Executors.newSingleThreadScheduledExecutor(threadFactory);
        executorService.submit(new Callable<Object>()
        {
            @Override
            public Object call() throws Exception
            {
                backgroundOperationsLoop();
                return null;
            }
        });

        if ( ensembleTracker != null )
        {
            ensembleTracker.start();
        }

        log.info(schemaSet.toDocumentation());
    }
    catch ( Exception e )
    {
        ThreadUtils.checkInterrupted(e);
        handleBackgroundOperationException(null, e);
    }
}
 
開發者ID:apache,項目名稱:curator,代碼行數:53,代碼來源:CuratorFrameworkImpl.java

示例13: testListenerConnectedAtStart

@Test
public void testListenerConnectedAtStart() throws Exception
{
    server.stop();

    Timing timing = new Timing(2);
    CuratorFramework client = CuratorFrameworkFactory.newClient(server.getConnectString(), timing.session(), timing.connection(), new RetryNTimes(0, 0));
    try
    {
        client.start();
        AsyncCuratorFramework async = AsyncCuratorFramework.wrap(client);

        final CountDownLatch connectedLatch = new CountDownLatch(1);
        final AtomicBoolean firstListenerAction = new AtomicBoolean(true);
        final AtomicReference<ConnectionState> firstListenerState = new AtomicReference<>();
        ConnectionStateListener listener = (client1, newState) ->
        {
            if ( firstListenerAction.compareAndSet(true, false) )
            {
                firstListenerState.set(newState);
                System.out.println("First listener state is " + newState);
            }
            if ( newState == ConnectionState.CONNECTED )
            {
                connectedLatch.countDown();
            }
        };
        client.getConnectionStateListenable().addListener(listener);

        // due to CURATOR-72, this was causing a LOST event to precede the CONNECTED event
        async.create().forPath("/foo");

        server.restart();

        Assert.assertTrue(timing.awaitLatch(connectedLatch));
        Assert.assertFalse(firstListenerAction.get());
        ConnectionState firstconnectionState = firstListenerState.get();
        Assert.assertEquals(firstconnectionState, ConnectionState.CONNECTED, "First listener state MUST BE CONNECTED but is " + firstconnectionState);
    }
    finally
    {
        CloseableUtils.closeQuietly(client);
    }
}
 
開發者ID:apache,項目名稱:curator,代碼行數:44,代碼來源:TestFrameworkBackground.java


注:本文中的org.apache.curator.framework.state.ConnectionState.CONNECTED屬性示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。