本文整理汇总了Java中org.apache.kafka.common.Node.id方法的典型用法代码示例。如果您正苦于以下问题:Java Node.id方法的具体用法?Java Node.id怎么用?Java Node.id使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类org.apache.kafka.common.Node
的用法示例。
在下文中一共展示了Node.id方法的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Java代码示例。
示例1: populateSnapshots
import org.apache.kafka.common.Node; //导入方法依赖的package包/类
private void populateSnapshots(Cluster kafkaCluster,
ClusterModel clusterModel,
TopicPartition tp,
Snapshot[] leaderLoadSnapshots) throws ModelInputException {
PartitionInfo partitionInfo = kafkaCluster.partition(tp);
// If partition info does not exist, the topic may have been deleted.
if (partitionInfo != null) {
for (Node replica : partitionInfo.replicas()) {
boolean isLeader = partitionInfo.leader() != null && replica.id() == partitionInfo.leader().id();
String rack = getRackHandleNull(replica);
// Note that we assume the capacity resolver can still return the broker capacity even if the broker
// is dead. We need this to get the host resource capacity.
Map<Resource, Double> brokerCapacity =
_brokerCapacityConfigResolver.capacityForBroker(rack, replica.host(), replica.id());
clusterModel.createReplicaHandleDeadBroker(rack, replica.id(), tp, isLeader, brokerCapacity);
// Push the load snapshot to the replica one by one.
for (int i = 0; i < leaderLoadSnapshots.length; i++) {
clusterModel.pushLatestSnapshot(rack, replica.id(), tp,
isLeader ? leaderLoadSnapshots[i].duplicate() : MonitorUtils.toFollowerSnapshot(leaderLoadSnapshots[i]));
}
}
}
}
示例2: isValidSample
import org.apache.kafka.common.Node; //导入方法依赖的package包/类
/**
* This is a simple sanity check on the sample data. We only verify that
* <p>
* 1. the broker of the sampled data is from the broker who holds the leader replica. If it is not, we simply
* discard the data because leader migration may have occurred so the metrics on the old data might not be
* accurate anymore.
* <p>
* 2. The sample contains metric for all the resources.
*
* @param sample the sample to do the sanity check.
* @param leaderValidation whether skip the leader validation or not.
* @return <tt>true</tt> if the sample is valid.
*/
private boolean isValidSample(PartitionMetricSample sample, boolean leaderValidation) {
boolean validLeader = true;
if (leaderValidation) {
Node leader = _metadata.fetch().leaderFor(sample.topicPartition());
validLeader = (leader != null) && (sample.brokerId() == leader.id());
if (!validLeader) {
LOG.warn("The metric sample is discarded due to invalid leader. Current leader {}, Sample: {}", leader, sample);
}
}
boolean completeMetrics = sample.numMetrics() == Resource.values().length;
if (!completeMetrics) {
LOG.warn("The metric sample is discarded due to missing metrics. Sample: {}", sample);
}
return validLeader && completeMetrics;
}
示例3: isReplicaMovementDone
import org.apache.kafka.common.Node; //导入方法依赖的package包/类
private boolean isReplicaMovementDone(Cluster cluster, TopicPartition tp, ExecutionTask task) {
boolean destinationExists = false;
boolean sourceExists = false;
for (Node node : cluster.partition(tp).replicas()) {
destinationExists = destinationExists || (node.id() == task.destinationBrokerId());
sourceExists = sourceExists || (node.id() == task.sourceBrokerId());
}
switch (task.state()) {
case IN_PROGRESS:
return destinationExists && !sourceExists;
case ABORTING:
return !destinationExists && sourceExists;
case DEAD:
return !destinationExists && !sourceExists;
default:
throw new IllegalStateException("Should never be here. State " + task.state());
}
}
示例4: populateBrokerMetaData
import org.apache.kafka.common.Node; //导入方法依赖的package包/类
private void populateBrokerMetaData() {
for (TopicMetadata topicMetadata : topicMetadataMap.values()) {
for (PartitionMetadata partitionMetadata : topicMetadata.partitionMetadata()) {
int leader = partitionMetadata.leader().id();
BrokerMetaData leaderBroker = brokerMetaDataMap.get(leader);
if (leaderBroker != null) {
leaderBroker.incrementNumLeaders();
}
for (Node replica : partitionMetadata.replicas()) {
int follower = replica.id();
if (leader != follower) {
BrokerMetaData followerBroker = brokerMetaDataMap.get(follower);
if (followerBroker != null) {
followerBroker.incrementNumFollowers();
}
}
}
}
}
log.debug("Broker meta cache" + BROKERS_TOPICS_CACHE_INSTANCE.getBrokerMetaDataMap());
}
示例5: getTargetBroker
import org.apache.kafka.common.Node; //导入方法依赖的package包/类
private int getTargetBroker(List<Node> replicas, int leader) {
int index = 0;
int mostLoaded = Integer.MIN_VALUE;
int size = replicas.size();
for (int i = size - 1; i >= 0; i--) {
Node node = replicas.get(i);
int id = node.id();
if (id == leader) {
continue;
}
Integer numFollowers = brokersInfo.get(id).getNumFollowers();
if (mostLoaded < numFollowers) {
mostLoaded = numFollowers;
index = i;
}
}
return replicas.remove(index).id();
}
示例6: fillInFollowerBytesInRate
import org.apache.kafka.common.Node; //导入方法依赖的package包/类
private void fillInFollowerBytesInRate(Cluster cluster, Map<Integer, Map<String, Integer>> leaderDistributionStats) {
synchronized (this) {
if (!_brokerFollowerLoad.isEmpty()) {
return;
}
for (Node node : cluster.nodes()) {
_brokerFollowerLoad.putIfAbsent(node.id(), 0.0);
BrokerLoad brokerLoad = _brokerLoad.get(node.id());
if (brokerLoad == null) {
// new broker?
continue;
}
for (PartitionInfo partitionInfo : cluster.partitionsForNode(node.id())) {
IOLoad topicIOLoad = brokerLoad.ioLoad(partitionInfo.topic(), partitionInfo.partition());
if (topicIOLoad == null) {
// The topic did not report any IO metric and the partition does not exist on the broker.
LOG.debug("No IO load reported from broker {} for partition {}-{}",
node.id(), partitionInfo.topic(), partitionInfo.partition());
continue;
}
int numLeadersOnBroker = leaderDistributionStats.get(node.id()).get(partitionInfo.topic());
double partitionBytesIn = topicIOLoad.bytesIn() / numLeadersOnBroker;
for (Node replica : partitionInfo.replicas()) {
if (replica.id() != node.id()) {
_brokerFollowerLoad.merge(replica.id(), partitionBytesIn, (v0, v1) -> v0 + v1);
}
}
}
}
}
}
示例7: isReplicaDeletionDone
import org.apache.kafka.common.Node; //导入方法依赖的package包/类
private boolean isReplicaDeletionDone(Cluster cluster, TopicPartition tp, ExecutionTask task) {
boolean sourceExists = false;
for (Node node : cluster.partition(tp).replicas()) {
sourceExists = sourceExists || (node.id() == task.sourceBrokerId());
}
return !sourceExists;
}
示例8: isReplicaAdditionDone
import org.apache.kafka.common.Node; //导入方法依赖的package包/类
private boolean isReplicaAdditionDone(Cluster cluster, TopicPartition tp, ExecutionTask task) {
boolean destinationExists = false;
for (Node node : cluster.partition(tp).replicas()) {
destinationExists = destinationExists || (node.id() == task.destinationBrokerId());
}
switch (task.state()) {
case IN_PROGRESS:
return destinationExists;
case ABORTING:
case DEAD:
return true;
default:
throw new IllegalStateException("Should never be here.");
}
}
示例9: isLeadershipMovementDone
import org.apache.kafka.common.Node; //导入方法依赖的package包/类
private boolean isLeadershipMovementDone(Cluster cluster, TopicPartition tp, ExecutionTask task) {
Node leader = cluster.leaderFor(tp);
switch (task.state()) {
case IN_PROGRESS:
return leader != null && leader.id() == task.destinationBrokerId();
case ABORTING:
case DEAD:
return true;
default:
throw new IllegalStateException("Should never be here.");
}
}
示例10: populateBrokerData
import org.apache.kafka.common.Node; //导入方法依赖的package包/类
/**
* Populates broker data for a given topic.
*
* @param topicMetadata
* Topic metadata
* @param brokersInfo
* <broker_id, brokerInfo> map
* @param brokerMetaDataMap
* Broker Id - > BrokerMetaData Map
*/
public void populateBrokerData(TopicMetadata topicMetadata, Map<Integer, Broker> brokersInfo,
Map<Integer, BrokerMetaData> brokerMetaDataMap) {
// iterate through the topic metainfo
log.debug("Topic: " + topicMetadata.topic());
for (PartitionMetadata part : topicMetadata.partitionMetadata()) {
String replicas = "";
List<Integer> partitionReplicas = new ArrayList<>();
String leaderHost = part.leader().host();
int leaderId = part.leader().id();
int partitionId = part.partition();
addToBrokerList(partitionId, leaderId, brokersInfo, brokerMetaDataMap, true);
partitionReplicas.add(leaderId);
for (Node replica : part.replicas()) {
int followerId = replica.id();
replicas += " " + followerId;
// dont add leader as replica also
if (leaderId != followerId) {
addToBrokerList(partitionId, followerId, brokersInfo, brokerMetaDataMap, false);
partitionReplicas.add(followerId);
}
}
log.debug(" Partition: " + partitionId + ": Leader: " + leaderHost + " Replicas:[" + replicas + "] ");
}
}
示例11: getControllerNode
import org.apache.kafka.common.Node; //导入方法依赖的package包/类
private Node getControllerNode(int controllerId, Collection<Node> brokers) {
for (Node broker : brokers) {
if (broker.id() == controllerId)
return broker;
}
return null;
}
示例12: leaderChanged
import org.apache.kafka.common.Node; //导入方法依赖的package包/类
private static boolean leaderChanged(PartitionInfo prevPartInfo, PartitionInfo currPartInfo) {
Node prevLeader = prevPartInfo.leader();
Node currLeader = currPartInfo.leader();
return !(prevLeader == null && currLeader == null) && !(prevLeader != null && currLeader != null
&& prevLeader.id() == currLeader.id());
}
示例13: process
import org.apache.kafka.common.Node; //导入方法依赖的package包/类
MetricSampler.Samples process(Cluster cluster,
Collection<TopicPartition> partitions,
MetricSampler.SamplingMode samplingMode) {
Map<Integer, Map<String, Integer>> leaderDistributionStats = leaderDistributionStats(cluster);
fillInFollowerBytesInRate(cluster, leaderDistributionStats);
//TODO: maybe need to skip the entire processing logic if broker load is not consistent.
// Theoretically we should not move forward at all if a broker reported a different all topic bytes in from all
// its resident replicas. However, it is not clear how often this would happen yet. At this point we still
// continue process the other brokers. Later on if in practice all topic bytes in and the aggregation value is
// rarely inconsistent we can just stop the sample generation when the this happens.
_brokerLoad.values().forEach(BrokerLoad::validate);
Set<PartitionMetricSample> partitionMetricSamples = new HashSet<>();
Set<BrokerMetricSample> brokerMetricSamples = new HashSet<>();
int skippedPartition = 0;
if (samplingMode == MetricSampler.SamplingMode.ALL
|| samplingMode == MetricSampler.SamplingMode.PARTITION_METRICS_ONLY) {
for (TopicPartition tp : partitions) {
try {
PartitionMetricSample sample = buildPartitionMetricSample(cluster, tp, leaderDistributionStats);
if (sample != null) {
LOG.debug("Added partition metrics sample for {}", tp);
partitionMetricSamples.add(sample);
} else {
skippedPartition++;
}
} catch (Exception e) {
LOG.error("Error building partition metric sample for " + tp, e);
skippedPartition++;
}
}
}
int skippedBroker = 0;
if (samplingMode == MetricSampler.SamplingMode.ALL
|| samplingMode == MetricSampler.SamplingMode.BROKER_METRICS_ONLY) {
for (Node node : cluster.nodes()) {
BrokerLoad brokerLoad = _brokerLoad.get(node.id());
if (brokerLoad == null || !brokerLoad.isValid()) {
// A new broker or broker metrics are not consistent.
LOG.debug("Skip generating broker metric sample for broker {} because it does not have IO load metrics or "
+ "the metrics are inconsistent.", node.id());
skippedBroker++;
continue;
}
double leaderCpuUtil = brokerLoad.cpuUtil();
if (leaderCpuUtil > 0) {
BrokerMetricSample brokerMetricSample =
new BrokerMetricSample(node.id(),
leaderCpuUtil,
brokerLoad.bytesIn() / BYTES_IN_KB,
brokerLoad.bytesOut() / BYTES_IN_KB,
// The replication bytes in is only available from Kafka 0.11.0 and above.
(brokerLoad.replicationBytesIn() > 0 ?
brokerLoad.replicationBytesIn() : _brokerFollowerLoad.get(node.id())) / BYTES_IN_KB,
brokerLoad.replicationBytesOut() / BYTES_IN_KB,
brokerLoad.messagesInRate(),
brokerLoad.produceRequestRate(),
brokerLoad.consumerFetchRequestRate(),
brokerLoad.followerFetchRequestRate(),
brokerLoad.requestHandlerAvgIdlePercent(),
-1.0,
brokerLoad.allTopicsProduceRequestRate(),
brokerLoad.allTopicsFetchRequestRate(),
_maxMetricTimestamp);
LOG.debug("Added broker metric sample for broker {}", node.id());
brokerMetricSamples.add(brokerMetricSample);
} else {
skippedBroker++;
}
}
}
LOG.info("Generated {}{} partition metric samples and {}{} broker metric samples for timestamp {}",
partitionMetricSamples.size(), skippedPartition > 0 ? "(" + skippedPartition + " skipped)" : "",
brokerMetricSamples.size(), skippedBroker > 0 ? "(" + skippedBroker + " skipped)" : "",
_maxMetricTimestamp);
return new MetricSampler.Samples(partitionMetricSamples, brokerMetricSamples);
}
示例14: testCommitsFetchedDuringAssign
import org.apache.kafka.common.Node; //导入方法依赖的package包/类
@Test
public void testCommitsFetchedDuringAssign() {
long offset1 = 10000;
long offset2 = 20000;
int rebalanceTimeoutMs = 6000;
int sessionTimeoutMs = 3000;
int heartbeatIntervalMs = 2000;
int autoCommitIntervalMs = 1000;
Time time = new MockTime();
Cluster cluster = TestUtils.singletonCluster(topic, 1);
Node node = cluster.nodes().get(0);
Metadata metadata = createMetadata();
metadata.update(cluster, Collections.<String>emptySet(), time.milliseconds());
MockClient client = new MockClient(time, metadata);
client.setNode(node);
PartitionAssignor assignor = new RoundRobinAssignor();
final KafkaConsumer<String, String> consumer = newConsumer(time, client, metadata, assignor,
rebalanceTimeoutMs, sessionTimeoutMs, heartbeatIntervalMs, true, autoCommitIntervalMs);
consumer.assign(singletonList(tp0));
// lookup coordinator
client.prepareResponseFrom(new FindCoordinatorResponse(Errors.NONE, node), node);
Node coordinator = new Node(Integer.MAX_VALUE - node.id(), node.host(), node.port());
// fetch offset for one topic
client.prepareResponseFrom(
offsetResponse(Collections.singletonMap(tp0, offset1), Errors.NONE),
coordinator);
assertEquals(offset1, consumer.committed(tp0).offset());
consumer.assign(Arrays.asList(tp0, tp1));
// fetch offset for two topics
Map<TopicPartition, Long> offsets = new HashMap<>();
offsets.put(tp0, offset1);
client.prepareResponseFrom(offsetResponse(offsets, Errors.NONE), coordinator);
assertEquals(offset1, consumer.committed(tp0).offset());
offsets.remove(tp0);
offsets.put(tp1, offset2);
client.prepareResponseFrom(offsetResponse(offsets, Errors.NONE), coordinator);
assertEquals(offset2, consumer.committed(tp1).offset());
consumer.close(0, TimeUnit.MILLISECONDS);
}
示例15: testManualAssignmentChangeWithAutoCommitEnabled
import org.apache.kafka.common.Node; //导入方法依赖的package包/类
@Test
public void testManualAssignmentChangeWithAutoCommitEnabled() {
int rebalanceTimeoutMs = 60000;
int sessionTimeoutMs = 30000;
int heartbeatIntervalMs = 3000;
int autoCommitIntervalMs = 1000;
Time time = new MockTime();
Map<String, Integer> tpCounts = new HashMap<>();
tpCounts.put(topic, 1);
tpCounts.put(topic2, 1);
Cluster cluster = TestUtils.singletonCluster(tpCounts);
Node node = cluster.nodes().get(0);
Metadata metadata = createMetadata();
metadata.update(cluster, Collections.<String>emptySet(), time.milliseconds());
MockClient client = new MockClient(time, metadata);
client.setNode(node);
PartitionAssignor assignor = new RangeAssignor();
final KafkaConsumer<String, String> consumer = newConsumer(time, client, metadata, assignor,
rebalanceTimeoutMs, sessionTimeoutMs, heartbeatIntervalMs, true, autoCommitIntervalMs);
// lookup coordinator
client.prepareResponseFrom(new FindCoordinatorResponse(Errors.NONE, node), node);
Node coordinator = new Node(Integer.MAX_VALUE - node.id(), node.host(), node.port());
// manual assignment
consumer.assign(Arrays.asList(tp0));
consumer.seekToBeginning(Arrays.asList(tp0));
// fetch offset for one topic
client.prepareResponseFrom(
offsetResponse(Collections.singletonMap(tp0, 0L), Errors.NONE),
coordinator);
assertEquals(0, consumer.committed(tp0).offset());
// verify that assignment immediately changes
assertTrue(consumer.assignment().equals(Collections.singleton(tp0)));
// there shouldn't be any need to lookup the coordinator or fetch committed offsets.
// we just lookup the starting position and send the record fetch.
client.prepareResponse(listOffsetsResponse(Collections.singletonMap(tp0, 10L), Errors.NONE));
client.prepareResponse(fetchResponse(tp0, 10L, 1));
ConsumerRecords<String, String> records = consumer.poll(0);
assertEquals(1, records.count());
assertEquals(11L, consumer.position(tp0));
// mock the offset commit response for to be revoked partitions
AtomicBoolean commitReceived = prepareOffsetCommitResponse(client, coordinator, tp0, 11);
// new manual assignment
consumer.assign(Arrays.asList(t2p0));
// verify that assignment immediately changes
assertTrue(consumer.assignment().equals(Collections.singleton(t2p0)));
// verify that the offset commits occurred as expected
assertTrue(commitReceived.get());
client.requests().clear();
consumer.close();
}