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


Java ConnectionState類代碼示例

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


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

示例1: setMetricsCacheLocation

import org.apache.curator.framework.state.ConnectionState; //導入依賴的package包/類
@Override
public ListenableFuture<Boolean> setMetricsCacheLocation(
    TopologyMaster.MetricsCacheLocation location,
    String topologyName) {
  client.getConnectionStateListenable().addListener(new ConnectionStateListener() {
    @Override
    public void stateChanged(CuratorFramework arg0, ConnectionState arg1) {
      if (arg1 != ConnectionState.CONNECTED) {
        // if not the first time successful connection, fail fast
        throw new RuntimeException("Unexpected state change to: " + arg1.name());
      }
    }
  });
  return createNode(
      StateLocation.METRICSCACHE_LOCATION, topologyName, location.toByteArray(), true);
}
 
開發者ID:twitter,項目名稱:heron,代碼行數:17,代碼來源:CuratorStateManager.java

示例2: stateChanged

import org.apache.curator.framework.state.ConnectionState; //導入依賴的package包/類
@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,代碼行數:19,代碼來源:RedirectorCuratorFramework.java

示例3: stateChanged

import org.apache.curator.framework.state.ConnectionState; //導入依賴的package包/類
/**
 * This implementation is done in parallel because some listeners can hang the thread for a few minutes
 * while waiting for the others.
 * @param client
 * @param newState
 */
@Override
public void stateChanged(CuratorFramework client, ConnectionState newState) {
    if (this.client instanceof  RedirectorCuratorFramework) {
        if (((RedirectorCuratorFramework) this.client).getConnection().equals(client)) {
            currentConnectionState = newState;
        }
    } else  {
        if (this.client.equals(client)) {
            currentConnectionState = newState;
        }
    }

    Metrics.reportConnectionState(newState.name());

    connectionListeners.forEach(listener ->
            listenerParallelRunner.submit(
                    (Runnable) () -> listener.stateChanged(getConnectorState(newState))));
}
 
開發者ID:Comcast,項目名稱:redirector,代碼行數:25,代碼來源:ZookeeperConnector.java

示例4: CuratorZookeeperClient

import org.apache.curator.framework.state.ConnectionState; //導入依賴的package包/類
public CuratorZookeeperClient(URL url) {
    super(url);
    try {
        Builder builder = CuratorFrameworkFactory.builder()
                .connectString(url.getBackupAddress())
                .retryPolicy(new RetryNTimes(Integer.MAX_VALUE, 1000))
                .connectionTimeoutMs(5000);
        String authority = url.getAuthority();
        if (authority != null && authority.length() > 0) {
            builder = builder.authorization("digest", authority.getBytes());
        }
        client = builder.build();
        client.getConnectionStateListenable().addListener((client, state) -> {
            if (state == ConnectionState.LOST) {
                CuratorZookeeperClient.this.stateChanged(StateListener.DISCONNECTED);
            } else if (state == ConnectionState.CONNECTED) {
                CuratorZookeeperClient.this.stateChanged(StateListener.CONNECTED);
            } else if (state == ConnectionState.RECONNECTED) {
                CuratorZookeeperClient.this.stateChanged(StateListener.RECONNECTED);
            }
        });
        client.start();
    } catch (Exception e) {
        throw new IllegalStateException(e.getMessage(), e);
    }
}
 
開發者ID:linux-china,項目名稱:dubbo3,代碼行數:27,代碼來源:CuratorZookeeperClient.java

示例5: stateChanged

import org.apache.curator.framework.state.ConnectionState; //導入依賴的package包/類
/**
 * some state make effect to the lock, we have to handle it.
 *
 * @param client   curator
 * @param newState the state of connection to the io.vertx.spi.cluster.impl.zookeeper.zookeeper.
 */
@Override
public void stateChanged(CuratorFramework client, ConnectionState newState) {
  switch (newState) {
    case LOST:
      //release locks and clean locks
      locks.values().stream().forEach(ZKLock::release);
      locks.clear();
      break;
    case SUSPENDED:
      //just release locks on this node.
      locks.values().stream().forEach(ZKLock::release);
      break;
    case RECONNECTED:
      break;
  }
}
 
開發者ID:IBYoung,項目名稱:vert.3x-gateway,代碼行數:23,代碼來源:ZookeeperClusterManager.java

示例6: stateChanged

