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


Java ZKPaths.makePath方法代碼示例

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


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

示例1: 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

示例2: 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

示例3: 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

示例4: addTableMetaLock

import org.apache.curator.utils.ZKPaths; //導入方法依賴的package包/類
private void addTableMetaLock(RouteResultset rrs) throws SQLNonTransientException {
    String schema = rrs.getSchema();
    String table = rrs.getTable();
    try {
        DbleServer.getInstance().getTmManager().addMetaLock(schema, table);
        if (DbleServer.getInstance().isUseZK()) {
            String nodeName = StringUtil.getFullName(schema, table);
            String ddlPath = KVPathUtil.getDDLPath();
            String nodePth = ZKPaths.makePath(ddlPath, nodeName);
            CuratorFramework zkConn = ZKUtils.getConnection();
            int times = 0;
            while (zkConn.checkExists().forPath(KVPathUtil.getSyncMetaLockPath()) != null || zkConn.checkExists().forPath(nodePth) != null) {
                LockSupport.parkNanos(TimeUnit.MILLISECONDS.toNanos(1000));
                if (times % 60 == 0) {
                    LOGGER.info("waiting for syncMeta.lock or metaLock about " + nodeName + " in " + ddlPath);
                    times = 0;
                }
                times++;
            }
            DbleServer.getInstance().getTmManager().notifyClusterDDL(schema, table, rrs.getStatement(), DDLInfo.DDLStatus.INIT, true);
        }
    } catch (Exception e) {
        DbleServer.getInstance().getTmManager().removeMetaLock(schema, table);
        throw new SQLNonTransientException(e.toString() + ",sql:" + rrs.getStatement());
    }
}
 
開發者ID:actiontech,項目名稱:dble,代碼行數:27,代碼來源:ServerConnection.java

示例5: 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

示例6: 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

示例7: createNode

import org.apache.curator.utils.ZKPaths; //導入方法依賴的package包/類
/**
 * 創建新的配置組
 */
public void createNode() {
    String newPropertyGroupName = (String) newPropertyGroup.getValue();
    if (LOGGER.isInfoEnabled()) {
        LOGGER.info("Create new node: {}", newPropertyGroupName);
    }
    String authedNode = ZKPaths.makePath(nodeAuth.getAuthedNode(), versionMB.getSelectedVersion());
    boolean created = nodeService.createProperty(ZKPaths.makePath(authedNode, newPropertyGroupName), null);
    if (created) {
        FacesContext.getCurrentInstance().addMessage(null,
            new FacesMessage("Property group created.", newPropertyGroupName));
        refreshGroup();
        newPropertyGroup.setValue(null);
        nodeData.refreshNodeProperties(null);
    }
    else {
        FacesContext.getCurrentInstance().addMessage(null,
            new FacesMessage(FacesMessage.SEVERITY_ERROR, "Property group creation failed.", newPropertyGroupName));
    }
}
 
開發者ID:ErinDavid,項目名稱:elastic-config,代碼行數:23,代碼來源:PropertyGroupManagedBean.java

示例8: create

import org.apache.curator.utils.ZKPaths; //導入方法依賴的package包/類
private Service create(final String name, final EventSource eventSource, final boolean replicateOutbound, final Duration sleepWhenIdle) {
    final Function<Multimap<String, ByteBuffer>, Void> eventSink = new Function<Multimap<String, ByteBuffer>, Void>() {
        @Override
        public Void apply(@Nullable Multimap<String, ByteBuffer> eventsByChannel) {
            _eventStore.addAll(eventsByChannel);
            return null;
        }
    };
    final Supplier<Iterable<OwnedSubscription>> subscriptionsSupplier = () -> _subscriptionDao.getAllSubscriptions();

    LeaderService leaderService = new LeaderService(
            _curator, ZKPaths.makePath("/leader/fanout", name), _selfId, "LeaderSelector-" + name, 1, TimeUnit.MINUTES,
            new Supplier<Service>() {
                @Override
                public Service get() {
                    return new DefaultFanout(name, eventSource, eventSink, replicateOutbound, sleepWhenIdle,
                            subscriptionsSupplier, _dataCenters.getSelf(), _logFactory, _subscriptionEvaluator,
                            _metricRegistry, _clock);
                }
            });
    ServiceFailureListener.listenTo(leaderService, _metricRegistry);
    _dropwizardTask.register("databus-fanout-" + name, leaderService);
    return leaderService;
}
 
開發者ID:bazaarvoice,項目名稱:emodb,代碼行數:25,代碼來源:DefaultFanoutManager.java

示例9: takeBucketOwnership

import org.apache.curator.utils.ZKPaths; //導入方法依賴的package包/類
@Override
public CompletableFuture<Boolean> takeBucketOwnership(int bucket, String processId, Executor executor) {
    Preconditions.checkArgument(bucket < bucketCount);

    // try creating an ephemeral node
    String bucketPath = ZKPaths.makePath(ZKStoreHelper.BUCKET_OWNERSHIP_PATH, String.valueOf(bucket));

    return storeHelper.createEphemeralZNode(bucketPath, SerializationUtils.serialize(processId))
            .thenCompose(created -> {
                if (!created) {
                    // Note: data may disappear by the time we do a getData. Let exception be thrown from here
                    // so that caller may retry.
                    return storeHelper.getData(bucketPath)
                            .thenApply(data -> (SerializationUtils.deserialize(data.getData())).equals(processId));
                } else {
                    return CompletableFuture.completedFuture(true);
                }
            });
}
 
