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


Java ConsumerRecord.value方法代碼示例

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


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

示例1: run

import org.apache.kafka.clients.consumer.ConsumerRecord; //導入方法依賴的package包/類
@Override
public void run() {
    while (true) {

        ConsumerRecords<byte[], ChangeDataRecord> changeRecords = consumer.poll(KAFKA_CONSUMER_POLL_TIMEOUT);
        for (ConsumerRecord<byte[], ChangeDataRecord> consumerRecord : changeRecords) {

            // The ChangeDataRecord contains all the changes made to a document
            ChangeDataRecord changeDataRecord = consumerRecord.value();
            String documentId = changeDataRecord.getId().getString();

            // Handle 'RECORD_INSERT'
            if (changeDataRecord.getType() == ChangeDataRecordType.RECORD_INSERT && this.onInsert != null) {
                this.onInsert.handle(documentId);
            }

            // Handle 'RECORD_DELETE'
            if (changeDataRecord.getType() == ChangeDataRecordType.RECORD_DELETE && this.onDelete != null) {
                this.onDelete.handle(documentId);
            }

        }
    }
}
 
開發者ID:mapr-demos,項目名稱:mapr-music,代碼行數:25,代碼來源:CdcStatisticService.java

示例2: ack

import org.apache.kafka.clients.consumer.ConsumerRecord; //導入方法依賴的package包/類
@Override
public void ack(Object msgId) {
    try {
        if (msgId != null && ConsumerRecord.class.isInstance(msgId)) {
            flowedMsgCount--;

            ConsumerRecord<String, byte[]> record = getMessageId(msgId);
            String recordString = new String(record.value());
            JSONObject jsonObject = JSONObject.parseObject(recordString);
            String dataSourceInfo = jsonObject.getString(DataPullConstants.DATA_SOURCE_INFO);
            String dsKey = FullPullHelper.getDataSourceKey(JSONObject.parseObject(dataSourceInfo));
            String splitIndex = jsonObject.getString(DataPullConstants.DATA_CHUNK_SPLIT_INDEX);
            LOG.info("Acked Record offset--------is:{}, {}:split index is {}", record.offset(), dsKey, splitIndex);
        }

        processedCount++;
        super.ack(msgId);
    } catch (Exception e) {
        LOG.error("DataPullingSpout:ack throwed exception!", e);
    }
}
 
開發者ID:BriData,項目名稱:DBus,代碼行數:22,代碼來源:DataPullingSpout.java

示例3: computeNext

import org.apache.kafka.clients.consumer.ConsumerRecord; //導入方法依賴的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

示例4: decodePayload

import org.apache.kafka.clients.consumer.ConsumerRecord; //導入方法依賴的package包/類
public static <K, V> Payload<K, V> decodePayload(Deserializer<V> valueDeserializer, ConsumerRecord<K, byte[]> originConsumerRecord) {
    TracingHeader tracingHeader = null;
    ConsumerRecord<K, V> dataRecord = null;
    boolean sampled = false;
    byte[] data = originConsumerRecord.value();
    byte[] vData = null;
    if (data.length <= HEADER_LENGTH) {
        vData = data;
    } else {
        ByteBuffer byteBuf = ByteBuffer.wrap(data);
        short magic = byteBuf.getShort(0);
        short tpLen = byteBuf.getShort(2);
        if (magic == MAGIC && tpLen == TracingHeader.LENGTH) {
            byte[] tpBytes = new byte[tpLen];
            System.arraycopy(byteBuf.array(), HEADER_LENGTH, tpBytes, 0, tpLen);
            tracingHeader = TracingHeader.fromBytes(tpBytes);
            sampled = true;
            int dataOffset = tpLen + HEADER_LENGTH;
            vData = new byte[byteBuf.array().length - dataOffset];
            System.arraycopy(byteBuf.array(), dataOffset, vData, 0, vData.length);
        } else {
            vData = data;
        }
    }
    dataRecord = new ConsumerRecord<>(originConsumerRecord.topic(),
            originConsumerRecord.partition(), originConsumerRecord.offset(),
            originConsumerRecord.key(), valueDeserializer.deserialize(originConsumerRecord.topic(), vData));
    return new Payload<>(tracingHeader, dataRecord, sampled);
}
 
