本文整理匯總了Java中org.apache.kafka.clients.consumer.Consumer.poll方法的典型用法代碼示例。如果您正苦於以下問題:Java Consumer.poll方法的具體用法?Java Consumer.poll怎麽用?Java Consumer.poll使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類org.apache.kafka.clients.consumer.Consumer
的用法示例。
在下文中一共展示了Consumer.poll方法的13個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。
示例1: readKeyValues
import org.apache.kafka.clients.consumer.Consumer; //導入方法依賴的package包/類
/**
* Returns up to `maxMessages` by reading via the provided consumer (the topic(s) to read from
* are already configured in the consumer).
*
* @param topic Kafka topic to read messages from
* @param consumer Kafka consumer
* @param waitTime Maximum wait time in milliseconds
* @param maxMessages Maximum number of messages to read via the consumer
* @return The KeyValue elements retrieved via the consumer
*/
private static <K, V> List<KeyValue<K, V>> readKeyValues(final String topic,
final Consumer<K, V> consumer, final long waitTime, final int maxMessages) {
final List<KeyValue<K, V>> consumedValues;
consumer.subscribe(Collections.singletonList(topic));
final int pollIntervalMs = 100;
consumedValues = new ArrayList<>();
int totalPollTimeMs = 0;
while (totalPollTimeMs < waitTime &&
continueConsuming(consumedValues.size(), maxMessages)) {
totalPollTimeMs += pollIntervalMs;
final ConsumerRecords<K, V> records = consumer.poll(pollIntervalMs);
for (final ConsumerRecord<K, V> record : records) {
consumedValues.add(new KeyValue<>(record.key(), record.value()));
}
}
return consumedValues;
}
示例2: pollCommunicateOnce
import org.apache.kafka.clients.consumer.Consumer; //導入方法依賴的package包/類
private void pollCommunicateOnce(Consumer<ByteBuffer, ByteBuffer> consumer) {
ConsumerRecords<ByteBuffer, ByteBuffer> records = consumer.poll(POLL_TIMEOUT);
if (records.isEmpty()) {
if (!stalled && checkStalled(consumer)) {
LOGGER.info("[I] Loader stalled {} / {}", f(leadId), f(localLoaderId));
stalled = true;
lead.notifyLocalLoaderStalled(leadId, localLoaderId);
}
// ToDo: Consider sending empty messages for heartbeat sake.
return;
}
if (stalled) {
stalled = false;
}
MutableLongList committedIds = new LongArrayList(records.count());
for (ConsumerRecord<ByteBuffer, ByteBuffer> record : records) {
committedIds.add(record.timestamp());
}
committedIds.sortThis();
lead.updateInitialContext(localLoaderId, committedIds);
consumer.commitSync();
}
示例3: readKeyValues
import org.apache.kafka.clients.consumer.Consumer; //導入方法依賴的package包/類
/**
* Returns up to `maxMessages` by reading via the provided consumer (the topic(s) to read from
* are already configured in the consumer).
*
* @param topic Kafka topic to read messages from
* @param consumer Kafka consumer
* @param waitTime Maximum wait time in milliseconds
* @param maxMessages Maximum number of messages to read via the consumer
* @return The KeyValue elements retrieved via the consumer
*/
private static <K, V> List<KeyValue<K, V>> readKeyValues(final String topic,
final Consumer<K, V> consumer, final long waitTime, final int maxMessages) {
final List<KeyValue<K, V>> consumedValues;
consumer.subscribe(Collections.singletonList(topic));
final int pollIntervalMs = 100;
consumedValues = new ArrayList<>();
int totalPollTimeMs = 0;
while (totalPollTimeMs < waitTime &&
continueConsuming(consumedValues.size(), maxMessages)) {
totalPollTimeMs += pollIntervalMs;
final ConsumerRecords<K, V> records = consumer.poll(pollIntervalMs);
for (final ConsumerRecord<K, V> record : records) {
consumedValues.add(new KeyValue<>(record.key(), record.value()));
}
}
return consumedValues;
}
示例4: main
import org.apache.kafka.clients.consumer.Consumer; //導入方法依賴的package包/類
public static void main(String[] args) {
String topic = "persistent://sample/standalone/ns/my-topic";
Properties props = new Properties();
props.put("bootstrap.servers", "pulsar://localhost:6650");
props.put("group.id", "my-subscription-name");
props.put("enable.auto.commit", "false");
props.put("key.deserializer", IntegerDeserializer.class.getName());
props.put("value.deserializer", StringDeserializer.class.getName());
Consumer<Integer, String> consumer = new KafkaConsumer<>(props);
consumer.subscribe(Arrays.asList(topic));
while (true) {
ConsumerRecords<Integer, String> records = consumer.poll(100);
records.forEach(record -> {
log.info("Received record: {}", record);
});
// Commit last offset
consumer.commitSync();
}
}
示例5: run
import org.apache.kafka.clients.consumer.Consumer; //導入方法依賴的package包/類
@Override
public void run() {
Consumer<String, Property> consumer = ConsumerFactory.getPropertyConsumer();
consumer.subscribe(Arrays.asList(Topics.SAVE_PROPERTY));
try {
while (true) {
ConsumerRecords<String, Property> records = consumer.poll(POLL_DELAY);
LOGGER.log(Level.INFO, "records fetched to persist {0}", records.count());
for (ConsumerRecord<String, Property> record : records) {
Property property = record.value();
propertyService.save(property);
}
}
} catch (Exception e) {
LOGGER.log(Level.SEVERE, null, e);
} finally {
consumer.close();
}
}
示例6: pollForResults
import org.apache.kafka.clients.consumer.Consumer; //導入方法依賴的package包/類
/**
* Polls a {@link Consumer> until it has either polled too many times without hitting the target number
* of results, or it hits the target number of results.
*
* @param pollMs - How long each poll could take.
* @param pollIterations - The maximum number of polls that will be attempted.
* @param targetSize - The number of results to read before stopping.
* @param consumer - The consumer that will be polled.
* @return The results that were read frmo the consumer.
* @throws Exception If the poll failed.
*/
public static <K, V> List<V> pollForResults(
final int pollMs,
final int pollIterations,
final int targetSize,
final Consumer<K, V> consumer) throws Exception {
requireNonNull(consumer);
final List<V> values = new ArrayList<>();
int i = 0;
while(values.size() < targetSize && i < pollIterations) {
for(final ConsumerRecord<K, V> record : consumer.poll(pollMs)) {
values.add( record.value() );
}
i++;
}
return values;
}
示例7: testReportingMetrics
import org.apache.kafka.clients.consumer.Consumer; //導入方法依賴的package包/類
@Test
public void testReportingMetrics() {
Properties props = new Properties();
props.setProperty(ConsumerConfig.BOOTSTRAP_SERVERS_CONFIG, bootstrapServers());
props.setProperty(ConsumerConfig.KEY_DESERIALIZER_CLASS_CONFIG, StringDeserializer.class.getName());
props.setProperty(ConsumerConfig.VALUE_DESERIALIZER_CLASS_CONFIG, MetricSerde.class.getName());
props.setProperty(ConsumerConfig.GROUP_ID_CONFIG, "testReportingMetrics");
props.setProperty(ConsumerConfig.AUTO_OFFSET_RESET_CONFIG, "earliest");
setSecurityConfigs(props, "consumer");
Consumer<String, CruiseControlMetric> consumer = new KafkaConsumer<>(props);
ConsumerRecords<String, CruiseControlMetric> records = ConsumerRecords.empty();
consumer.subscribe(Collections.singletonList(TOPIC));
long startMs = System.currentTimeMillis();
Set<Integer> metricTypes = new HashSet<>();
while (metricTypes.size() < 16 && System.currentTimeMillis() < startMs + 15000) {
records = consumer.poll(10);
for (ConsumerRecord<String, CruiseControlMetric> record : records) {
metricTypes.add((int) record.value().metricType().id());
}
}
HashSet<Integer> expectedMetricTypes = new HashSet<>(Arrays.asList((int) ALL_TOPIC_BYTES_IN.id(),
(int) ALL_TOPIC_BYTES_OUT.id(),
(int) TOPIC_BYTES_IN.id(),
(int) TOPIC_BYTES_OUT.id(),
(int) PARTITION_SIZE.id(),
(int) BROKER_CPU_UTIL.id(),
(int) ALL_TOPIC_PRODUCE_REQUEST_RATE.id(),
(int) ALL_TOPIC_FETCH_REQUEST_RATE.id(),
(int) ALL_TOPIC_MESSAGES_IN_PER_SEC.id(),
(int) TOPIC_PRODUCE_REQUEST_RATE.id(),
(int) TOPIC_FETCH_REQUEST_RATE.id(),
(int) TOPIC_MESSAGES_IN_PER_SEC.id(),
(int) BROKER_PRODUCE_REQUEST_RATE.id(),
(int) BROKER_CONSUMER_FETCH_REQUEST_RATE.id(),
(int) BROKER_FOLLOWER_FETCH_REQUEST_RATE.id(),
(int) BROKER_REQUEST_HANDLER_AVG_IDLE_PERCENT.id()));
assertEquals("Expected to see " + expectedMetricTypes + ", but only see " + metricTypes, metricTypes, expectedMetricTypes);
}
示例8: main
import org.apache.kafka.clients.consumer.Consumer; //導入方法依賴的package包/類
public static void main(String[] args) {
// build consumer
Properties props = new Properties();
props.put("bootstrap.servers", "127.0.0.1:9092");
props.put("key.deserializer", "org.apache.kafka.common.serialization.StringDeserializer");
props.put("value.deserializer", "org.apache.kafka.common.serialization.StringDeserializer"); // 配置value的序列化類
props.setProperty("group.id", "0"); // group 代表一個消費組(可根據之,實現queue隊列或者topic廣播)
props.setProperty("enable.auto.commit", "true");
props.setProperty("auto.offset.reset", "earliest");
Consumer<String, String> consumer = new KafkaConsumer<String, String>(props);
// sub msg
String topic = "demo_topic";
consumer.subscribe(Arrays.asList(topic));
for (int i = 0; i < 100; i++) {
ConsumerRecords<String, String> records = consumer.poll(1000);
System.out.println(records.count());
for (ConsumerRecord<String, String> record : records) {
System.out.println("record = " + record);
}
}
// close consumer
consumer.close();
}
示例9: testSimpleConsumer
import org.apache.kafka.clients.consumer.Consumer; //導入方法依賴的package包/類
@Test
public void testSimpleConsumer() throws Exception {
String topic = "persistent://sample/standalone/ns/testSimpleConsumer";
Properties props = new Properties();
props.put("bootstrap.servers", lookupUrl.toString());
props.put("group.id", "my-subscription-name");
props.put("enable.auto.commit", "false");
props.put("key.deserializer", StringDeserializer.class.getName());
props.put("value.deserializer", StringDeserializer.class.getName());
Consumer<String, String> consumer = new PulsarKafkaConsumer<>(props);
consumer.subscribe(Arrays.asList(topic));
Producer pulsarProducer = pulsarClient.createProducer(topic);
for (int i = 0; i < 10; i++) {
Message msg = MessageBuilder.create().setKey(Integer.toString(i)).setContent(("hello-" + i).getBytes())
.build();
pulsarProducer.send(msg);
}
for (int i = 0; i < 10; i++) {
ConsumerRecords<String, String> records = consumer.poll(100);
assertEquals(records.count(), 1);
int idx = i;
records.forEach(record -> {
assertEquals(record.key(), Integer.toString(idx));
assertEquals(record.value(), "hello-" + idx);
});
consumer.commitSync();
}
consumer.close();
}
示例10: run
import org.apache.kafka.clients.consumer.Consumer; //導入方法依賴的package包/類
@Override
public void run() {
Consumer<String, String> consumer = ConsumerFactory.getPageConsumer();
consumer.subscribe(Arrays.asList(PAGE_EXTRACTOR));
try {
while (true) {
ConsumerRecords<String, String> records = consumer.poll(POLL_DELAY);
LOGGER.log(Level.INFO, "records fetched {0}", records.count());
Producer<String, Property> propertyProducer = ProducerFactory.getPropertyProducer();
for (ConsumerRecord<String, String> record : records) {
String url = record.value();
int type = 2;
List<Property> properties = extractPageData(url, type);
for (Property property : properties) {
propertyProducer.send(new ProducerRecord<>(PAGE_DETAIL_EXTRACTOR, property));
}
}
consumer.commitAsync((Map<TopicPartition, OffsetAndMetadata> offsets, Exception exception) -> {
if (exception != null) {
LOGGER.log(Level.SEVERE, null, exception);
} else {
offsets.entrySet().stream()
.forEach(entry -> LOGGER.log(Level.INFO, "records commited: partition {0}, offset {1}",
Arrays.asList(entry.getKey().partition(), entry.getValue().offset())));
}
});
}
} catch (Exception e) {
LOGGER.log(Level.SEVERE, null, e);
} finally {
consumer.close();
}
}
示例11: testSimpleProducerConsumer
import org.apache.kafka.clients.consumer.Consumer; //導入方法依賴的package包/類
@Test(timeOut = 30000)
public void testSimpleProducerConsumer() throws Exception {
String topic = "persistent://sample/standalone/ns/testSimpleProducerConsumer";
Properties producerProperties = new Properties();
producerProperties.put("bootstrap.servers", lookupUrl.toString());
producerProperties.put("key.serializer", IntegerSerializer.class.getName());
producerProperties.put("value.serializer", StringSerializer.class.getName());
Producer<Integer, String> producer = new KafkaProducer<>(producerProperties);
Properties consumerProperties = new Properties();
consumerProperties.put("bootstrap.servers", lookupUrl.toString());
consumerProperties.put("group.id", "my-subscription-name");
consumerProperties.put("key.deserializer", IntegerDeserializer.class.getName());
consumerProperties.put("value.deserializer", StringDeserializer.class.getName());
consumerProperties.put("enable.auto.commit", "true");
Consumer<Integer, String> consumer = new KafkaConsumer<>(consumerProperties);
consumer.subscribe(Arrays.asList(topic));
List<Long> offsets = new ArrayList<>();
for (int i = 0; i < 10; i++) {
RecordMetadata md = producer.send(new ProducerRecord<Integer, String>(topic, i, "hello-" + i)).get();
offsets.add(md.offset());
log.info("Published message at {}", Long.toHexString(md.offset()));
}
producer.flush();
producer.close();
for (int i = 0; i < 10; i++) {
ConsumerRecords<Integer, String> records = consumer.poll(1000);
assertEquals(records.count(), 1);
int idx = i;
records.forEach(record -> {
log.info("Received record: {}", record);
assertEquals(record.key().intValue(), idx);
assertEquals(record.value(), "hello-" + idx);
assertEquals(record.offset(), offsets.get(idx).longValue());
});
}
consumer.close();
}
示例12: read
import org.apache.kafka.clients.consumer.Consumer; //導入方法依賴的package包/類
/**
* Read all JSON messages from the replicate info topic and creates the
* latest catalog for PLOG monitor to use for controlling Kafka task
* configuration. This is only done during source connector startup,
* therefore it creates a consumer each time
*
* @return synchronized sorted catalog of replicate info
* @throws Exception for any consumer errors
*/
public synchronized Map <String, ReplicateInfo> read () throws Exception {
/* short lived consumer, no need to keep it alive seeing that
* it always consumes all messages again, the volume of messages
* is low and the consumer doesn't need to be coordinated */
Consumer<String, String> consumer = new KafkaConsumer<String, String> (
consumerProps
);
consumer.subscribe(Arrays.asList(topicName));
Map<String, ReplicateInfo> catalog = Collections.synchronizedMap(
new LinkedHashMap<String, ReplicateInfo> ()
);
try {
logger.debug (
"Polling topic: " + topicName + " for existing replicate " +
"catalog"
);
/* greedy implementation, always fetch all replicate info
* messages when source connector is started */
ConsumerRecords<String, String> records = consumer.poll(
REPLICATE_INFO_POLL_TIMEOUT
);
consumer.commitSync();
if (records != null) {
for (ConsumerRecord<String, String> record : records) {
logger.trace (
"Read " + topicName + " record, key: " +
record.key() + " value: " + record.value()
);
String identifier = record.key();
ReplicateInfo info = ReplicateInfo.fromJSONString(
record.value()
);
/* all message are consumed in order, always overwrite
* with the latest info */
catalog.put (identifier, info);
}
}
}
catch (Exception e) {
throw new Exception (
"Failed to read replicate info records from topic: " +
topicName + ", reason: " + e.getMessage(),
e
);
}
finally {
consumer.close();
}
logger.debug (
"Read replicate catalog: " + catalog.toString() + " " +
"from topic: " + topicName
);
return catalog;
}
示例13: read
import org.apache.kafka.clients.consumer.Consumer; //導入方法依賴的package包/類
@Override
public synchronized Map <String, ReplicateInfo> read ()
throws Exception {
Map<String, ReplicateInfo> catalog = Collections.synchronizedMap(
new LinkedHashMap<String, ReplicateInfo> ()
);
Consumer<String, String> consumer =
new MockConsumer<String, String>(
OffsetResetStrategy.EARLIEST
);
consumer.subscribe(Arrays.asList(mockTopicName));
try {
/* greedy implementation, always fetch all replicate info
* messages when source connector is started */
ConsumerRecords<String, String> records = consumer.poll(
100
);
if (records != null) {
for (ConsumerRecord<String, String> record : records) {
String identifier = record.key();
ReplicateInfo info = ReplicateInfo.fromJSONString(
record.value()
);
/* all message are consumed in order, always overwrite
* with the latest info */
catalog.put (identifier, info);
}
}
}
catch (Exception e) {
throw new Exception (
"Failed to read replicate info records from topic: " +
mockTopicName + ", reason: " + e.getMessage(),
e
);
}
finally {
consumer.close();
}
return catalog;
}