import org.apache.curator.framework.state.ConnectionState; //導入依賴的package包/類
@Override
public void stateChanged(CuratorFramework client, ConnectionState newState) {
	
    switch (newState) {
    case LOST:
    case SUSPENDED:

        Collection<InterProcessMutex> oldLocks = new ArrayList<>(locks.values());
        locks.clear();

        oldLocks.stream().parallel().forEach(lock -> {
            try {
                lock.release();
            } catch (Exception e) {
                logger.trace("Can't release lock on " + newState);
            }
        });
        break;
    default:
    }
}
 
開發者ID:benson-git,項目名稱:ibole-microservice,代碼行數:22,代碼來源:DistributedLockServiceCuratorImpl.java

示例7: destroy

import org.apache.curator.framework.state.ConnectionState; //導入依賴的package包/類
@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,代碼行數:18,代碼來源:ZookeeperServiceRegistry.java

示例8: stateChanged

import org.apache.curator.framework.state.ConnectionState; //導入依賴的package包/類
/**
 * {@inheritDoc}
 * @see org.apache.curator.framework.state.ConnectionStateListener#stateChanged(org.apache.curator.framework.CuratorFramework, org.apache.curator.framework.state.ConnectionState)
 */
@Override
public void stateChanged(final CuratorFramework client, final ConnectionState newState) {
	SimpleLogger.log("ZK Connection State Change to [%s]", newState.name());
	connected.set(newState.isConnected());
	switch(newState) {			
		case CONNECTED:						
			registerPending();
			dropConnectLatches();
			break;
		case LOST:
			setAllPending();
			break;
		case READ_ONLY:
			break;
		case RECONNECTED:
			registerPending();
			dropConnectLatches();
			break;
		case SUSPENDED:
			break;
		default:
			break;
	}
	
}
 
開發者ID:nickman,項目名稱:HeliosStreams,代碼行數:30,代碼來源:EndpointPublisher.java

示例9: stateChanged

import org.apache.curator.framework.state.ConnectionState; //導入依賴的package包/類
/**
 * {@inheritDoc}
 * @see org.apache.curator.framework.state.ConnectionStateListener#stateChanged(org.apache.curator.framework.CuratorFramework, org.apache.curator.framework.state.ConnectionState)
 */
@Override
public void stateChanged(final CuratorFramework client, final ConnectionState newState) {
	log.info("ZK Connection State Change to [{}]", newState.name());
	connected.set(newState.isConnected());
	switch(newState) {			
		case CONNECTED:							
			registerPending();
			break;
		case LOST:
			setAllPending();
			break;
		case READ_ONLY:
			break;
		case RECONNECTED:
			registerPending();
			break;
		case SUSPENDED:
			break;
		default:
			break;
	
	}		
}
 
開發者ID:nickman,項目名稱:HeliosStreams,代碼行數:28,代碼來源:EndpointPublisher.java

示例10: stateChanged

import org.apache.curator.framework.state.ConnectionState; //導入依賴的package包/類
/**
 * {@inheritDoc}
 * @see org.apache.curator.framework.state.ConnectionStateListener#stateChanged(org.apache.curator.framework.CuratorFramework, org.apache.curator.framework.state.ConnectionState)
 */
@Override
public void stateChanged(final CuratorFramework client, final ConnectionState newState) {
	log.info("ZK Connection State Change to [{}]", newState.name());
	connected.set(newState.isConnected());
	switch(newState) {			
		case CONNECTED:	
			sendNotification(new Notification(NOTIF_SERVICE_CONNECT, OBJECT_NAME, notifSerial.incrementAndGet(), System.currentTimeMillis(), "EndpointListener connected to Zookeeper at [" + zkConnect + "]"));
			break;
		case LOST:
			final int lostEndpoints = registered.size();
			registered.clear();
			sendNotification(new Notification(NOTIF_SERVICE_DISCONNECT, OBJECT_NAME, notifSerial.incrementAndGet(), System.currentTimeMillis(), "EndpointListener lost connection to Zookeeper [" + zkConnect + "]. Lost [" + lostEndpoints + "] endpoints"));
			break;
		case READ_ONLY:
			break;
		case RECONNECTED:
			sendNotification(new Notification(NOTIF_SERVICE_RECONNECT, OBJECT_NAME, notifSerial.incrementAndGet(), System.currentTimeMillis(), "EndpointListener re-connected to Zookeeper at [" + zkConnect + "]"));
			break;
		case SUSPENDED:
			break;
		default:
			break;
	}		
}
 