開發者ID:YanXs,項目名稱:nighthawk,代碼行數:30,代碼來源:PayloadCodec.java

示例5: consume

import org.apache.kafka.clients.consumer.ConsumerRecord; //導入方法依賴的package包/類
@Override
public void consume(ConsumerRecords<String, String> records) {
    for (ConsumerRecord<String, String> record : records) {
        String msg = record.value();
        logger.info(msg);
    }
}
 
開發者ID:Zephery,項目名稱:newblog,代碼行數:8,代碼來源:KafkaConsumerHandlerImpl.java

示例6: transform

import org.apache.kafka.clients.consumer.ConsumerRecord; //導入方法依賴的package包/類
@Override
public boolean transform(ConsumerRecord<String, String> change, Row row)
    throws BiremeException {
  MaxwellRecord record = new MaxwellRecord(change.value());

  if (filter(record)) {
    return false;
  }

  Table table = cxt.tablesInfo.get(getMappedTableName(record));

  row.type = record.type;
  row.produceTime = record.produceTime;
  row.originTable = getOriginTableName(record);
  row.mappedTable = getMappedTableName(record);
  row.keys = formatColumns(record, table, table.keyNames, false);

  if (row.type == RowType.INSERT || row.type == RowType.UPDATE) {
    row.tuple = formatColumns(record, table, table.columnName, false);
  }

  if (row.type == RowType.UPDATE) {
    row.oldKeys = formatColumns(record, table, table.keyNames, true);

    if (row.keys.equals(row.oldKeys)) {
      row.oldKeys = null;
    }
  }

  return true;
}
 
開發者ID:HashDataInc,項目名稱:bireme,代碼行數:32,代碼來源:MaxwellPipeLine.java

示例7: readLine

import org.apache.kafka.clients.consumer.ConsumerRecord; //導入方法依賴的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

示例8: run

import org.apache.kafka.clients.consumer.ConsumerRecord; //導入方法依賴的package包/類
@Override public void run() {
    consumer.subscribe(Collections.singletonList(topic));
    try {
        while (running) {
            ConsumerRecords<ByteBuffer, ByteBuffer> records = consumer.poll(POLL_TIMEOUT);
            List<MessageMetadata> metadatas = new ArrayList<>(records.count());

            for (ConsumerRecord<ByteBuffer, ByteBuffer> record : records) {
                MessageMetadata metadata = (MessageMetadata)serializer.deserialize(record.key());
                TransactionWrapper wrapper = new TransactionWrapper(metadata, record.value());

                metadatas.add(metadata);
                buffer.put(metadata.getTransactionId(), wrapper);
            }
            Collections.sort(metadatas, new MetadataComparator());
            List<Long> transactionsToCommit = leadProxy.notifyTransactionsRead(consumerId, metadatas);

            if (!transactionsToCommit.isEmpty()) {
                committer.commit(transactionsToCommit, deserializerClosure, doneNotifier);
            }
            // TODO commit transaction only after applying in ignite
            consumer.commitSync();
        }
    }
    finally {
        consumer.unsubscribe();
    }
}
 
開發者ID:epam,項目名稱:Lagerta,代碼行數:29,代碼來源:SubscriberConsumer.java

示例9: processSingleRecord

import org.apache.kafka.clients.consumer.ConsumerRecord; //導入方法依賴的package包/類
private void processSingleRecord(List<Long> txIds, ConsumerRecord<ByteBuffer, ByteBuffer> record) {
    long txId = record.timestamp();
    boolean found = txIds.remove(txId);
    if (found) {
        ProducerRecord<ByteBuffer, ByteBuffer> producerRecord =
                new ProducerRecord<>(clusterConfig.getGapTopic(), record.key(), record.value());
        producer.send(producerRecord);
    }
}
 
開發者ID:epam,項目名稱:Lagerta,代碼行數:10,代碼來源:ReconcilerImpl.java

示例10: consume

