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


Java ConsumerRecord.offset方法代碼示例

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


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

示例1: poll

import org.apache.kafka.clients.consumer.ConsumerRecord; //導入方法依賴的package包/類
public List<StatMessage> poll() {
                /* 快速取,如果沒有就立刻返回 */
    ConsumerRecords<String, String> records = consumer.poll(1000);
    if (records.count() == 0) {
        count++;
        if (count % 60 == 0) {
            count = 0;
            LOG.info(String.format("running on %s (offset=%d).......", statTopic,  consumer.position(statTopicPartition)));
        }
        return null;
    }

    LOG.info(String.format("KafkaSource got %d records......", records.count()));

    List<StatMessage> list = new ArrayList<>();
    for (ConsumerRecord<String, String> record : records) {
        String key = record.key();
        long offset = record.offset();

        StatMessage msg = StatMessage.parse(record.value());
        list.add(msg);
        //logger.info(String.format("KafkaSource got record key=%s, offset=%d......", key, offset));
    }

    return list;
}
 
開發者ID:BriData,項目名稱:DBus,代碼行數:27,代碼來源:KafkaSource.java

示例2: pollNextTransaction

import org.apache.kafka.clients.consumer.ConsumerRecord; //導入方法依賴的package包/類
@Override
public TransactionInput pollNextTransaction(long timeout, TimeUnit unit) {
    Iterator<ConsumerRecord<Integer, byte[]>> iterator = m_consumer.poll(unit.toMillis(timeout)).iterator();
    if (!iterator.hasNext()) {
        return null;
    }

    ConsumerRecord<Integer, byte[]> firstRecord = iterator.next();
    if (iterator.hasNext()) {
        throw new IllegalStateException("Kafka should not return more than one record");
    }

    return new TransactionInput() {
        @Override
        public InputStream getInputStream() throws IOException {
            return new ByteArrayInputStream(firstRecord.value());
        }

        @Override
        public long getTransactionId() {
            return firstRecord.offset();
        }
    };
}
 
開發者ID:Axway,項目名稱:iron,代碼行數:25,代碼來源:KafkaTransactionStore.java

示例3: fromKafka

import org.apache.kafka.clients.consumer.ConsumerRecord; //導入方法依賴的package包/類
static Message<? extends com.google.protobuf.Message> fromKafka(com.google.protobuf.Message protoMessage, Envelope envelope, ConsumerRecord<String, byte[]> record) {
    boolean wasReceived = true;

    Topic topic = new Topic(record.topic());
    String partitioningKey = record.key();
    int partitionId = record.partition();
    long offset = record.offset();

    String messageId = envelope.getMessageId();
    String correlationId = envelope.getCorrelationId();

    MessageType type = MessageType.of(protoMessage);

    String requestCorrelationId = envelope.getRequestCorrelationId();
    Topic replyTo = new Topic(envelope.getReplyTo());

    Metadata meta = new Metadata(wasReceived, topic, partitioningKey, partitionId, offset, messageId, correlationId, requestCorrelationId, replyTo, type);
    return new Message<>(protoMessage, meta);
}
 
開發者ID:Sixt,項目名稱:ja-micro,代碼行數:20,代碼來源:Messages.java

示例4: convertMessages

import org.apache.kafka.clients.consumer.ConsumerRecord; //導入方法依賴的package包/類
private void convertMessages(ConsumerRecords<byte[], byte[]> msgs) {
    for (ConsumerRecord<byte[], byte[]> msg : msgs) {
        log.trace("Consuming message with key {}, value {}", msg.key(), msg.value());
        SchemaAndValue keyAndSchema = keyConverter.toConnectData(msg.topic(), msg.key());
        SchemaAndValue valueAndSchema = valueConverter.toConnectData(msg.topic(), msg.value());
        SinkRecord record = new SinkRecord(msg.topic(), msg.partition(),
                keyAndSchema.schema(), keyAndSchema.value(),
                valueAndSchema.schema(), valueAndSchema.value(),
                msg.offset(),
                ConnectUtils.checkAndConvertTimestamp(msg.timestamp()),
                msg.timestampType());
        record = transformationChain.apply(record);
        if (record != null) {
            messageBatch.add(record);
        }
    }
}
 
開發者ID:YMCoding,項目名稱:kafka-0.11.0.0-src-with-comment,代碼行數:18,代碼來源:WorkerSinkTask.java

示例5: 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

示例6: 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

示例7: 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

