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


Java ConsumerRecord.topic方法代碼示例

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


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

示例1: onMessage

import org.apache.kafka.clients.consumer.ConsumerRecord; //導入方法依賴的package包/類
@Override
public void onMessage(ConsumerRecord<K, V> data, Acknowledgment acknowledgment) {
    logger.info(cachingDateFormatter.format(System.currentTimeMillis()) + "-" + data.toString());
    // router topic
    String topic = data.topic();

    MessageHandler<K, V> messageHandler = messageHandlers.get(topic);
    if (null == messageHandler) {
        // TODO:需要處理 未找到注冊的MessageHandler
        throw new RuntimeException("not found MessagHandler Instance");
    }
    // 獲取運行時泛型
    Type messageType = ((ParameterizedType) messageHandler.getClass().getGenericInterfaces()[0]).getActualTypeArguments()[0];
    // create MessageChannel , MessageBuilder
    messageChannel = new KafkaMessageChannel(acknowledgment);
    messageChannel.putMessage(data);
    Message message = MessageBuilder.build(messageType, messageChannel).createMessage(data.key());
    messageHandler.handler(message);
}
 
開發者ID:ailang323,項目名稱:tankms,代碼行數:20,代碼來源:KafkaMessageListenerAdapter.java

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

示例3: onMessageConsumed

import org.apache.kafka.clients.consumer.ConsumerRecord; //導入方法依賴的package包/類
private synchronized void onMessageConsumed(ConsumerRecord<String, String> record) {
    log.info(String.format("Consumed message: [%s]", record));

    TopicPartition topicPartition = new TopicPartition(record.topic(), record.partition());

    if (!messagesByTopicPartition.containsKey(topicPartition)) {
        messagesByTopicPartition.put(topicPartition, new VersionedMessages(Lists.newLinkedList()));
    }

    VersionedMessages versionedMessages = messagesByTopicPartition.get(topicPartition);
    LinkedList<ConsumerRecord<String, String>> messages = versionedMessages.messages;
    messages.addFirst(record);

    if (messages.size() > maxTopicMessagesCount) {
        messages.removeLast();
    }

    versionedMessages.version.incrementAndGet();
}
 
開發者ID:enthusiast94,項目名稱:kafka-visualizer,代碼行數:20,代碼來源:KafkaTopicsDataTracker.java

示例4: call

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

    logger.debug("Number of records received : {}", records.count());
    try {
        for (final ConsumerRecord<String, Serializable> record : records) {
            TopicPartition tp = new TopicPartition(record.topic(), record.partition());
            logger.info("Record received topicPartition : {}, offset : {}", tp,
                record.offset());
            partitionToUncommittedOffsetMap.put(tp, record.offset());

            processConsumerRecords(record);
        }
    } catch (Exception e) {
        logger.error("Error while consuming", e);
    }
    return true;
}
 
開發者ID:warlock-china,項目名稱:azeroth,代碼行數:19,代碼來源:NewApiTopicConsumer.java

示例5: pollAndCommitTransactionsBatch

import org.apache.kafka.clients.consumer.ConsumerRecord; //導入方法依賴的package包/類
private void pollAndCommitTransactionsBatch() {
    ConsumerRecords<ByteBuffer, ByteBuffer> records = consumer.poll(POLL_TIMEOUT);
    List<TransactionScope> scopes = new ArrayList<>(records.count());
    for (ConsumerRecord<ByteBuffer, ByteBuffer> record : records) {
        TransactionScope transactionScope = serializer.deserialize(record.key());
        if (transactionScope.getScope().isEmpty()) {
            LOGGER.warn("[R] {} polled empty transaction {}", readerId, transactionScope.getTransactionId());
        }
        TopicPartition topicPartition = new TopicPartition(record.topic(), record.partition());
        buffer.put(transactionScope.getTransactionId(),
                new TransactionData(transactionScope, record.value(), topicPartition, record.offset()));
        scopes.add(transactionScope);
        committedOffsetMap.computeIfAbsent(topicPartition, COMMITTED_OFFSET).notifyRead(record.offset());
    }
    if (!scopes.isEmpty()) {
        scopes.sort(SCOPE_COMPARATOR);
        LOGGER.trace("[R] {} polled {}", readerId, scopes);
    }
    approveAndCommitTransactionsBatch(scopes);
}
 
開發者ID:epam,項目名稱:Lagerta,代碼行數:21,代碼來源:Reader.java

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

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

示例8: transform

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

  if (!value.has("payload") || value.get("payload").isJsonNull()) {
    return false;
  }

  JsonObject payLoad = value.getAsJsonObject("payload");
  DebeziumRecord record = new DebeziumRecord(change.topic(), payLoad);

  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.DELETE) {
    row.tuple = formatColumns(record, table, table.columnName, false);
  }

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

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

示例10: onCompletion

import org.apache.kafka.clients.consumer.ConsumerRecord; //導入方法依賴的package包/類
@Override
public void onCompletion(Throwable error, ConsumerRecord<String, String> record) {
    TopicPartition partition = new TopicPartition(record.topic(), record.partition());
    List<ConsumerRecord<String, String>> records = consumedRecords.get(partition);
    if (records == null) {
        records = new ArrayList<>();
        consumedRecords.put(partition, records);
    }
    records.add(record);
}
 