import org.apache.kafka.clients.consumer.ConsumerRecord; //導入方法依賴的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

示例11: TransactionWrapper

import org.apache.kafka.clients.consumer.ConsumerRecord; //導入方法依賴的package包/類
public TransactionWrapper(ConsumerRecord<ByteBuffer, ByteBuffer> record, TransactionMetadata deserializedMetadata) {
    GridArgumentCheck.notNull(deserializedMetadata, "metadata cannot be null");
    this.value = record.value();
    this.key = record.key();
    this.topicPartition = new TopicPartition(record.topic(), record.partition());
    this.offset = record.offset();
    this.deserializedMetadata = deserializedMetadata;
}
 
開發者ID:epam,項目名稱:Lagerta,代碼行數:9,代碼來源:TransactionWrapper.java

示例12: extractAndConvertValue

import org.apache.kafka.clients.consumer.ConsumerRecord; //導入方法依賴的package包/類
@Override
protected Object extractAndConvertValue(ConsumerRecord<?, ?> record, Type type) {
    Object value = record.value();
    if (value instanceof PublishedEventWrapper)
        try {
            PublishedEventWrapper eventWrapper = (PublishedEventWrapper) value;
            userContext.extractUserContext(eventWrapper.getUserContext());
            operationContext.switchContext(eventWrapper.getOpId());
            return objectMapper.readValue(eventWrapper.getEvent(), TypeFactory.rawClass(type));
        } catch (IOException e) {
            throw new SerializationException(e);
        }
    else
        return super.extractAndConvertValue(record, type);
}
 
開發者ID:kloiasoft,項目名稱:eventapis,代碼行數:16,代碼來源:EventMessageConverter.java

示例13: processConsumerRecords

import org.apache.kafka.clients.consumer.ConsumerRecord; //導入方法依賴的package包/類
/**
 * @param record
 */
private void processConsumerRecords(final ConsumerRecord<String, Serializable> record) {
    final MessageHandler messageHandler = topicHandlers.get(record.topic());

    consumerContext.saveOffsetsBeforeProcessed(record.topic(), record.partition(),
        record.offset());
    //兼容沒有包裝的情況
    final DefaultMessage message = record.value() instanceof DefaultMessage
        ? (DefaultMessage) record.value()
        : new DefaultMessage((Serializable) record.value());
    //第一階段處理
    messageHandler.p1Process(message);
    //第二階段處理
    processExecutor.submit(new Runnable() {
        @Override
        public void run() {
            try {
                messageHandler.p2Process(message);
                //
                consumerContext.saveOffsetsAfterProcessed(record.topic(),
                    record.partition(), record.offset());
            } catch (Exception e) {
                boolean processed = messageHandler.onProcessError(message);
                if (processed == false) {
                    errorMessageProcessor.submit(message, messageHandler);
                }
                logger.error("[" + messageHandler.getClass().getSimpleName()
                             + "] process Topic[" + record.topic() + "] error",
                    e);
            }
        }
    });
}
 
開發者ID:warlock-china,項目名稱:azeroth,代碼行數:36,代碼來源:NewApiTopicConsumer.java

示例14: producerRecordFromConsumerRecord

import org.apache.kafka.clients.consumer.ConsumerRecord; //導入方法依賴的package包/類
private static ProducerRecord<String, String> producerRecordFromConsumerRecord(String topic, ConsumerRecord<String, String> record) {
    return new ProducerRecord<>(topic, record.key(), record.value());
}
 
開發者ID:YMCoding,項目名稱:kafka-0.11.0.0-src-with-comment,代碼行數:4,代碼來源:TransactionalMessageCopier.java

示例15: extract

import org.apache.kafka.clients.consumer.ConsumerRecord; //導入方法依賴的package包/類
@Override
public long extract(ConsumerRecord<Object, Object> record, long previousTimestamp) {

    if (record.value() instanceof Integer) return Long.valueOf(String.valueOf(record.value()));
    return record.timestamp();
}
 
開發者ID:carlosmenezes,項目名稱:mockafka,代碼行數:7,代碼來源:TestTimestampExtractor.java


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