当前位置: 首页 > wzjs >正文

百度网站链接提交入口海口海南网站建设

百度网站链接提交入口,海口海南网站建设,做美工要开通什么网站的会员呢,二级域名免费申请网站ConsumerRecord 是 Apache Kafka 消费者从主题中读取消息时的核心数据结构,每条消息都会被封装为一个 ConsumerRecord 对象。它包含了消息的元数据(如来源、位置)和实际内容,是消费者处理消息的基础单元。以下是其核心要点&#x…

ConsumerRecord 是 Apache Kafka 消费者从主题中读取消息时的核心数据结构,每条消息都会被封装为一个 ConsumerRecord 对象。它包含了消息的元数据(如来源、位置)和实际内容,是消费者处理消息的基础单元。以下是其核心要点:

ConsumerRecord 的结构与字段

每个 ConsumerRecord 包含以下关键信息:

topic:消息所属的 Kafka 主题名称(字符串)

partition:消息所在分区的编号(整数)

offset:消息在分区中的唯一位置标识(长整数),用于追踪消费进度

key:消息的键(泛型),通常用于分区路由或业务标识(如订单ID

value:消息的值(泛型),即实际传输的数据(如 JSON 字符串、二进制数据等)

timestamp:消息的时间戳(长整数),表示消息生成或追加到分区的时间

headers:消息头(键值对集合),用于传递业务元数据(如消息类型、版本号)

checksum:校验和(长整数,已逐步弃用),用于验证消息完整性

在代码中的使用示例

在 Java 或 Spring Kafka 中,ConsumerRecord 通常通过消费者监听器(如 @KafkaListener)接收并处理:

@KafkaListener(topics = "orders")
public void handleOrder(ConsumerRecord<String, Order> record) {String key = record.key();         // 获取消息键(如订单ID)Order value = record.value();     // 获取消息值(如订单对象)String topic = record.topic();     // 获取主题名称long offset = record.offset();     // 获取消息偏移量// 处理业务逻辑...
}

源码

//
// Source code recreated from a .class file by IntelliJ IDEA
// (powered by FernFlower decompiler)
//package org.apache.kafka.clients.consumer;import java.util.Optional;
import org.apache.kafka.common.header.Headers;
import org.apache.kafka.common.header.internals.RecordHeaders;
import org.apache.kafka.common.record.DefaultRecord;
import org.apache.kafka.common.record.TimestampType;public class ConsumerRecord<K, V> {public static final long NO_TIMESTAMP = -1L;public static final int NULL_SIZE = -1;public static final int NULL_CHECKSUM = -1;private final String topic;private final int partition;private final long offset;private final long timestamp;private final TimestampType timestampType;private final int serializedKeySize;private final int serializedValueSize;private final Headers headers;private final K key;private final V value;private final Optional<Integer> leaderEpoch;private volatile Long checksum;public ConsumerRecord(String topic, int partition, long offset, K key, V value) {this(topic, partition, offset, -1L, TimestampType.NO_TIMESTAMP_TYPE, -1L, -1, -1, key, value);}public ConsumerRecord(String topic, int partition, long offset, long timestamp, TimestampType timestampType, long checksum, int serializedKeySize, int serializedValueSize, K key, V value) {this(topic, partition, offset, timestamp, timestampType, checksum, serializedKeySize, serializedValueSize, key, value, new RecordHeaders());}public ConsumerRecord(String topic, int partition, long offset, long timestamp, TimestampType timestampType, Long checksum, int serializedKeySize, int serializedValueSize, K key, V value, Headers headers) {this(topic, partition, offset, timestamp, timestampType, checksum, serializedKeySize, serializedValueSize, key, value, headers, Optional.empty());}public ConsumerRecord(String topic, int partition, long offset, long timestamp, TimestampType timestampType, Long checksum, int serializedKeySize, int serializedValueSize, K key, V value, Headers headers, Optional<Integer> leaderEpoch) {if (topic == null) {throw new IllegalArgumentException("Topic cannot be null");} else if (headers == null) {throw new IllegalArgumentException("Headers cannot be null");} else {this.topic = topic;this.partition = partition;this.offset = offset;this.timestamp = timestamp;this.timestampType = timestampType;this.checksum = checksum;this.serializedKeySize = serializedKeySize;this.serializedValueSize = serializedValueSize;this.key = key;this.value = value;this.headers = headers;this.leaderEpoch = leaderEpoch;}}public String topic() {return this.topic;}public int partition() {return this.partition;}public Headers headers() {return this.headers;}public K key() {return this.key;}public V value() {return this.value;}public long offset() {return this.offset;}public long timestamp() {return this.timestamp;}public TimestampType timestampType() {return this.timestampType;}/** @deprecated */@Deprecatedpublic long checksum() {if (this.checksum == null) {this.checksum = DefaultRecord.computePartialChecksum(this.timestamp, this.serializedKeySize, this.serializedValueSize);}return this.checksum;}public int serializedKeySize() {return this.serializedKeySize;}public int serializedValueSize() {return this.serializedValueSize;}public Optional<Integer> leaderEpoch() {return this.leaderEpoch;}public String toString() {return "ConsumerRecord(topic = " + this.topic + ", partition = " + this.partition + ", leaderEpoch = " + this.leaderEpoch.orElse((Object)null) + ", offset = " + this.offset + ", " + this.timestampType + " = " + this.timestamp + ", serialized key size = " + this.serializedKeySize + ", serialized value size = " + this.serializedValueSize + ", headers = " + this.headers + ", key = " + this.key + ", value = " + this.value + ")";}
}
http://www.dtcms.com/wzjs/613015.html

相关文章:

  • 响应式网站pad尺寸石家庄新闻综合频道
  • 外贸用什么网站开发客户58同城网络营销
  • 网站建设和程序开发哪个好无锡游戏网站建设公司
  • 泰州网站建设搭建中国十大培训机构影视后期
  • 网站设计 重庆seo优化主要工作内容
  • 网站建设入门 下载建网站费用明细
  • 山东济南网站建设安卓应用开发软件
  • 重庆网站推广专员信用网站建设内容
  • 平面设计图网站南京做网站团队
  • 深圳企业网站制作维护普通话考试最后一题万能模板
  • 网站搭建论文东昌府网站建设公司
  • 南阳市建设局网站wordpress更改字体大小
  • 南京做网站yuanmus表白网页制作软件手机版
  • 深圳专业建网站多少钱手机端网站做app开发
  • 互联网教育网站开发全平台内容系统免费
  • 怎么弄免费的php空间做网站微信答题小程序怎么做
  • 企业为啥要做网站wordpress loop count
  • 网站用亚马逊做标题会侵权吗高端网站优化公司
  • 做变性手术视频网站做国际贸易哪个网站好
  • 全球网站流量排名查询网站开发语言总结
  • 怎样自己做网站模板为什么建网站
  • 网站建设公司四川四川网站建设咨询
  • 免费的行情网站ifind是做动画网站
  • 网站图片设置要建一个网站该怎么做
  • 网站开发销售提成科技加盟网站建设
  • 国税网站建设调查报告网站做端口是什么问题
  • 男女做暖暖的试看网站什么是网站的后台
  • 分销网站有哪些公众号网页版
  • 网站维护建设东莞正规网页设计培训学费
  • 淘客推广效果阿里巴巴seo排名优化