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


Java ZKPaths類代碼示例

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


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

示例1: notifyClusterDDL

import org.apache.curator.utils.ZKPaths; //導入依賴的package包/類
public void notifyClusterDDL(String schema, String table, String sql, DDLInfo.DDLStatus ddlStatus, boolean needNotifyOther) throws Exception {
    CuratorFramework zkConn = ZKUtils.getConnection();
    DDLInfo ddlInfo = new DDLInfo(schema, sql, ZkConfig.getInstance().getValue(ZkParamCfg.ZK_CFG_MYID), ddlStatus);
    String nodeName = StringUtil.getFullName(schema, table);
    String nodePath = ZKPaths.makePath(KVPathUtil.getDDLPath(), nodeName);
    if (zkConn.checkExists().forPath(nodePath) == null) {
        zkConn.create().forPath(nodePath, ddlInfo.toString().getBytes(StandardCharsets.UTF_8));
    } else {
        String instancePath = ZKPaths.makePath(nodePath, KVPathUtil.DDL_INSTANCE);
        String thisNode = ZkConfig.getInstance().getValue(ZkParamCfg.ZK_CFG_MYID);
        ZKUtils.createTempNode(instancePath, thisNode);
        if (needNotifyOther) {
            //this node is ddl sender
            zkConn.setData().forPath(nodePath, ddlInfo.toString().getBytes(StandardCharsets.UTF_8));
            while (true) {
                List<String> preparedList = zkConn.getChildren().forPath(instancePath);
                List<String> onlineList = zkConn.getChildren().forPath(KVPathUtil.getOnlinePath());
                if (preparedList.size() >= onlineList.size()) {
                    zkConn.delete().deletingChildrenIfNeeded().forPath(nodePath);
                    break;
                }
                LockSupport.parkNanos(TimeUnit.MILLISECONDS.toNanos(100));
            }
        }
    }
}
 
開發者ID:actiontech,項目名稱:dble,代碼行數:27,代碼來源:ProxyMetaManager.java

示例2: getMarkerData

import org.apache.curator.utils.ZKPaths; //導入依賴的package包/類
@Override
CompletableFuture<Data<Integer>> getMarkerData(int segmentNumber) {
    final CompletableFuture<Data<Integer>> result = new CompletableFuture<>();
    final String path = ZKPaths.makePath(markerPath, String.format("%d", segmentNumber));
    cache.getCachedData(path)
            .whenComplete((res, ex) -> {
                if (ex != null) {
                    Throwable cause = Exceptions.unwrap(ex);
                    if (cause instanceof StoreException.DataNotFoundException) {
                        result.complete(null);
                    } else {
                        result.completeExceptionally(cause);
                    }
                } else {
                    result.complete(res);
                }
            });

    return result;
}
 
開發者ID:pravega,項目名稱:pravega,代碼行數:21,代碼來源:ZKStream.java

示例3: addPartner

import org.apache.curator.utils.ZKPaths; //導入依賴的package包/類
public void addPartner(String key, Partner partner) {
	String partnerPath = ZKPaths.makePath(partnerStorePath, key);
	RetryRunner.create().onFinalError(e -> {
		LOGGER.error("addPartner.error", e);
		ReporterHolder.incException(e);
		throw new ServiceErrorException(ErrorCode.SYSTEM_ERROR);
	}).run((Callable<Void>) () -> {
		if (client.checkExists().creatingParentsIfNeeded().forPath(partnerPath) != null) {
			client.setData()
			      .forPath(partnerPath, JSONObject.toJSONBytes(partner));
		} else {
			client.create()
			      .creatingParentsIfNeeded()
			      .withMode(CreateMode.PERSISTENT)
			      .forPath(partnerPath, JSONObject.toJSONBytes(partner));
		}
		return null;
	});
}
 
開發者ID:mm23504570,項目名稱:snowflake,代碼行數:20,代碼來源:PartnerStore.java

示例4: removePartner

import org.apache.curator.utils.ZKPaths; //導入依賴的package包/類
public void removePartner(String key) {
	RetryRunner.create()
	           .excludeExceptions(KeeperException.NoNodeException.class)
	           .includeExceptions(KeeperException.class)
	           .onFinalError(e -> {
		           if (e instanceof KeeperException.NoNodeException) {
		           } else {
			           ReporterHolder.incException(e);
			           LOGGER.error("removePartner.error", e);
			           throw new ServiceErrorException(ErrorCode.SYSTEM_ERROR);
		           }
	           })
	           .run((Callable<Void>) () -> {
		           client.delete()
		                 .forPath(ZKPaths.makePath(partnerStorePath, key));
		           return null;
	           });
}
 
開發者ID:mm23504570,項目名稱:snowflake,代碼行數:19,代碼來源:PartnerStore.java

示例5: getZkRangeStore