開發者ID:YMCoding,項目名稱:kafka-0.11.0.0-src-with-comment,代碼行數:11,代碼來源:KafkaBasedLogTest.java

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

示例12: update

import org.apache.kafka.clients.consumer.ConsumerRecord; //導入方法依賴的package包/類
@Override
public void update(final ConsumerRecord<byte[], byte[]> record) {
    final TopicPartition tp = new TopicPartition(record.topic(), record.partition());
    if (!updatedPartitions.containsKey(tp)) {
        updatedPartitions.put(tp, 0);
    }
    updatedPartitions.put(tp, updatedPartitions.get(tp) + 1);
}
 
開發者ID:YMCoding,項目名稱:kafka-0.11.0.0-src-with-comment,代碼行數:9,代碼來源:StateConsumerTest.java

示例13: addRecord

import org.apache.kafka.clients.consumer.ConsumerRecord; //導入方法依賴的package包/類
private static void addRecord(final ConsumerRecord<byte[], byte[]> record,
                              final Map<String, Map<TopicPartition, List<ConsumerRecord<byte[], byte[]>>>> recordPerTopicPerPartition) {

    final String topic = record.topic();
    final TopicPartition partition = new TopicPartition(topic, record.partition());

    if ("data".equals(topic)
        || "echo".equals(topic)
        || "min".equals(topic)
        || "sum".equals(topic)) {

        Map<TopicPartition, List<ConsumerRecord<byte[], byte[]>>> topicRecordsPerPartition
            = recordPerTopicPerPartition.get(topic);

        if (topicRecordsPerPartition == null) {
            topicRecordsPerPartition = new HashMap<>();
            recordPerTopicPerPartition.put(topic, topicRecordsPerPartition);
        }

        List<ConsumerRecord<byte[], byte[]>> records = topicRecordsPerPartition.get(partition);
        if (records == null) {
            records = new ArrayList<>();
            topicRecordsPerPartition.put(partition, records);
        }
        records.add(record);
    } else {
        throw new RuntimeException("FAIL: received data from unexpected topic: " + record);
    }
}
 
開發者ID:YMCoding,項目名稱:kafka-0.11.0.0-src-with-comment,代碼行數:30,代碼來源:EosTestDriver.java

示例14: process

import org.apache.kafka.clients.consumer.ConsumerRecord; //導入方法依賴的package包/類
/**
 * 處理mysql 拉全量請求
 */
@Override
public void process(final ConsumerRecord<String, byte[]> consumerRecord, Object... args){
	try{
 	List<MessageEntry> msgEntryLst = parser.getEntry(consumerRecord.value());
 	if(msgEntryLst.isEmpty())
 		return ; 
 	EntryHeader entryHeader = msgEntryLst.get(0).getEntryHeader();
 	EventType operType = entryHeader.getOperType();
 	
 	//TODO 暫時放棄拉全量表的update/delete等消息
     if (operType!=EventType.INSERT) {
         listener.reduceFlowSize(consumerRecord.serializedValueSize());
         consumerListener.syncOffset(consumerRecord);
         return;
     }
     
  // 判斷是否處理過該消息
     String msgPos = entryHeader.getPos();
     Object processed = cache.getIfPresent(msgPos);
     if (processed != null) {
         logger.info("Data have bean processed, the data position is [{}]", msgPos);
         listener.reduceFlowSize(consumerRecord.serializedValueSize());
         consumerListener.syncOffset(consumerRecord);
         return;
     }
     
     logger.info("Received FULL DATA PULL REQUEST message");
     ControlMessage message = Convertor.mysqlFullPullMessage(msgEntryLst.get(0), listener.getListenerId(), consumerRecord);
     String schemaName = getStringValue("SCHEMA_NAME", message);
     String tableName = getStringValue("TABLE_NAME", message);
     DataTable table = ThreadLocalCache.get(Constants.CacheNames.DATA_TABLES, Utils.buildDataTableCacheKey(schemaName, tableName));
     if (table == null) {
         logger.warn("Table {}.{} is not supported,please configure it in dbus database.", schemaName, tableName);
         return;
     }
     
     for (String controlTopic : controlTopics) {
         String json = message.toJSONString();
         ProducerRecord<String, byte[]> producerRecord = new ProducerRecord<>(controlTopic, message.getType(), json.getBytes());
	
         Future<RecordMetadata> future = listener.sendRecord(producerRecord);
         future.get();
	
         logger.info("write initial load request message to kafka: {}", json);
     }
     
  // 暫停接收 topic 的數據
        TopicPartition tp = new TopicPartition(consumerRecord.topic(), consumerRecord.partition());
        consumerListener.pauseTopic(tp, consumerRecord.offset(), message);

        // emit FULL_DATA_PULL_REQ 通知給bolt
        EmitData emitData = new EmitData();
        emitData.add(EmitData.DB_SCHEMA, schemaName);
        emitData.add(EmitData.DATA_TABLE, tableName);

        List<Object> values = new Values(emitData, Command.FULL_DATA_PULL_REQ);
        listener.emitData(values, consumerRecord);

        consumerListener.syncOffset(consumerRecord);
        cache.put(msgPos, msgEntryLst.get(0).toString());
	}catch(Exception e){
		throw new RuntimeException(e);
	}
}
 
開發者ID:BriData,項目名稱:DBus,代碼行數:68,代碼來源:MysqlInitialLoadProcessor.java

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


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