本文整理匯總了Java中org.apache.curator.framework.state.ConnectionState.RECONNECTED屬性的典型用法代碼示例。如果您正苦於以下問題:Java ConnectionState.RECONNECTED屬性的具體用法?Java ConnectionState.RECONNECTED怎麽用?Java ConnectionState.RECONNECTED使用的例子?那麽, 這裏精選的屬性代碼示例或許可以為您提供幫助。您也可以進一步了解該屬性所在類org.apache.curator.framework.state.ConnectionState
的用法示例。
在下文中一共展示了ConnectionState.RECONNECTED屬性的14個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。
示例1: stateChanged
@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();
}
}
}
示例2: 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);
}
}
}
示例3: isConnected
@Override
public boolean isConnected() {
return client != null && client.isStarted() &&
currentConnectionState != null &&
(currentConnectionState == ConnectionState.CONNECTED ||
currentConnectionState == ConnectionState.RECONNECTED);
}
示例4: 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;
}
}
示例5: KafkaConsumerCache
/**
* Creates a KafkaConsumerCache object. Before it is used, you must call
* startCache()
*
* @param apiId
* @param s
* @param metrics
*/
public KafkaConsumerCache(String apiId, MetricsSet metrics) {
if (apiId == null) {
throw new IllegalArgumentException("API Node ID must be specified.");
}
fApiId = apiId;
// fSettings = s;
fMetrics = metrics;
String strkSetting_ZkBasePath= AJSCPropertiesMap.getProperty(CambriaConstants.msgRtr_prop,kSetting_ZkBasePath);
if(null==strkSetting_ZkBasePath)strkSetting_ZkBasePath = kDefault_ZkBasePath;
fBaseZkPath = strkSetting_ZkBasePath;
fConsumers = new ConcurrentHashMap<String, KafkaConsumer>();
fSweepScheduler = Executors.newScheduledThreadPool(1);
curatorConsumerCache = null;
status = Status.NOT_STARTED;
listener = new ConnectionStateListener() {
public void stateChanged(CuratorFramework client, ConnectionState newState) {
if (newState == ConnectionState.LOST) {
log.info("ZooKeeper connection expired");
handleConnectionLoss();
} else if (newState == ConnectionState.READ_ONLY) {
log.warn("ZooKeeper connection set to read only mode.");
} else if (newState == ConnectionState.RECONNECTED) {
log.info("ZooKeeper connection re-established");
handleReconnection();
} else if (newState == ConnectionState.SUSPENDED) {
log.warn("ZooKeeper connection has been suspended.");
handleConnectionSuspended();
}
}
};
}
示例6: stateChanged
@Override
public void stateChanged(final CuratorFramework client, final ConnectionState newState) {
if (ConnectionState.LOST == newState) {
log.info("Connection lost from zookeeper :server=" + serverLists + ", namespace=" + namespace);
}
if (ConnectionState.RECONNECTED == newState) {
log.info("Reconnection from zookeeper :server=" + serverLists + ", namespace=" + namespace);
}
}
示例7: stateChanged
@Override
public void stateChanged(final CuratorFramework client, final ConnectionState newState) {
log.info("zookeeper connection state changed.new state:{}", newState);
if (ConnectionState.RECONNECTED == newState) {
zookeeperConfigGroup.loadNode();
}
}
示例8: stateChanged
@Override
public void stateChanged(CuratorFramework client, ConnectionState newState)
{
if ( newState == ConnectionState.RECONNECTED )
{
reconnected.countDown();
}
}
示例9: stateChanged
/**
* TODO - figure out how to register this listener
*/
@Override
public void stateChanged(final CuratorFramework client,
final ConnectionState newState) {
if (newState == ConnectionState.RECONNECTED) {
registerAvailability();
}
}
示例10: 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());
}
}
示例11: 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);
}
}
示例12: testDisconnectReconnectWithMultipleClients
@Test
public void testDisconnectReconnectWithMultipleClients() throws Exception
{
Timing timing = new Timing();
CuratorFramework curatorFramework1 = CuratorFrameworkFactory.newClient(server.getConnectString(), new RetryNTimes(10, 500));
CuratorFramework curatorFramework2 = CuratorFrameworkFactory.newClient(server.getConnectString(), new RetryNTimes(10, 500));
curatorFramework1.start();
curatorFramework1.checkExists().forPath("/"); // clear initial connect events
curatorFramework2.start();
curatorFramework2.checkExists().forPath("/"); // clear initial connect events
final String sharedCountPath = "/count";
final int initialCount = 10;
SharedCount sharedCount1 = new SharedCount(curatorFramework1, sharedCountPath, initialCount);
SharedCount sharedCountWithFaultyWatcher = createSharedCountWithFaultyWatcher(curatorFramework2, sharedCountPath, initialCount);
class MySharedCountListener implements SharedCountListener
{
final public Phaser gotSuspendEvent = new Phaser(1);
final public Phaser gotChangeEvent = new Phaser(1);
final public Phaser getReconnectEvent = new Phaser(1);
final public AtomicInteger numChangeEvents = new AtomicInteger(0);
@Override
public void countHasChanged(SharedCountReader sharedCount, int newCount) throws Exception
{
numChangeEvents.incrementAndGet();
gotChangeEvent.arrive();
}
@Override
public void stateChanged(CuratorFramework client, ConnectionState newState)
{
if (newState == ConnectionState.SUSPENDED) {
gotSuspendEvent.arrive();
} else if (newState == ConnectionState.RECONNECTED) {
getReconnectEvent.arrive();
}
}
}
MySharedCountListener listener1 = new MySharedCountListener();
sharedCount1.addListener(listener1);
sharedCount1.start();
MySharedCountListener listener2 = new MySharedCountListener();
sharedCountWithFaultyWatcher.addListener(listener2);
try
{
sharedCount1.setCount(12);
Assert.assertEquals(listener1.gotChangeEvent.awaitAdvanceInterruptibly(0, timing.seconds(), TimeUnit.SECONDS), 1);
Assert.assertEquals(sharedCount1.getCount(), 12);
Assert.assertEquals(sharedCountWithFaultyWatcher.getCount(), 10);
// new counter with faultyWatcher start
sharedCountWithFaultyWatcher.start();
for (int i = 0; i < 10; i++) {
sharedCount1.setCount(13 + i);
Assert.assertEquals(sharedCount1.getCount(), 13 + i);
server.restart();
Assert.assertEquals(listener2.getReconnectEvent.awaitAdvanceInterruptibly(i, timing.forWaiting().seconds(), TimeUnit.SECONDS), i + 1);
// CURATOR-311 introduces to Curator's client reading server's shared count value
// when client's state gets ConnectionState.RECONNECTED. Following tests ensures that.
Assert.assertEquals(listener2.gotChangeEvent.awaitAdvanceInterruptibly(i, timing.forWaiting().seconds(), TimeUnit.SECONDS), i + 1);
Assert.assertEquals(sharedCountWithFaultyWatcher.getCount(), 13 + i);
}
}
finally
{
CloseableUtils.closeQuietly(sharedCount1);
CloseableUtils.closeQuietly(curatorFramework1);
CloseableUtils.closeQuietly(sharedCountWithFaultyWatcher);
CloseableUtils.closeQuietly(curatorFramework2);
}
}
示例13: start
public void start(String nodeName, int port, boolean addShutdownHook, byte[] payload) throws Exception {
Preconditions.checkArgument(framework.getState() == CuratorFrameworkState.STARTED);
this.nodeName = nodeName;
this.port = port;
this.payload = payload;
// Register ephemeral node as representation of this service's nodename and port
// such as /services/myservice/nodes/192.168.1.1:8000
this.node = baseNode + "/" + nodeName + ":" + port;
this.listener = new ConnectionStateListener() {
@Override
public void stateChanged(CuratorFramework curatorFramework, ConnectionState connectionState) {
if (connectionState == ConnectionState.RECONNECTED) {
log.info("Re-registering with ZK as node {}", node);
deleteAndCreateNode();
}
}
};
// Ensure the parent paths exist persistently
while (framework.checkExists().forPath(baseNode) == null) {
log.info("Creating base node {}", baseNode);
framework.create()
.creatingParentsIfNeeded()
.withMode(CreateMode.PERSISTENT)
.forPath(baseNode);
}
log.info("Registering with ZK as node {}", node);
deleteAndCreateNode();
framework.getConnectionStateListenable().addListener(listener);
if (addShutdownHook) {
log.info("Adding shutdown hook for disco service");
Runtime.getRuntime().addShutdownHook(new Thread() {
@Override
public void run() {
log.info("Shutting down disco service");
try {
DiscoService.this.stop();
} catch (Exception e) {
log.error("Couldn't stop disco service", e);
}
}
});
}
}
示例14: reconnectedTrigger
public static ConnectionTrigger reconnectedTrigger() {
return new ConnectionTrigger(ConnectionState.RECONNECTED);
}