本文整理匯總了Java中org.apache.curator.utils.ZKPaths.getNodeFromPath方法的典型用法代碼示例。如果您正苦於以下問題:Java ZKPaths.getNodeFromPath方法的具體用法?Java ZKPaths.getNodeFromPath怎麽用?Java ZKPaths.getNodeFromPath使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類org.apache.curator.utils.ZKPaths
的用法示例。
在下文中一共展示了ZKPaths.getNodeFromPath方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。
示例1: startInitialTasks
import org.apache.curator.utils.ZKPaths; //導入方法依賴的package包/類
private void startInitialTasks()
{
if( !startedInitialTasks )
{
List<ChildData> currentData = taskCache.getCurrentData();
List<String> taskIds = Lists.newArrayList();
for( ChildData task : currentData )
{
String taskId = ZKPaths.getNodeFromPath(task.getPath());
LOGGER.debug("Task added " + taskId);
taskIds.add(taskId);
addRunner(taskId);
}
requestFullStatus(taskIds);
startedInitialTasks = true;
}
}
示例2: handleReconnection
import org.apache.curator.utils.ZKPaths; //導入方法依賴的package包/類
private void handleReconnection() {
log.info("Reading current cache data from ZK and synchronizing local cache");
final List<ChildData> cacheData = curatorConsumerCache.getCurrentData();
// Remove all the consumers in this API nodes cache that now belong to
// other API nodes.
for (ChildData cachedConsumer : cacheData) {
final String consumerId = ZKPaths.getNodeFromPath(cachedConsumer.getPath());
final String owningApiId = (cachedConsumer.getData() != null) ? new String(cachedConsumer.getData())
: "undefined";
if (!fApiId.equals(owningApiId)) {
fConsumers.remove(consumerId);
}
}
setStatus(Status.CONNECTED);
}
示例3: newListener
import org.apache.curator.utils.ZKPaths; //導入方法依賴的package包/類
private PathChildrenCacheListener newListener(final EventType eventType, final GroupChangedListener delegate) {
return
(client, event) -> {
switch (event.getType()) {
case CHILD_ADDED : {
String addedMemberId = ZKPaths.getNodeFromPath(event.getData().getPath());
delegate.memberAdded(eventType, addedMemberId);
break;
}
case CHILD_REMOVED : {
final String removedMemberId = ZKPaths.getNodeFromPath(event.getData().getPath());
delegate.memberRemoved(eventType, removedMemberId);
break;
}
default :
break;
}
};
}
示例4: childEvent
import org.apache.curator.utils.ZKPaths; //導入方法依賴的package包/類
@Override
public void childEvent(CuratorFramework client, PathChildrenCacheEvent event) throws Exception
{
Type type = event.getType();
if( type.equals(Type.CHILD_ADDED) || type.equals(Type.CHILD_UPDATED) || type.equals(Type.CHILD_REMOVED) )
{
String remoteId = ZKPaths.getNodeFromPath(event.getData().getPath());
String[] clientInfo = new String(event.getData().getData()).split(":");
if( !isThisNode(remoteId) && !hasSameInfo(clientInfo) )
{
if( type.equals(Type.CHILD_ADDED) )
{
senders.get(remoteId);
addReceiver(remoteId, clientInfo);
}
else if( type.equals(Type.CHILD_UPDATED) )
{
senders.get(remoteId);
removeReceiver(remoteId);
addReceiver(remoteId, clientInfo);
}
else
{
removeReceiver(remoteId);
}
}
}
}
示例5: childEvent
import org.apache.curator.utils.ZKPaths; //導入方法依賴的package包/類
@Override
public void childEvent(CuratorFramework client, PathChildrenCacheEvent event) throws Exception {
if (logger.isDebugEnabled()) {
logger.debug("path={} event={}", event.getData().getPath(), event.getType());
}
switch (event.getType()) {
case CHILD_ADDED:
logChildChanged(client, event);
addOrUpdate(event);
break;
case CHILD_UPDATED:
logChildChanged(client, event);
addOrUpdate(event);
break;
case CHILD_REMOVED:
logChildChanged(client, event);
String key = ZKPaths.getNodeFromPath(event.getData().getPath());
itemSet.remove(key);
break;
case CONNECTION_SUSPENDED:
logChildChanged(client, event);
break;
case CONNECTION_RECONNECTED:
logChildChanged(client, event);
initDataFromZk();
break;
case CONNECTION_LOST:
logChildChanged(client, event);
break;
case INITIALIZED:
logChildChanged(client, event);
break;
}
}
示例6: addProvider
import org.apache.curator.utils.ZKPaths; //導入方法依賴的package包/類
private void addProvider(ChildData childData, boolean onlyIfAbsent) throws Exception {
String instanceId = ZKPaths.getNodeFromPath(childData.getPath());
ServiceDescription serviceInstance = serializer.deserialize(childData.getData());
if (onlyIfAbsent) {
providers.putIfAbsent(instanceId, serviceInstance);
} else {
providers.put(instanceId, serviceInstance);
}
cache.clearDataBytes(childData.getPath(), childData.getStat().getVersion());
}
示例7: nodeAdd
import org.apache.curator.utils.ZKPaths; //導入方法依賴的package包/類
/**
* zookeeper listen the node add event ret: 0: failed ,1:the node is root
* node,2:success
*/
private int nodeAdd(long logIndex, CuratorFramework client, TreeCacheEvent event) {
String flag = getClassName() + ".nodeAdd";
String strNode = null;
String strVal = null;
String strPath = null;
try {
strPath = event.getData().getPath();
if (strPath.equals(ZK_ROOT)) {
FRCLogger.getInstance().info(logIndex, flag, "NODE_ADDED ROOT dir!", null);
return DefaultValues.ZK_ADD_ROOT;
}
strNode = ZKPaths.getNodeFromPath(strPath);
strVal = new String(client.getData().forPath(strPath));
FRCLogger.getInstance().info(logIndex, flag, "Node:{}\n value:{}", null, strNode,
strVal);
RedisInfo redisInfo = (RedisInfo) JSONProvider.parseObject(logIndex, strVal,
RedisInfo.class);
if (null == redisInfo) {
FRCLogger.getInstance().warn(logIndex, flag, ":{}", null, strVal);
this.delPath(logIndex, strPath);
return DefaultValues.ZK_ADD_FAIL;
}
redisInfo.setRedis_name(strPath);
cnm.nodeAdd(logIndex, redisInfo);
} catch (Exception e) {
FRCLogger.getInstance().warn(logIndex, flag,
"nodeAdd event :path:{}->[{}] add fail,exception detail: {}", e, strVal);
return DefaultValues.ZK_ADD_FAIL;
}
return DefaultValues.ZK_ADD_SUC;
}
示例8: updateNode
import org.apache.curator.utils.ZKPaths; //導入方法依賴的package包/類
/**
* zookeeper listen the node update event
*/
private boolean updateNode(long logIndex, TreeCacheEvent event) {
String flag = this.getClassName() + ".updateNode";
try {
String strPath = event.getData().getPath();
if (strPath.equals(ZK_ROOT)) {
FRCLogger.getInstance().info(logIndex, flag, "NODE_ADDED ROOT dir!", null);
return true;
}
strPath = event.getData().getPath();
String strNode = ZKPaths.getNodeFromPath(strPath);
String strVal = new String(client.getData().forPath(strPath));
FRCLogger.getInstance().info(logIndex, flag, "Node:{}\n value:{}", null, strNode,
strVal);
RedisInfo redisInfo = getRedisInfo(logIndex, event);
if (null == redisInfo)
return false;
redisInfo.setRedis_name(strPath);
int state = this.getState(redisInfo.getRedis_state());
if (RedisState.STATE_UNKOWN == state) {
FRCLogger.getInstance().warn(logIndex, flag, "redis workstate is wrong! data:{}",
null, JSONProvider.toJSONString(logIndex, redisInfo));
return false;
}
cnm.nodeUpdate(logIndex, redisInfo);
return true;
} catch (Exception e) {
FRCLogger.getInstance().warn(logIndex, flag, "exception", e);
return false;
}
}
示例9: removeNode
import org.apache.curator.utils.ZKPaths; //導入方法依賴的package包/類
private boolean removeNode(long logIndex, TreeCacheEvent event) {
String flag = this.getClassName() + ".removeNode";
try {
String strPath = event.getData().getPath();
if (strPath.equals(ZK_ROOT)) {
FRCLogger.getInstance().info(logIndex, flag, "NODE_ADDED ROOT dir!", null);
return true;
}
String strNode = ZKPaths.getNodeFromPath(strPath);
String strVal = new String(client.getData().forPath(strPath));
FRCLogger.getInstance().info(logIndex, flag, "Node:{}\n value:{}", null, strNode,
strVal);
RedisInfo redisInfo = getRedisInfo(logIndex, event);
if (null == redisInfo)
return false;
cnm.nodeRemove(logIndex, redisInfo);
} catch (Exception e) {
FRCLogger.getInstance().warn(logIndex, flag, "exception", e);
return false;
}
return true;
}
示例10: getRedisName
import org.apache.curator.utils.ZKPaths; //導入方法依賴的package包/類
/**
* get the zookeeper data of node of the event
*
* @param logIndex
* @param event
* zookeeper event
* @return
*/
@SuppressWarnings("unused")
private String getRedisName(long logIndex, TreeCacheEvent event) {
String flag = getClassName() + ".getRedisName";
try {
return ZKPaths.getNodeFromPath(event.getData().getPath());
} catch (Exception e) {
FRCLogger.getInstance().warn(logIndex, flag,
"zookeeper getRedisName fail exception detail: {}", e);
return null;
}
}
示例11: childEvent
import org.apache.curator.utils.ZKPaths; //導入方法依賴的package包/類
@Override
public void childEvent(CuratorFramework client, PathChildrenCacheEvent event) throws Exception
{
Type type = event.getType();
LOGGER.debug("Event = " + type);
if( type == Type.CHILD_ADDED || type == Type.CHILD_REMOVED )
{
final boolean init;
if( !startedInitialTasks )
{
synchronized( initialTasksLock )
{
init = startedInitialTasks;
}
}
else
{
init = startedInitialTasks;
}
if( init )
{
String taskId = ZKPaths.getNodeFromPath(event.getData().getPath());
switch( type )
{
case CHILD_ADDED:
LOGGER.debug("Task added " + taskId);
requestFullStatus(Collections.singleton(taskId));
addRunner(taskId);
break;
case CHILD_REMOVED:
LOGGER.debug("Task removed " + taskId);
statusHandler.retireStatus(taskId);
runnerHandler.deleteRunner(taskId, false);
break;
}
}
else
{
LOGGER.debug("Not init yet. " + event.getData().getPath());
}
}
else
{
long sessionId = client.getZookeeperClient().getZooKeeper().getSessionId();
if( type == Type.CONNECTION_SUSPENDED )
{
suspendedSessionId = sessionId;
}
else
if( (type == Type.CONNECTION_RECONNECTED && suspendedSessionId != sessionId)
|| type == Type.CONNECTION_LOST )
{
runnerHandler.lostConnection();
}
else if( type == Type.INITIALIZED )
{
synchronized( initialTasksLock )
{
startInitialTasks();
}
}
}
}
示例12: getNameFromPath
import org.apache.curator.utils.ZKPaths; //導入方法依賴的package包/類
public static String getNameFromPath(String path) {
return ZKPaths.getNodeFromPath(path);
}
示例13: toChildPath
import org.apache.curator.utils.ZKPaths; //導入方法依賴的package包/類
protected String toChildPath(ChildData childData) {
String fullPath = childData.getPath();
return ZKPaths.getNodeFromPath(fullPath);
}
示例14: addOrUpdate
import org.apache.curator.utils.ZKPaths; //導入方法依賴的package包/類
void addOrUpdate(PathChildrenCacheEvent event) {
String key = ZKPaths.getNodeFromPath(event.getData().getPath());
itemSet.add(key);
}
示例15: reload
import org.apache.curator.utils.ZKPaths; //導入方法依賴的package包/類
/**
* 重加載路徑path配置節點
*
* @param path 配置節點路徑
*/
private void reload(String path) {
log.debug("reload the config node:{}", ZKPaths.getNodeFromPath(path));
String key = ZKPaths.getNodeFromPath(path);
zookeeperConfigGroup.reloadKey(key);
}