import org.apache.curator.utils.ZKPaths; //導入依賴的package包/類
public ZkRangeStore getZkRangeStore(int clientIndex) {
	String lockPath = "/snowflake/locks";
	String storePath = "/snowflake/idstore";
	CuratorFramework curatorFramework = ZkUtils.create("127.0.0.1:2181", 1000, 10000);
	curatorFramework.start();
	for (String client : clients) {
		try {
			curatorFramework.setData().forPath(ZKPaths.makePath(storePath, client), "0".getBytes());
		} catch (Exception e) {
			if (e instanceof KeeperException.NoNodeException) {
				try {
					curatorFramework.create().creatingParentsIfNeeded().forPath(storePath, "0".getBytes());
				} catch (Exception e1) {
					e1.printStackTrace();
				}
			}
		}
	}
	return new ZkRangeStore(clients.get(clientIndex), curatorFramework, lockPath, storePath, 1, TimeUnit.SECONDS, 0, 10);
}
 
開發者ID:mm23504570,項目名稱:snowflake,代碼行數:21,代碼來源:TestSeqBase.java

示例6: doWork

import org.apache.curator.utils.ZKPaths; //導入依賴的package包/類
private void doWork()
{
  for ( String path : paths )
  {
    try
    {
      List<String> children = client.getChildren().forPath(path);
      for ( String name : children )
      {
        String thisPath = ZKPaths.makePath(path, name);
        Stat stat = client.checkExists().forPath(thisPath);
        if ( (stat != null) && (stat.getNumChildren() == 0) )
        {
          reaper.addPath(thisPath, mode);
        }
      }
    }
    catch ( Exception e )
    {
      log.error("Could not get children for path: " + path, e);
    }
  }
}
 
開發者ID:nucypher,項目名稱:hadoop-oss,代碼行數:24,代碼來源:ChildReaper.java

示例7: createPath

import org.apache.curator.utils.ZKPaths; //導入依賴的package包/類
/**
 * 創建配製信息
 * 方法描述
 * @param configKey 配製的當前路徑名稱信息
 * @param filterInnerMap  最終的信息是否為map
 * @param configDirectory 配製的目錄
 * @param restDirectory 子目錄信息
 * @創建日期 2016年9月11日
 */
public boolean createPath(String path) {

    // 得到當前的目錄信息
    LOGGER.trace("createPath child path is {}", path);

    boolean result = true;
    try {
        // 進行目錄的創建操作
        ZKPaths.mkdirs(curator.getZookeeperClient().getZooKeeper(), path);
    } catch (Exception e) {
        LOGGER.error(" createPath error", e);
        result = false;
    }

    return result;
}
 
開發者ID:huang-up,項目名稱:mycat-src-1.6.1-RELEASE,代碼行數:26,代碼來源:ZkMultLoader.java

示例8: readTargetChildsData

import org.apache.curator.utils.ZKPaths; //導入依賴的package包/類
/**
 * 讀取指定節點的子菜單的值
 *
 * @param path
 * @return
 */
public Map<String, String> readTargetChildsData(String path) {
    if (!ObjectUtils.allNotNull(zkClient, path)) {
        return null;
    }
    Map<String, String> map = null;
    try {
        Stat stat = exists(path);
        if (stat != null) {
            List<String> childrens = zkClient.getChildren().forPath(path);
            GetDataBuilder dataBuilder = zkClient.getData();
            if (childrens != null) {
                map = childrens.stream().collect(Collectors.toMap(Function.identity(), (child) -> {
                    try {
                        return new String(dataBuilder.forPath(ZKPaths.makePath(path, child)), Charsets.UTF_8);
                    } catch (Exception e1) {
                        return null;
                    }
                }));
            }
        }
    } catch (Exception e) {
        log.error("get target childs data fail!, path:{} , error:{}", path, e);
    }
    return map;

}
 
開發者ID:lee123lee123,項目名稱:GoPush,代碼行數:33,代碼來源:ZkUtils.java

示例9: 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;
	}
}
 
開發者ID:equella,項目名稱:Equella,代碼行數:18,代碼來源:ClusteredTaskServiceImpl.java

示例10: should_load_agent_config

import org.apache.curator.utils.ZKPaths; //導入依賴的package包/類
@Test
public void should_load_agent_config() throws IOException, InterruptedException {
    // given:
    String wsUrl = "ws://localhost:8080/logging";
    String cmdStatusUrl = "http://localhost:8080/cmd/report";
    String cmdLogUrl = "http://localhost:8080/cmd/log/upload";
    AgentSettings config = new AgentSettings(wsUrl, cmdStatusUrl, cmdLogUrl);

    // when: create zone with agent config
    String zonePath = ZKPaths.makePath(ROOT_PATH, "ali");
    zkClient.createEphemeral(zonePath, config.toBytes());

    // then:
    Config.AGENT_SETTINGS = Config.loadAgentConfig(server.getConnectString(), "ali", 5);
    Assert.assertNotNull(Config.agentSettings());
    Assert.assertEquals(wsUrl, Config.agentSettings().getWebSocketUrl());
    Assert.assertEquals(cmdStatusUrl, Config.agentSettings().getCmdStatusUrl());
    Assert.assertEquals(cmdLogUrl, Config.agentSettings().getCmdLogUrl());
}
 