示例8: update

import org.apache.kafka.clients.consumer.ConsumerRecord; //導入方法依賴的package包/類
@SuppressWarnings("unchecked")
@Override
public void update(final ConsumerRecord<byte[], byte[]> record) {
    final SourceNodeAndDeserializer sourceNodeAndDeserializer = deserializers.get(record.topic());
    final ConsumerRecord<Object, Object> deserialized = sourceNodeAndDeserializer.deserializer.deserialize(record);
    final ProcessorRecordContext recordContext =
            new ProcessorRecordContext(deserialized.timestamp(),
                                       deserialized.offset(),
                                       deserialized.partition(),
                                       deserialized.topic());
    processorContext.setRecordContext(recordContext);
    processorContext.setCurrentNode(sourceNodeAndDeserializer.sourceNode);
    sourceNodeAndDeserializer.sourceNode.process(deserialized.key(), deserialized.value());
    offsets.put(new TopicPartition(record.topic(), record.partition()), deserialized.offset() + 1);
}
 
開發者ID:YMCoding,項目名稱:kafka-0.11.0.0-src-with-comment,代碼行數:16,代碼來源:GlobalStateUpdateTask.java

示例9: restoreState

import org.apache.kafka.clients.consumer.ConsumerRecord; //導入方法依賴的package包/類
private void restoreState(final StateRestoreCallback stateRestoreCallback,
                          final List<TopicPartition> topicPartitions,
                          final Map<TopicPartition, Long> highWatermarks) {
    for (final TopicPartition topicPartition : topicPartitions) {
        consumer.assign(Collections.singletonList(topicPartition));
        final Long checkpoint = checkpointableOffsets.get(topicPartition);
        if (checkpoint != null) {
            consumer.seek(topicPartition, checkpoint);
        } else {
            consumer.seekToBeginning(Collections.singletonList(topicPartition));
        }

        long offset = consumer.position(topicPartition);
        final Long highWatermark = highWatermarks.get(topicPartition);

        while (offset < highWatermark) {
            final ConsumerRecords<byte[], byte[]> records = consumer.poll(100);
            for (ConsumerRecord<byte[], byte[]> record : records) {
                offset = record.offset() + 1;
                if (record.key() != null) {
                    stateRestoreCallback.restore(record.key(), record.value());
                }
            }
        }
        checkpointableOffsets.put(topicPartition, offset);
    }
}
 
開發者ID:YMCoding,項目名稱:kafka-0.11.0.0-src-with-comment,代碼行數:28,代碼來源:GlobalStateManagerImpl.java

示例10: processNext

import org.apache.kafka.clients.consumer.ConsumerRecord; //導入方法依賴的package包/類
private long processNext(final List<ConsumerRecord<byte[], byte[]>> records, final StateRestorer restorer, final Long endOffset) {
    for (final ConsumerRecord<byte[], byte[]> record : records) {
        final long offset = record.offset();
        if (restorer.hasCompleted(offset, endOffset)) {
            return offset;
        }
        if (record.key() != null) {
            restorer.restore(record.key(), record.value());
        }
    }
    return consumer.position(restorer.partition());
}
 
開發者ID:YMCoding,項目名稱:kafka-0.11.0.0-src-with-comment,代碼行數:13,代碼來源:StoreChangelogReader.java

示例11: updateStandbyStates

import org.apache.kafka.clients.consumer.ConsumerRecord; //導入方法依賴的package包/類
List<ConsumerRecord<byte[], byte[]>> updateStandbyStates(final TopicPartition storePartition,
                                                         final List<ConsumerRecord<byte[], byte[]>> records) {
    final long limit = offsetLimit(storePartition);
    List<ConsumerRecord<byte[], byte[]>> remainingRecords = null;

    // restore states from changelog records
    final StateRestoreCallback restoreCallback = restoreCallbacks.get(storePartition.topic());

    long lastOffset = -1L;
    int count = 0;
    for (final ConsumerRecord<byte[], byte[]> record : records) {
        if (record.offset() < limit) {
            try {
                restoreCallback.restore(record.key(), record.value());
            } catch (final Exception e) {
                throw new ProcessorStateException(String.format("%s exception caught while trying to restore state from %s", logPrefix, storePartition), e);
            }
            lastOffset = record.offset();
        } else {
            if (remainingRecords == null) {
                remainingRecords = new ArrayList<>(records.size() - count);
            }

            remainingRecords.add(record);
        }
        count++;
    }

    // record the restored offset for its change log partition
    restoredOffsets.put(storePartition, lastOffset + 1);

    return remainingRecords;
}
 