開發者ID:nickman,項目名稱:HeliosStreams,代碼行數:29,代碼來源:EndpointListener.java

示例11: stateChanged

import org.apache.curator.framework.state.ConnectionState; //導入依賴的package包/類
/**
 * {@inheritDoc}
 * @see org.apache.curator.framework.state.ConnectionStateListener#stateChanged(org.apache.curator.framework.CuratorFramework, org.apache.curator.framework.state.ConnectionState)
 */
@Override
public void stateChanged(final CuratorFramework client, final ConnectionState newState) {
	final ConnectionState cs = cfState.getAndSet(newState);
	log.info("cfState transition: [{}] --> [{}]", cs, newState);
	
	switch(newState) {			
		case CONNECTED:
			break;
		case LOST:
			break;
		case READ_ONLY:
			break;
		case RECONNECTED:
			break;
		case SUSPENDED:
			break;
		default:
			break;
			
		}
}
 
開發者ID:nickman,項目名稱:HeliosStreams,代碼行數:26,代碼來源:AdminFinder.java

示例12: stateChanged

import org.apache.curator.framework.state.ConnectionState; //導入依賴的package包/類
@Override
public void stateChanged(CuratorFramework client, ConnectionState newState) {

  logger.debug("StateChanged: {}", newState);

  switch (newState) {
    case SUSPENDED:
      resignLeadership();
      break;

    case RECONNECTED:
      try {
        takeLeadership();
      } catch (InterruptedException e) {
        logger.error("While handling RECONNECTED", e);
      }
      break;

    case LOST:
      resignLeadership();
      break;
  }
}
 
開發者ID:networknt,項目名稱:light-eventuate-4j,代碼行數:24,代碼來源:EventuateLeaderSelectorListener.java

示例13: stateChanged

import org.apache.curator.framework.state.ConnectionState; //導入依賴的package包/類
@Override
public void stateChanged(CuratorFramework framework, ConnectionState connectionState) {
    switch (connectionState) {
        case CONNECTED:
            metricUpdater.incZKConnected();
            break;
        case SUSPENDED:
            metricUpdater.incZKSuspended();
            break;
        case RECONNECTED:
            metricUpdater.incZKReconnected();
            break;
        case LOST:
            metricUpdater.incZKConnectionLost();
            break;
        case READ_ONLY:
            // NOTE: Should not be relevant for configserver.
            break;
    }
}
 
開發者ID:vespa-engine,項目名稱:vespa,代碼行數:21,代碼來源:Tenants.java

示例14: stateChanged

import org.apache.curator.framework.state.ConnectionState; //導入依賴的package包/類
@Override
public void stateChanged(final CuratorFramework client, final ConnectionState newState) {
    JobScheduleController jobScheduleController = JobRegistry.getInstance().getJobScheduleController(jobName);
    if (ConnectionState.LOST == newState) {
        jobScheduleController.pauseJob();
    } else if (ConnectionState.RECONNECTED == newState) {
        if (!leaderElectionService.hasLeader()) {
            leaderElectionService.leaderElection();
        }
        serverService.persistServerOnline();
        executionService.clearRunningInfo(shardingService.getLocalHostShardingItems());
        if (!serverService.isJobPausedManually()) {
            jobScheduleController.resumeJob();
        }
    }
}
 
開發者ID:artoderk,項目名稱:elastic-jobx,代碼行數:17,代碼來源:JobOperationListenerManager.java

示例15: getAndIncrement

import org.apache.curator.framework.state.ConnectionState; //導入依賴的package包/類
@Override
public long getAndIncrement() throws Exception {
	while (true) {
		ConnectionState connState = connStateListener.getLastState();

		if (connState != null) {
			throw new IllegalStateException("Connection state: " + connState);
		}

		VersionedValue<Integer> current = sharedCount.getVersionedValue();
		int newCount = current.getValue() + 1;

		if (newCount < 0) {
			// overflow and wrap around
			throw new Exception("Checkpoint counter overflow. ZooKeeper checkpoint counter only supports " +
					"checkpoints Ids up to " + Integer.MAX_VALUE);
		}

		if (sharedCount.trySetCount(current, newCount)) {
			return current.getValue();
		}
	}
}
 
開發者ID:axbaretto,項目名稱:flink,代碼行數:24,代碼來源:ZooKeeperCheckpointIDCounter.java


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