開發者ID:pravega,項目名稱:pravega,代碼行數:20,代碼來源:ZKStreamMetadataStore.java

示例10: ZkRangeStore

import org.apache.curator.utils.ZKPaths; //導入方法依賴的package包/類
public ZkRangeStore(String clientName, CuratorFramework client, String lockPath, String sequencePath, long time, TimeUnit unit,
                    long initialValue, int rangeSize) {
	this.clientName = clientName;
	this.client = client;
	this.initialValue = initialValue;
	this.rangeSize = rangeSize;
	lockPath = ZKPaths.makePath(lockPath, clientName);
	this.sequencePath = ZKPaths.makePath(sequencePath, clientName);
	this.time = time;
	this.unit = unit;
	this.lock = new InterProcessMutex(client, lockPath);
}
 
開發者ID:mm23504570,項目名稱:snowflake,代碼行數:13,代碼來源:ZkRangeStore.java

示例11: getFullPath

import org.apache.curator.utils.ZKPaths; //導入方法依賴的package包/類
@Override
public String getFullPath(String type, String... extras)
{
	String path = getParentPath(type);
	for( String child : extras )
	{
		path = ZKPaths.makePath(path, child);
	}
	return path;
}
 
開發者ID:equella,項目名稱:Equella,代碼行數:11,代碼來源:ZookeeperServiceImpl.java

示例12: AgentManager

import org.apache.curator.utils.ZKPaths; //導入方法依賴的package包/類
public AgentManager(String zkHost, int zkTimeout, String zone, String name) throws IOException {
    this.zkHost = zkHost;
    this.zkTimeout = zkTimeout;

    this.zkClient = new ZKClient(zkHost, ZK_RETRY_PERIOD, ZK_RECONNECT_TIME);
    this.zone = zone;
    this.name = name;
    this.zonePath = ZKPaths.makePath(Config.ZK_ROOT, this.zone);
    this.nodePath = ZKPaths.makePath(this.zonePath, this.name);
}
 
開發者ID:FlowCI,項目名稱:flow-platform,代碼行數:11,代碼來源:AgentManager.java

示例13: loadAgentConfig

import org.apache.curator.utils.ZKPaths; //導入方法依賴的package包/類
/**
 * connect to zk server to load config from zone data
 */
public static AgentSettings loadAgentConfig(String zkHost, String zoneName, int retry) {
    try (ZKClient zkClient = new ZKClient(zkHost, 1000, retry)) {
        zkClient.start();

        String zonePath = ZKPaths.makePath(ZK_ROOT, zoneName);
        byte[] raw = zkClient.getData(zonePath);
        return Jsonable.parse(raw, AgentSettings.class);

    } catch (Throwable e) {
        throw new RuntimeException(e);
    }
}
 
開發者ID:FlowCI,項目名稱:flow-platform,代碼行數:16,代碼來源:Config.java

示例14: should_agent_registered

import org.apache.curator.utils.ZKPaths; //導入方法依賴的package包/類
@Test
public void should_agent_registered() throws Throwable {
    // when: start agent in thread
    AgentManager agent = new AgentManager(server.getConnectString(), 20000, ZONE, MACHINE);
    new Thread(agent).start();
    Thread.sleep(5000); // wait for agent registration

    // when:
    String agentNodePath = ZKPaths.makePath(ZK_ROOT, ZONE, MACHINE);
    Assert.assertEquals(true, zkClient.exist(agentNodePath));
    agent.stop();
}
 
開發者ID:FlowCI,項目名稱:flow-platform,代碼行數:13,代碼來源:AgentManagerTest.java

示例15: registerServiceInstance

import org.apache.curator.utils.ZKPaths; //導入方法依賴的package包/類
public void registerServiceInstance(String region,
                                    String availabilityZone,
                                    String flavor,
                                    String serviceName,
                                    int servicePort,
                                    String serviceAddress,
                                    String serviceAddressV6,
                                    String weight) 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, new HashMap<String, String>() {{
        put("ipv4Address", serviceAddress);
        put("ipv6Address", serviceAddressV6);
        if (weight != null) {
            put("weight", weight);
        }
    }});

    try {
        JsonInstanceSerializer<MetaData> serializer = new JsonInstanceSerializer<>(MetaData.class);
        byte[] bytes = serializer.serialize(service);
        String path = ZKPaths.makePath(ZKPaths.makePath(regPath, service.getName()), service.getId());

        if ( ! connector.isPathExists(path)) {
            connector.createEphemeral(path);
            connector.save(new String(bytes), path);
        } else {
            log.warn("Node " + path + " already exists");
        }
    } catch (Exception e) {
        e.printStackTrace();
    }
}
 
開發者ID:Comcast,項目名稱:redirector,代碼行數:35,代碼來源:TestServiceUtil.java


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