本文整理匯總了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;
});
}
示例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);
}
}
}
示例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();
}
示例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());
}
}
示例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());
}
示例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);
}
}
示例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));
}
}
示例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;
}
示例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);
}
});
}
示例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);
}
示例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;
}
示例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);
}
示例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);
}
}
示例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();
}
示例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();
}
}