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


Java ConsumerRecords.iterator方法代碼示例

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


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

示例1: computeNext

import org.apache.kafka.clients.consumer.ConsumerRecords; //導入方法依賴的package包/類
@Override
protected KeyMessage<K,V> computeNext() {
  if (iterator == null || !iterator.hasNext()) {
    try {
      long timeout = MIN_POLL_MS;
      ConsumerRecords<K, V> records;

      while ((records = consumer.poll(timeout)).isEmpty()) {
        timeout = Math.min(MAX_POLL_MS, timeout * 2);
      }
      iterator = records.iterator();
    } catch (Exception e) {
      consumer.close();
      return endOfData();
    }
  }
  ConsumerRecord<K,V> mm = iterator.next();
  return new KeyMessageImpl<>(mm.key(), mm.value());
}
 
開發者ID:oncewang,項目名稱:oryx2,代碼行數:20,代碼來源:ConsumeDataIterator.java

示例2: pollAndDispatchMessage

import org.apache.kafka.clients.consumer.ConsumerRecords; //導入方法依賴的package包/類
private synchronized void pollAndDispatchMessage() throws InterruptedException {
	// 處理記錄過程中,不能修改consumer相關的設定
	// 拉取需要處理的記錄
	ConsumerRecords<String, byte[]> allRecords = consumer.poll(10000);

	// 為每個消息都封裝成CALLABLE的形式,並進行調用處理
	Iterator<ConsumerRecord<String, byte[]>> iterator = allRecords.iterator();
	List<MessageHandler> listJob = new LinkedList<>();
	while (iterator.hasNext()) {
		listJob.add(new MessageHandler(iterator.next()));
	}
	executeJobs(listJob);
	// 全部調用成功,更新消費坐標
	consumer.commitAsync();
}
 
開發者ID:QNJR-GROUP,項目名稱:EasyTransaction,代碼行數:16,代碼來源:KafkaEasyTransMsgConsumerImpl.java

示例3: consume

import org.apache.kafka.clients.consumer.ConsumerRecords; //導入方法依賴的package包/類
private List<KafkaResult> consume() {
    final List<KafkaResult> kafkaResultList = new ArrayList<>();
    final ConsumerRecords consumerRecords = kafkaConsumer.poll(clientConfig.getPollTimeoutMs());

    logger.info("Consumed {} records", consumerRecords.count());
    final Iterator<ConsumerRecord> recordIterator = consumerRecords.iterator();
    while (recordIterator.hasNext()) {
        // Get next record
        final ConsumerRecord consumerRecord = recordIterator.next();

        // Convert to KafkaResult.
        final KafkaResult kafkaResult = new KafkaResult(
            consumerRecord.partition(),
            consumerRecord.offset(),
            consumerRecord.timestamp(),
            consumerRecord.key(),
            consumerRecord.value()
        );

        // Add to list.
        kafkaResultList.add(kafkaResult);
    }

    // Commit offsets
    commit();
    return kafkaResultList;
}
 
開發者ID:SourceLabOrg,項目名稱:kafka-webview,代碼行數:28,代碼來源:WebKafkaConsumer.java

示例4: readLine

import org.apache.kafka.clients.consumer.ConsumerRecords; //導入方法依賴的package包/類
@Override
public String readLine() {
	String line = "";
	ConsumerRecords<String, String> records = this.consumer.poll(1000);
	Iterator<ConsumerRecord<String, String>> iterator = records.iterator();
	if (iterator.hasNext()) {
		ConsumerRecord<String, String> record = iterator.next();
		logger.info(String.format("offset = %d, key = %s, value = %s\n", record.offset(), record.key(), record.value()));
		line = record.value();
	}
	return line;
}
 
開發者ID:netkiller,項目名稱:ipo,代碼行數:13,代碼來源:KafkaInput.java

示例5: onConsume