開發者ID:FlowCI,項目名稱:flow-platform,代碼行數:20,代碼來源:ConfigTest.java

示例11: should_create_and_delete_zk_node_for_children

import org.apache.curator.utils.ZKPaths; //導入依賴的package包/類
@Test
public void should_create_and_delete_zk_node_for_children() throws Throwable {
    // init:
    String rootPath = ZKPaths.makePath("/", "flow-test");
    String childPath = ZKPaths.makePath(rootPath, "child-node");

    // when: create root and child
    zkClient.create(rootPath, null);
    zkClient.create(childPath, null);

    // then:
    Assert.assertEquals(true, zkClient.exist(rootPath));
    Assert.assertEquals(true, zkClient.exist(childPath));

    // when: delete node with children
    zkClient.delete(rootPath, true);

    // then:
    Assert.assertEquals(false, zkClient.exist(rootPath));
    Assert.assertEquals(false, zkClient.exist(childPath));
}
 
開發者ID:FlowCI,項目名稱:flow-platform,代碼行數:22,代碼來源:ZkClientTest.java

示例12: should_listen_node_change_event

import org.apache.curator.utils.ZKPaths; //導入依賴的package包/類
@Test
public void should_listen_node_change_event() throws Throwable {
    // init: create node and watch it
    String path = ZKPaths.makePath("/", "flow-test");
    zkClient.create(path, null);
    Assert.assertEquals(true, zkClient.exist(path));

    final CountDownLatch latch = new CountDownLatch(1);
    zkClient.watchNode(path, latch::countDown);

    // when:
    zkClient.setData(path, "hello".getBytes());

    // then:
    latch.await(10L, TimeUnit.SECONDS);
    Assert.assertEquals("hello", new String(zkClient.getData(path)));
}
 
開發者ID:FlowCI,項目名稱:flow-platform,代碼行數:18,代碼來源:ZkClientTest.java

示例13: after

import org.apache.curator.utils.ZKPaths; //導入依賴的package包/類
@After
public void after() throws Throwable {
    String rootPath = "/";
    for (String nodeName : zkClient.getChildren(rootPath)) {

        if (nodeName.equals("zookeeper")) {
            return;
        }

        String path = ZKPaths.makePath(rootPath, nodeName);
        zkClient.delete(path, false);
    }

    Assert.assertEquals(1, zkClient.getChildren(rootPath).size());

    zkClient.close();
}
 
開發者ID:FlowCI,項目名稱:flow-platform,代碼行數:18,代碼來源:ZkClientTest.java

示例14: deRegisterServiceInstance

import org.apache.curator.utils.ZKPaths; //導入依賴的package包/類
public void deRegisterServiceInstance(String region,
                                    String availabilityZone,
                                    String flavor,
                                    String serviceName,
                                    int servicePort, String serviceAddress) throws Exception {
    String regPath = new StringBuilder().append(registrationPath).append("/").append(region).append("/")
        .append(availabilityZone).append("/").append(flavor).toString();

    ServiceInstance<MetaData> service = getServiceInstance(serviceName, servicePort, serviceAddress, Collections.emptyMap());
    String path = ZKPaths.makePath(ZKPaths.makePath(regPath, service.getName()), service.getId());

    if (connector.isPathExists(path)) {
        log.info("Deleting key={}", path);
        connector.delete(path);
    }
}
 
開發者ID:Comcast,項目名稱:redirector,代碼行數:17,代碼來源:TestServiceUtil.java

示例15: getConsumerHostInfos

import org.apache.curator.utils.ZKPaths; //導入依賴的package包/類
public static ArrayList<HostInfo> getConsumerHostInfos(String serviceName)
{
	ArrayList<HostInfo> consumerHostInfos=new ArrayList<HostInfo>();
	String consumerDirPath="/"+serviceName+"/consumers";
	try {
		if(client.checkExists().forPath(consumerDirPath)==null)
		{
			return consumerHostInfos;
		}
		for(String childNode:ZKPaths.getSortedChildren(client.getZookeeperClient().getZooKeeper(), "/registor"+consumerDirPath))
		{
			consumerHostInfos.add(HostInfoFormatter.fromFormatString(childNode));
		}
	} catch (Exception e) {
		// TODO Auto-generated catch block
		e.printStackTrace();
	}
	return consumerHostInfos;
}
 
開發者ID:laddcn,項目名稱:grpcx,代碼行數:20,代碼來源:Register.java


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