開發者ID:YMCoding,項目名稱:kafka-0.11.0.0-src-with-comment,代碼行數:34,代碼來源:ProcessorStateManager.java

示例12: bufferRecord

import org.apache.kafka.clients.consumer.ConsumerRecord; //導入方法依賴的package包/類
public void bufferRecord(ConsumerRecord<Integer, Integer> record) {
    recordBuffer.add(
        new ConsumerRecord<>(record.topic(), record.partition(), record.offset(), 0L,
                             TimestampType.CREATE_TIME, 0L, 0, 0,
                             serializer.serialize(record.topic(), record.key()),
                             serializer.serialize(record.topic(), record.value())));
    endOffset = record.offset();

    super.updateEndOffsets(Collections.singletonMap(assignedPartition, endOffset));
}
 
開發者ID:YMCoding,項目名稱:kafka-0.11.0.0-src-with-comment,代碼行數:11,代碼來源:MockRestoreConsumer.java

示例13: fromRecord

import org.apache.kafka.clients.consumer.ConsumerRecord; //導入方法依賴的package包/類
public static MarkerKey fromRecord(ConsumerRecord r) {
    return new MarkerKey(r.partition(), r.offset());
}
 
開發者ID:softwaremill,項目名稱:kmq,代碼行數:4,代碼來源:MarkerKey.java

示例14: execute

import org.apache.kafka.clients.consumer.ConsumerRecord; //導入方法依賴的package包/類
@Override
public void execute(Tuple input) {
    ConsumerRecord<String, byte[]> record = (ConsumerRecord<String, byte[]>) input.getValueByField("record");

    long kafkaOffset = record.offset();
    String fromTopic = record.topic();

    FullyOffset currentOffset = new FullyOffset(0, 0, 0);

    try {
        //處理ctrl topic的數據
        if (fromTopic.equalsIgnoreCase(dsInfo.getCtrlTopic())) {
            processControlCommand(record, input);
            return;
        }

        // a 讀取message數據
        processor.preProcess(record);

        // b 一次讀取一個partition
        List<DispatcherPackage> list;
        int partitionOffset = 0;


        do {
            partitionOffset++;
            list = processor.getNextList();
            if (list == null) {
                break;
            }

            //分schema後的子包
            int subOffset = 1;
            for (DispatcherPackage subPackage : list) {
                currentOffset = new FullyOffset(kafkaOffset, partitionOffset, subOffset);

                // 1 獲得數據
                String key = subPackage.getKey();
                byte[] content = subPackage.getContent();
                int msgCount = subPackage.getMsgCount();
                String schemaName = subPackage.getSchemaName();
                String toTopic = subPackage.getToTopic();

                ContinuousFullyOffset continuousOffset = getSchemaFullyOffset(schemaName);
                continuousOffset.setProcessingOffset(currentOffset);
                if (key == null) {
                    // 2 構建數據消息的key,記錄上一個offset是誰, 主要是用於日誌查錯
                    subPackage.setKey(continuousOffset.toString());
                    key = subPackage.getKey();
                }

                logger.debug(String.format("  currentOffset=%s, from_topic: %s, (to_topic:%s, schemaName=%s), Key=%s, msg_count=%d",
                        currentOffset.toString(), fromTopic, toTopic, schemaName, key, msgCount));
                this.collector.emit(input, new Values(subPackage, currentOffset));

                continuousOffset.setProcessedOffset(currentOffset);

                subOffset++;
            }
        } while (true);

        this.collector.ack(input);

    } catch (Exception ex) {
        // Print something in the log
        logger.error(String.format("FAIL! Dispatcher bolt fails at offset (%s).", currentOffset.toString()));
        // Call fail
        this.collector.fail(input);

        collector.reportError(ex);
        throw new RuntimeException(ex);
    }
}
 
開發者ID:BriData,項目名稱:DBus,代碼行數:74,代碼來源:DispatcherBout.java

示例15: QueueElement

import org.apache.kafka.clients.consumer.ConsumerRecord; //導入方法依賴的package包/類
public QueueElement(ConsumerRecord<String, byte[]> record) {
    this.key = record.offset();
    setRecord(record);
}
 
開發者ID:BriData,項目名稱:DBus,代碼行數:5,代碼來源:QueueElement.java


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