import org.apache.kafka.clients.consumer.ConsumerRecords; //導入方法依賴的package包/類
@Override
public ConsumerRecords onConsume(final ConsumerRecords records) {

    final Map<TopicPartition, List<ConsumerRecord>> filteredRecords = new HashMap<>();

    // Iterate thru records
    final Iterator<ConsumerRecord> recordIterator = records.iterator();
    while (recordIterator.hasNext()) {
        final ConsumerRecord record = recordIterator.next();

        boolean result = true;

        // Iterate through filters
        for (final RecordFilterDefinition recordFilterDefinition : recordFilterDefinitions) {
            // Pass through filter
            result = recordFilterDefinition.getRecordFilter().includeRecord(
                record.topic(),
                record.partition(),
                record.offset(),
                record.key(),
                record.value()
            );

            // If we return false
            if (!result) {
                // break out of loop
                break;
            }
        }

        // If filter return true
        if (result) {
            // Include it in the results
            final TopicPartition topicPartition = new TopicPartition(record.topic(), record.partition());
            filteredRecords.putIfAbsent(topicPartition, new ArrayList<>());
            filteredRecords.get(topicPartition).add(record);
        }
    }

    // return filtered results
    return new ConsumerRecords(filteredRecords);
}
 
開發者ID:SourceLabOrg,項目名稱:kafka-webview,代碼行數:43,代碼來源:RecordFilterInterceptor.java

示例6: testFilterMessages

import org.apache.kafka.clients.consumer.ConsumerRecords; //導入方法依賴的package包/類
/**
 * Test that filters can filter messages.
 */
@Test
public void testFilterMessages() {
    final int totalRecords = 5;

    // Create mock Filters
    final RecordFilter mockFilter1 = mock(RecordFilter.class);
    final RecordFilter mockFilter2 = mock(RecordFilter.class);

    when(mockFilter1.includeRecord(eq("MyTopic"), eq(0), anyLong(), anyObject(), anyObject()))
        .thenReturn(true, false, true, true, true);
    when(mockFilter2.includeRecord(eq("MyTopic"), eq(0), anyLong(), anyObject(), anyObject()))
        .thenReturn(true, true, false, true);

    final RecordFilterDefinition recordFilterDefinition1 = new RecordFilterDefinition(mockFilter1, new HashMap<>());
    final RecordFilterDefinition recordFilterDefinition2 = new RecordFilterDefinition(mockFilter2, new HashMap<>());

    // Create ConsumerConfigs
    final Map<String, Object> consumerConfigs = new HashMap<>();
    consumerConfigs.put(RecordFilterInterceptor.CONFIG_KEY, Lists.newArrayList(recordFilterDefinition1, recordFilterDefinition2));

    // Create interceptor.
    final RecordFilterInterceptor interceptor = new RecordFilterInterceptor();

    // Call configure
    interceptor.configure(consumerConfigs);

    // Create ConsumerRecords
    final ConsumerRecords consumerRecords = createConsumerRecords(totalRecords);

    // Pass through interceptor
    final ConsumerRecords results = interceptor.onConsume(consumerRecords);

    // Validate we got the expected results
    assertEquals("Should have 3 records", totalRecords - 2, results.count());

    for (Iterator<ConsumerRecord> it = results.iterator(); it.hasNext(); ) {
        final ConsumerRecord consumerRecord = it.next();
        assertNotEquals("Should not have offsets 1 and 3", 1, consumerRecord.offset());
        assertNotEquals("Should not have offsets 1 and 3", 3, consumerRecord.offset());
    }

    // Verify mocks
    verify(mockFilter1, times(totalRecords))
        .includeRecord(eq("MyTopic"), eq(0), anyLong(), anyObject(), anyObject());
    verify(mockFilter2, times(totalRecords - 1))
        .includeRecord(eq("MyTopic"), eq(0), anyLong(), anyObject(), anyObject());
}
 
開發者ID:SourceLabOrg,項目名稱:kafka-webview,代碼行數:51,代碼來源:RecordFilterInterceptorTest.java


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