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

网站设计师职责创新的购物网站建设

网站设计师职责,创新的购物网站建设,学设计哪个网站好,什么网站内链建设KafkaConsumer从Kafka拉取消息时发送的请求是FetchRequest(具体格式后面介绍),在其中需要指定消费者希望拉取的起始消息的offset。 为了消费者快速获取这个值#xff0c;KafkaConsumer使用SubscriptionState来追踪TopicPartition与offset对应关系。 图展示了SubscriptionSta…KafkaConsumer从Kafka拉取消息时发送的请求是FetchRequest(具体格式后面介绍),在其中需要指定消费者希望拉取的起始消息的offset。 为了消费者快速获取这个值KafkaConsumer使用SubscriptionState来追踪TopicPartition与offset对应关系。 图展示了SubscriptionState依赖的类以及其核心字段。 SubscriptionType是SubscriptionState的一个内部枚举类型表示的是订阅Topic的模式分为四类。 NONE:SubscriptionState.subscriptionType的初始值。AUTO_TOPICS:按照指定的Topic名字进行订阅自动分配分区。AUTO_PATTERN:按照指定的正则表达式匹配Topic进行订阅自动分配分区。USER_ASSIGNED:用户手动指定消费者消费的Topic以及分区编号。 TopicPartitionState表示的是TopicPartition的消费状态其关键字段如下所示。 position:记录了下次要从Kafka服务端获取的消息的offset。committed:记录了最近一次提交的offset。paused:记录了当前TopicPartition是否处于暂停状态与Consumer接口的pause方法相关。resetStrategy:OffsetResetStrategy枚举类型重置position的策略。同时此字段是否为空也表示了是否需要重置position的值。 TopicPartitionState提供了管理上面四个字段方法比较简单不再赘述。 在前面介绍Consumer接口时提到过subscribe()方法和assign()方法是互斥的。其实上面介绍的三种模式都是互斥的。下面是setSubscriptionType()方法的代码无论选择哪种模式都会调用此方法进行设置如图3-10所示。 下面介绍SubscriptionState的核心字段。 subscriptionType:SubscriptionType枚举类型表示订阅的模式。subscribedPattern:使用AUTO_PATTERN模式时是按照此字段记录的正则表达式对所有Topic进行匹配对匹配符合的Topic进行订阅。subscription:如果使用AUTO_TOPICS或AUTO_PATTERN模式则使用此集合记录所有订阅的Topic。向subscription集合中添加数据的方法只有changeSubscription方法而调用changeSubscription()方法有两处如图所示。 在图中的①处使用的是AUTO_TOPICS模式订阅 图中的②处使用AUTOPATTERN模式订阅。 我们在前面介绍Metadata的时候提到过可以在其上添加Listener,当Metadata更新时会触发Metadata.Listener.onMetadataUpdate()方法图中的②处就是在Metadata的Listener中通过subscribedPattern模式过滤Topic,并调用changeSubscription()方法修改subscription集合。 userAssignment:如果使用USER_ASSIGNED模式则此集合记录了分配给当前消费者的TopicPartition集合。SubscriptionType模式是互斥的所以userAssignment集合与subscription集合也是互斥的。assignment:MapTopicPartition,TopicPartitionState类型无论使用什么订阅模式都使用此集合记录每个TopicPartition的消费状态。groupSubscription:在前面描述的协议中Consumer Group中会选举一个Leader,Leader使用该集合记录Consumer Group中所有消费者订阅的Topic,而其他Follower的该集合中只保存了其自身的订阅的Topic。 图中的①处是将消费者自身订阅的Topic添加到groupSubscribe集合 ②处是在Leader收到JoinGroupResponse时调用在JoinGroupResponse中包含了全部消费者订阅的Topic,在此时将Topic信息添加到groupSubscribe集合。 ③处则是将groupSubscribe中其他消费者订阅的Topic删除只留下自身订阅的Topic(即subscription集合),这是groupSubscription集合收缩的场景。 needsPartitionAssignment:标记是否需要进行一次分区分配。这里简单了解一下修改needPartitionAssignment的场景和含义如图所示。 图中的①、⑤处将needsPartitionAssignment设置为true是因为消费者订阅的Topic发生了变化所以需要进行分区分配 ③处将needsParitionAssignment设置为false是因为使用USER_ASSIGNED订阅模式所以不需要分区分配操作 ④处是成功得到SyncGroupResponse中的分区分配结果时的操作此时Rebalance操作结束将needsPartitionAssignment设置为false; ②处的场景比较复杂调用②处将needRessignment设置为true,主要是因为在某些请求响应中出现了ILLEGAL_GENERATION等异常或是订阅的Topic出现了分区数量的变化调用关系如图所示。 needsFetchCommittedOffsets:标记是否需要从GroupCoordinator获取最近提交的offset。当出现异步提交offset操作或是Rebalance操作刚完成时会将其置为true,成功获取最近提交offset之后会设置为fasle。defaultResetStrategy:默认OffsetResetStrategy策略。listener:ConsumerRebalanceListener类型用于监听分区分配操作。 SubscriptionState中的方法主要是管理上面的几个集合字段操作比较简单不再详细介绍。下面简单分析前面示例中使用的subscribe()方法
http://www.zqtcl.cn/news/759345/

相关文章:

  • 上海企业响应式网站建设推荐网站建设类织梦模板
  • 洛阳最好的做网站的公司哪家好信誉好的邢台做网站
  • 织梦 旅游网站模板seo百家外链网站
  • 做网站提升公司形象摄影网站建设任务书
  • wordpress建站不好用wordpress共用用户多站点
  • 企业网站设计请示杭州做企业网站的公司
  • 苏宁易购网站建设的不足之处wordpress myisam
  • 互联网站建设维护是做什么的网站建设模板成功案例
  • 制作网站需要什么语言wordpress 免签约支付宝
  • 西安网站开发的未来发展易企网络网站建设
  • 贵州做网站怎么推广vs2012 做网站教程
  • 完全菜鸟七天学会建网站网络营销的四大基础理论
  • 东莞网站优化案例网站职业技术培训学校
  • 银川网站建设公司电话公司在百度做网站找谁
  • 交换链接适用于哪些网站网络规划与设计的目的
  • 网站做标签寺院网站模板
  • 高端h5网站柳州建站
  • 百度商桥网站郑州有做网站的公司没
  • 做专业网站济南品牌网站建设低价
  • 网站制作客户寻找数据中台厂商
  • 免费找图片素材的网站西安企业seo
  • 网站建设 名词解释国内网站建设建设
  • 文山州建设局网站域名查询seo
  • php网站模块修改太原小店区最新消息今天
  • 苏州网站优化公司seo服务合同
  • vip影视网站怎么做的辽宁建设厅网站什么时候换的
  • 搭建个网站网站维护合同模板
  • 优盖网logo在线设计南通做网站优化的公司
  • 做百度糯米网站的团队新媒体营销推广公司
  • 个人做网站的时代已经过去大连男科医院排名表