- 使用 Spring Initializr 创建 Spring Boot 应用程序
- 在Spring Boot中配置Cassandra
- 在 Spring Boot 上配置 Tomcat 连接池
- 将Camel消息路由到嵌入WildFly的Artemis上
本文整理了Java中com.taobao.metamorphosis.utils.ZkUtils
类的一些代码示例,展示了ZkUtils
类的具体用法。这些代码示例主要来源于Github
/Stackoverflow
/Maven
等平台,是从一些精选项目中提取出来的代码,具有较强的参考意义,能在一定程度帮忙到你。ZkUtils
类的具体详情如下:
包路径:com.taobao.metamorphosis.utils.ZkUtils
类名称:ZkUtils
[英]zkĹ
[中]zkĹ
代码示例来源:origin: killme2008/Metamorphosis
final List<String> brokers = ZkUtils.getChildren(this.zkClient, this.brokerIdsPath + "/" + brokerId);
if (brokers == null) {
return ret;
ZkUtils.readDataMaybeNull(this.zkClient, this.brokerIdsPath + "/" + brokerId + "/" + broker);
if (StringUtils.isNotBlank(brokerData)) {
ret.add(new Broker(brokerId, brokerData + "?slaveId=" + slaveId));
代码示例来源:origin: killme2008/Metamorphosis
for (final String topic : topics) {
List<String> partList = null;
final List<String> brokers = ZkUtils.getChildren(this.zkClient, this.brokerTopicsSubPath + "/" + topic);
for (final String broker : brokers) {
final String[] tmp = StringUtils.split(broker, "-");
if (tmp != null && tmp.length == 2) {
String path = this.brokerTopicsSubPath + "/" + topic + "/" + broker;
String brokerData = ZkUtils.readData(this.zkClient, path);
try {
final TopicBroker topicBroker = TopicBroker.parse(brokerData);
代码示例来源:origin: killme2008/Metamorphosis
throws Exception {
try {
createEphemeralPath(client, path, data);
storedData = readData(client, path);
代码示例来源:origin: killme2008/Metamorphosis
/**
* zkѯmaster broker,null
* */
public Broker getMasterBrokerById(final int brokerId) {
final String brokersString = ZkUtils.readDataMaybeNull(this.zkClient, this.brokerIdsPathOf(brokerId, -1));
if (StringUtils.isNotBlank(brokersString)) {
return new Broker(brokerId, brokersString);
}
return null;
}
代码示例来源:origin: killme2008/Metamorphosis
/**
* һbrokertopics
*
* */
public Set<String> getTopicsByBrokerIdFromMaster(final int brokerId) {
final Set<String> set = new HashSet<String>();
final List<String> allTopics = ZkUtils.getChildren(this.zkClient, this.brokerTopicsSubPath);
for (final String topic : allTopics) {
final List<String> brokers = ZkUtils.getChildren(this.zkClient, this.brokerTopicsSubPath + "/" + topic);
if (brokers != null && brokers.size() > 0) {
for (final String broker : brokers) {
if ((String.valueOf(brokerId) + "-m").equals(broker)) {
set.add(topic);
}
}
}
}
return set;
}
代码示例来源:origin: com.taobao.metamorphosis/metamorphosis-tools
public void setOffset(String topic, String group, Partition partition, String srcOffset) throws Exception {
String path = query.getOffsetPath(group, topic, partition);
ZkUtils.updatePersistentPath(this.query.getZkClient(), path, srcOffset);
}
}
代码示例来源:origin: com.taobao.metamorphosis/metamorphosis-client
/**
* consumerIdȡĵtopicб
*
* @param consumerId
* @return
* @throws Exception
*/
protected List<String> getTopics(final String consumerId) throws Exception {
final String topicsString =
ZkUtils.readData(ConsumerZooKeeper.this.zkClient, this.dirs.consumerRegistryDir + "/" + consumerId);
if (StringUtils.isBlank(topicsString)) {
return Collections.emptyList();
}
final String[] topics = topicsString.split(",");
final List<String> rt = new ArrayList<String>(topics.length);
for (final String topic : topics) {
rt.add(topic);
}
return rt;
}
}
代码示例来源:origin: com.taobao.metamorphosis/metamorphosis-client
for (int i = 0; i < MAX_N_RETRIES; i++) {
ZkUtils.makeSurePersistentPathExists(this.zkClient, dirs.consumerRegistryDir);
ZkUtils.createEphemeralPathExpectConflict(this.zkClient, dirs.consumerRegistryDir + "/"
+ loadBalanceListener.consumerIdString, topicString);
ZkUtils.makeSurePersistentPathExists(this.zkClient, partitionPath);
this.zkClient.subscribeChildChanges(partitionPath, loadBalanceListener);
代码示例来源:origin: killme2008/Metamorphosis
/**
* Create an ephemeral node with the given path and data. Create parents if
* necessary.
*/
public static void createEphemeralPath(final ZkClient client, final String path, final String data)
throws Exception {
try {
client.createEphemeral(path, data);
}
catch (final ZkNoNodeException e) {
createParentPath(client, path);
client.createEphemeral(path, data);
}
}
代码示例来源:origin: com.taobao.metamorphosis/metamorphosis-client
private void deleteOwnership(final String znode) {
try {
ZkUtils.deletePath(ConsumerZooKeeper.this.zkClient, znode);
}
catch (final Throwable t) {
log.error("exception during releasePartitionOwnership", t);
}
if (log.isDebugEnabled()) {
log.debug("Consumer " + this.consumerIdString + " releasing " + znode);
}
}
代码示例来源:origin: com.taobao.metamorphosis/metamorphosis-client
/**
* ӷownerϵ
*
* @param topicDirs
* @param partition
* @param topic
* @param consumerThreadId
* @return
*/
protected boolean ownPartition(final ZKGroupTopicDirs topicDirs, final String partition, final String topic,
final String consumerThreadId) throws Exception {
final String partitionOwnerPath = topicDirs.consumerOwnerDir + "/" + partition;
try {
ZkUtils.createEphemeralPathExpectConflict(ConsumerZooKeeper.this.zkClient, partitionOwnerPath,
consumerThreadId);
}
catch (final ZkNodeExistsException e) {
// ԭʼĹϵӦѾɾԺ
log.info("waiting for the partition ownership to be deleted: " + partition);
return false;
}
catch (final Exception e) {
throw e;
}
this.addPartitionTopicInfo(topicDirs, partition, topic, consumerThreadId);
return true;
}
代码示例来源:origin: com.taobao.metamorphosis/metamorphosis-client
private void publishTopicInternal(final String topic, final BrokerConnectionListener listener) throws Exception,
NotifyRemotingException, InterruptedException {
final String partitionPath = this.metaZookeeper.brokerTopicsPubPath + "/" + topic;
ZkUtils.makeSurePersistentPathExists(ProducerZooKeeper.this.zkClient, partitionPath);
ProducerZooKeeper.this.zkClient.subscribeChildChanges(partitionPath, listener);
// һҪͬȴ
listener.syncedUpdateBrokersInfo();
}
代码示例来源:origin: killme2008/Metamorphosis
List<Partition> partList = null;
final String dataString =
ZkUtils.readDataMaybeNull(this.zkClient, this.brokerTopicsPathOf(topic, false, brokerId, -1));
if (StringUtils.isBlank(dataString)) {
continue;
代码示例来源:origin: killme2008/Metamorphosis
/**
* طָtopicmaster brokers
* */
public Map<Integer, String> getMasterBrokersByTopic(final String topic) {
final Map<Integer, String> ret = new TreeMap<Integer, String>();
final List<String> brokerIds = ZkUtils.getChildren(this.zkClient, this.brokerTopicsPubPath + "/" + topic);
if (brokerIds == null) {
return ret;
}
for (final String brokerIdStr : brokerIds) {
if (!brokerIdStr.endsWith("-m")) {
continue;
}
final int brokerId = Integer.parseInt(StringUtils.split(brokerIdStr, "-")[0]);
final Broker broker = this.getMasterBrokerById(brokerId);
if (broker != null) {
ret.put(brokerId, broker.getZKString());
}
}
return ret;
}
代码示例来源:origin: com.taobao.metamorphosis/metamorphosis-client
ZkUtils.updatePersistentPath(this.zkClient, topicDirs.consumerOffsetDir + "/"
+ info.getPartition().toString(), msgId + "-" + newOffset);
代码示例来源:origin: killme2008/Metamorphosis
/**
* Update the value of a persistent node with the given path and data.
* create parrent directory if necessary. Never throw NodeExistException.
*/
public static void updatePersistentPath(final ZkClient client, final String path, final String data)
throws Exception {
try {
client.writeData(path, data);
}
catch (final ZkNoNodeException e) {
createParentPath(client, path);
client.createPersistent(path, data);
}
catch (final Exception e) {
throw e;
}
}
代码示例来源:origin: com.taobao.metamorphosis/metamorphosis-client
ZkUtils.deletePath(this.zkClient, listener.dirs.consumerRegistryDir + "/"
+ listener.consumerIdString);
代码示例来源:origin: com.taobao.metamorphosis/metamorphosis-client
@Override
public TopicPartitionRegInfo load(final String topic, final String group, final Partition partition) {
final ZKGroupTopicDirs topicDirs = this.metaZookeeper.new ZKGroupTopicDirs(topic, group);
final String znode = topicDirs.consumerOffsetDir + "/" + partition.toString();
final String offsetString = ZkUtils.readDataMaybeNull(this.zkClient, znode);
if (offsetString == null) {
return null;
}
else {
// Ͽͻ
final int index = offsetString.lastIndexOf("-");
if (index > 0) {
// 1.4ʼ¿ͻ
final long msgId = Long.parseLong(offsetString.substring(0, index));
final long offset = Long.parseLong(offsetString.substring(index + 1));
return new TopicPartitionRegInfo(topic, partition, offset, msgId);
}
else {
// Ͽͻ
final long offset = Long.parseLong(offsetString);
return new TopicPartitionRegInfo(topic, partition, offset);
}
}
}
代码示例来源:origin: killme2008/Metamorphosis
for (final String topic : topics) {
List<Partition> partList = null;
final List<String> brokers = ZkUtils.getChildren(this.zkClient, this.brokerTopicsPubPath + "/" + topic);
for (final String broker : brokers) {
final String[] brokerStrs = StringUtils.split(broker, "-");
if (this.isMaster(brokerStrs)) {
String path = this.brokerTopicsPubPath + "/" + topic + "/" + broker;
String brokerData = ZkUtils.readData(this.zkClient, path);
try {
final TopicBroker topicBroker = TopicBroker.parse(brokerData);
代码示例来源:origin: killme2008/Metamorphosis
/**
* brokerȺ,slavemaster
*
* @param zkClient
* @return
*/
public Cluster getCluster() {
final Cluster cluster = new Cluster();
final List<String> nodes = ZkUtils.getChildren(this.zkClient, this.brokerIdsPath);
for (final String node : nodes) {
// String brokerZKString = readData(zkClient, brokerIdsPath + "/" +
// node);
final int brokerId = Integer.parseInt(node);
final Set<Broker> brokers = this.getBrokersById(brokerId);
if (brokers != null && !brokers.isEmpty()) {
cluster.addBroker(brokerId, brokers);
}
}
return cluster;
}
我在这个网站上发布的代码有这个问题 https://developers.google.com/drive/quickstart-cs是 Google Drive 快速入门的开发人员站点。我按照网站上
我正在尝试制作一个非常简单的 Kafka Producer,目前正在关注 producer example除了我的制作人没有分区程序类。 将所需文件导出到 jar 后,我将它们传输到我的 Linux
问题 在java中,我有一个“Util项目”,在进行单元测试时使用另一个“Mock项目”。 我的问题是“模拟项目”也使用“Util项目”来构建一些模拟对象。 当我使用 Maven 构建项目时,我无法构
据我所知,这些包已经存在很长时间了。但是,我从未见过它们的实际用法。而且这些包似乎不成熟,不再维护。如果是,为什么这些包现在存在? 最佳答案 包裹automata被 scala.xml.dtd 使用,
关闭。这个问题需要debugging details .它目前不接受答案。 想改进这个问题?将问题更新为 on-topic对于堆栈溢出。 1年前关闭。 Improve this question Co
在java.util.Collections中,有一个方法: public static void fill(List list, T obj) 用第二个参数指定的对象填充第一个参数指定的List。
我不明白它要我做什么。分配给 sentence正在工作: val sentences : java.util.List[CoreMap] = document.get(classOf[Sentence
在我的 React 应用程序中,我想使用一些实用程序。我见过两种不同的方法。第一个是,只是创建函数并将其导出。第二个是,创建一个 Util 类并导出一个对象,这样它就不能被实例化(静态类)。 clas
我有一个 util 类,它接受 String jwtToken 和 Key key 并使用 io.jsonwebtoken.jwts 解码 jwt。 但是,我无法对此进行测试。原因是,我无法模拟公钥并
我有使用目标命名空间的专有架构 xmlns:ax216="http://util.java/xsd" 这给我带来了从 java (java.util.xsd) 开始生成禁止的(由 Java 安全管理器
我正在阅读集合以查看 Javadocs 中的实现层次结构。 Collections声明为public class Collections extendds Object Collection声明为pu
我正在使用 Spring-boot 应用程序,我可以在其中连接 Azure 应用程序配置。但是当我尝试使用内容类型应用程序/JSON 读取值时出现错误。 我的Java类 @ConfigurationP
我正在使用 Spring-boot 应用程序,我可以在其中连接 Azure 应用程序配置。但是当我尝试使用内容类型应用程序/JSON 读取值时出现错误。 我的Java类 @ConfigurationP
我在使用格式说明符时遇到问题。这是否意味着我正在使用 %d? public static void main(String[] args) { double y, x; for (x =
鉴于此代码 import java.util.Iterator; private static List someList = new ArrayList(); public static void
我正在 HackerEarth 解决问题,我无法弄清楚为什么我的程序在命令行上正确运行并给出正确的结果,但在代码编辑器上运行时却给出 java.util.NoSuchElementException
我正在尝试使用以下代码使用对象列表列表中的数据填充tableModel readExcel.readSheet(0): TableModel tableModel = new DefaultTabl
java.util.Set 、 java.util.List 和其他 Collection 接口(interface)不可序列化。需要一个简单、直接的解决方案来在可序列化的 POJO 中使用它。 pu
我试图从 servlet 返回数据库搜索结果的 ArrayList 以显示在 jsp 页面上。 在servlet中设置arraylist作为请求的属性,并将请求转发到jsp页面。当我尝试在 jsp 页
我是android新手,最近我试图从firebase中提取数据到recyclerview/cardview中以垂直布局显示数据,它显示将Hashmap转换为Arraylist的错误,其中代码是:
我是一名优秀的程序员,十分优秀!