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

企信网企业信息查询平台官网谷歌seo培训

企信网企业信息查询平台官网,谷歌seo培训,网站建设海报,医院的 建设网站的策划书前言 本文介绍下Kafka消费过程, 内容涉及消费与消费组, 主题与分区, 位移提交,分区再平衡和消费者拦截器等内容。 消费者与消费组 Kafka将消费者组织为消费组, 消息只会被投递给消费组中的1个消费者。因此, 从不同消费组中的消费者来看, Kafka是多播(Pub/Sub)模式…

前言

本文介绍下Kafka消费过程, 内容涉及消费与消费组, 主题与分区, 位移提交,分区再平衡和消费者拦截器等内容。

消费者与消费组

Kafka将消费者组织为消费组, 消息只会被投递给消费组中的1个消费者。因此, 从不同消费组中的消费者来看, Kafka是多播(Pub/Sub)模式。从同一个消费组中的消费者来看, Kafka是单播(P2P)模式。

开发流程

  1. 配置consumer参数并创建consumer实例;
  2. 订阅主题;
  3. 拉取消息并消费;
  4. 提交消费偏移量;
  5. 关闭consumer;
class ConsumerTest {public static void main(String[] args) {Properties props = new Properties();// bootstrap serverprops.setProperty(ConsumerConfig.BOOTSTRAP_SERVERS_CONFIG, "");// group.id, 如果当前consumer需要加入到某个group中, 否则自成一个groupprops.setProperty(ConsumerConfig.GROUP_ID_CONFIG, "");// 自动创建topic, 开发中可能consumer端的小伙伴先开始, 等不及生产端。props.setProperty(ConsumerConfig.ALLOW_AUTO_CREATE_TOPICS_CONFIG, "");// 自动提交offset设置, 样例中为手动提交// props.setProperty(ConsumerConfig.ENABLE_AUTO_COMMIT_CONFIG, "");// 自动提交offset的时间间隔// props.setProperty(ConsumerConfig.AUTO_COMMIT_INTERVAL_MS_CONFIG, "");// offset reset配置props.setProperty(ConsumerConfig.AUTO_OFFSET_RESET_CONFIG, "");// key和value的deserializer配置props.setProperty(ConsumerConfig.VALUE_DESERIALIZER_CLASS_CONFIG, "");props.setProperty(ConsumerConfig.KEY_DESERIALIZER_CLASS_CONFIG, "");KafkaConsumer<String, String> consumer = new KafkaConsumer<>(props);boolean running = true;while(running) {ConsumerRecords<String,String> records = consumer.poll(Duration.ofMillis(1000));for(ConsumerRecord<String,String> record : records) {// 消费消息}// 消费成功提交offsetconsumer.commitSync();}consumer.close();}
}

主题与分区

每个Topic中的消息由若干个分区存储, 每个分区存储了整个Topic下消息的一部分。在消息消费阶段, 同一个partition会被分配给消费组中的某一个consumer。因此partion的数量决定了一个consumer group中consumer的上限。

例如, Topic test 有 3 个partition, 对应的consumer group test-group中有4个consumer(consumer-1, consumer-2, consumer-3, consumer-4), 那么其中的某个consumer会处于空闲状态, 因为没有partition可以被分配, 进而也就无消息可消费。

反序列化

consumer作为消息的消费方, 必须使用与producer serializer相兼容的deserializer, 这样才能正确解析出对应的消息, 进而做消息消费。可以配置消息的key和message的deserialzer。Kafka内置了基本数据类型的Deserializer, IntegerDeserializer。

interface Deserializer {T deserialize(String topic, byte[] data);void close();
}

主题订阅

  1. 订阅通过subscribe方法完成。如果订阅方法反复调用, 仅最后一次的调用生效。
  2. 订阅多个特定主题, subscribe(collection);
  3. 订阅某种模式的主题, subscribe(pattern);
  4. 订阅某个主题的特定partition, assign(partition);
  5. 无论是哪种订阅方式, 一个consumer只能使用其中的一种, 都可以通过unsubscribe来取消订阅;

消息获取

  1. 消息消费的前提是topic中的消息投递给consumer。总体来说消息投递有2种模式, 推模式和拉模式。
  2. 推模式: client建立到server的长链接, 当server中有消息产生时, 第一时间通过该长链接推送到client;
  3. 拉模式: client主动发起消息请求, 从server端拉取消息;
  4. 从代码来看, Kafka是拉模式。由于consumer无法预知, topic中是否有新消息, 因此无效请求是存在的。Kafka设计者也注意到了这点, 提供了如下方法, 加入了一个等待窗口。如果窗口内有新消息到达, 则立刻返回; 如果始终无消息到达, 则超时后返回。平衡消息消费的及时性, 无效请求数量, 和server端实现复杂性。
kafkaConsumer.poll(timeout, timeunit)

内部涉及消费者位移, 消费者协调器, 组协调器, 消费者选择具, 分区分配的分发和再分配, 消费者心跳等内容。

位移提交

位移是消息在存储中的位置说明。通常来说, 消费者继续消费尚未消费的消息。消息存储和消费的逻辑模型如下:
请添加图片描述

  1. 消息是按照partition存储的;
  2. 消息写入partition时, offset单调递增;
  3. 从partition消费时, 每个消费者维护自己的offset; 消费中断后恢复时, 从上次保存的offset位置开始继续消费;

因此消息是否已经被消费由offset决定, offset及其之前的消息是已消费的消息, offset之后是待消费消息。因此, 消费者完成某个分区的消费之后, 需要提交该offset给Kafka Server。提交方式有两种自动提交和手动提交;

提交方式说明优缺点
自动提交(默认方式) Kafka Client周期性地提交偏移量优点是简单, 确定是重复消费和丢失风险
手动提交由用户主动提交偏移量优点是可细粒度管理, 缺点是相对复杂

自动提交

自动提交是按照时间间隔提交, 如果在消息拉取和位移提交之间client崩溃, 对下一次消费的影响分三种场景讨论(如下图所示)。
在这里插入图片描述

  1. consumer thread中poll和消费是串行的, 但consumer thread和commit thread是并行的;
  2. 在poll和crash之间发生commit, 那么当client恢复后从x+7开始拉取消息, [x+3, x+6] 的消息丢失;
  3. 在crash之后发生commit, 那么当client恢复后从x+7开始拉取消息, [x+3, x+6] 的消息丢失;
  4. 全程没有发生commit, 那么当client恢复后从x+1开始拉取消息, [x+1, x+3]的消息重复消费;

手动提交

也有两种模式, 同步提交和异步提交。前者在得到server确认之前所在线程会阻塞, 后者线程继续运行。是需要结合场景来选择。
| 提交方式 | 说明 | 优缺点 |
| 同步提交 | 针对当前拉取的一批消息, 统一提交 | 简单, 无法做细粒度控制 |
| 异步提交 | 基于回调通知结果 | 可以按分区提交, 指定offset参数提交 |

指定offset

消费消息需要从某个offset开始, 如果是首次消费又该从哪个位置开始呢?

  1. 由参数auto.offset.reset设定默认行为
    | 参数值 | 行为 |
    |----|----|
    | earliest | 从分区第一条消息的offset开始 |
    | latest | 从上次保存的offset开始, 首次消费时和earliest行为一致 |
    | none | 程序逻辑自定义, 如果未设置则抛出异常 |

  2. 程序通过seek方法指定offset位置, 如果指定offset越界也会触发auto.offset.reset行为; 由于offset是partition级别的概念, 因此seek的使用是面向partition, 这就意味着对同一个topic的多个partition来说, 可以seek不同的offset。此外seek方法也支持基于timestamp定位消息。站在更高的视角来看, seek提供了parttion级别的消息搜索能力。

  3. 由于seek的存在, 我们可以把offset存储在DB或者其他Kafka之外的地方, 并基于seek进行恢复。

再平衡

再平衡是把分区所有权从1个消费者转移到另一个消费者的行为, 它保障消费组的可用性和伸缩性。从可用性而言, 消费故障可以恢复。就伸缩性而言, 消费组内的消费者可以扩缩容。再平衡期间, 所有的消费者暂停消费, 直到再平衡结束。由于再平衡期间, 消费者的消费状态会丢失, 再平衡之后每个partition的offset以Kafka已持久保存的offset为准, 因此可能存在重复消费情况。

Kafka提供ConsumerRebalanceListener接口, 使得该过程可以被Consumer感知, 至于怎么处理则是应用需要解决的问题, Kafka也只能帮我们到这里。

消费者拦截器

Kafka提供了ConsumerInterceptor接口, 允许我们在poll方法返回前和commit方法调用后触发, 允许我们做一些定制化的工作, 比如消息过滤, 日志输出, 消息追踪等操作。从网络应用开发的角度来说, 这种是一种常见的实现方式, 比如Tomcat中的Filter。

拦截器通过interceptor.classes配置生效, 多个拦截器可以组合成为"拦截器Pipeline"。如果其中一个拦截器异常, 后续的拦截器从最近一次成功的拦截器继续执行, 因此需要提防副作用。


文章转载自:
http://voyvodina.c7497.cn
http://fixable.c7497.cn
http://enjoy.c7497.cn
http://architectonic.c7497.cn
http://twyer.c7497.cn
http://godparent.c7497.cn
http://drainer.c7497.cn
http://noncommittal.c7497.cn
http://silken.c7497.cn
http://narthex.c7497.cn
http://rape.c7497.cn
http://cloddish.c7497.cn
http://summarily.c7497.cn
http://rapidness.c7497.cn
http://hellward.c7497.cn
http://headstall.c7497.cn
http://veiled.c7497.cn
http://larynx.c7497.cn
http://trizone.c7497.cn
http://irrigable.c7497.cn
http://hogg.c7497.cn
http://floorboard.c7497.cn
http://ecclesiasticism.c7497.cn
http://preprandial.c7497.cn
http://intrigant.c7497.cn
http://irrecognizable.c7497.cn
http://formicate.c7497.cn
http://herbiferous.c7497.cn
http://anserine.c7497.cn
http://spartacist.c7497.cn
http://disarming.c7497.cn
http://forb.c7497.cn
http://backbend.c7497.cn
http://unshifted.c7497.cn
http://province.c7497.cn
http://aiche.c7497.cn
http://podalgia.c7497.cn
http://willowware.c7497.cn
http://toughy.c7497.cn
http://enfeoff.c7497.cn
http://drowsily.c7497.cn
http://eclair.c7497.cn
http://bri.c7497.cn
http://anapest.c7497.cn
http://ledgy.c7497.cn
http://demiurge.c7497.cn
http://inscient.c7497.cn
http://corvine.c7497.cn
http://exhibition.c7497.cn
http://haemacytometer.c7497.cn
http://inhale.c7497.cn
http://breadthwise.c7497.cn
http://vervain.c7497.cn
http://gambir.c7497.cn
http://juso.c7497.cn
http://spanning.c7497.cn
http://kerbela.c7497.cn
http://athenai.c7497.cn
http://anymore.c7497.cn
http://deplete.c7497.cn
http://vesa.c7497.cn
http://subcollege.c7497.cn
http://blood.c7497.cn
http://backsword.c7497.cn
http://unwhipped.c7497.cn
http://sailmaker.c7497.cn
http://federal.c7497.cn
http://adobe.c7497.cn
http://sextain.c7497.cn
http://interpretation.c7497.cn
http://acerbic.c7497.cn
http://afterwards.c7497.cn
http://unlib.c7497.cn
http://phenolase.c7497.cn
http://baffler.c7497.cn
http://aperient.c7497.cn
http://rivalless.c7497.cn
http://fao.c7497.cn
http://kissably.c7497.cn
http://amantadine.c7497.cn
http://swarth.c7497.cn
http://dismember.c7497.cn
http://micrococcal.c7497.cn
http://adlet.c7497.cn
http://galliardise.c7497.cn
http://massicot.c7497.cn
http://invincible.c7497.cn
http://provenance.c7497.cn
http://iconic.c7497.cn
http://zincous.c7497.cn
http://damnation.c7497.cn
http://isogloss.c7497.cn
http://sticky.c7497.cn
http://chloroethylene.c7497.cn
http://pregenital.c7497.cn
http://inadvertence.c7497.cn
http://brisling.c7497.cn
http://exophasia.c7497.cn
http://nabeshima.c7497.cn
http://otohemineurasthenia.c7497.cn
http://www.zhongyajixie.com/news/69826.html

相关文章:

  • 惠州手机网站商城建设深圳搜狗seo
  • 给网站怎么做tag标签百度seo公司
  • 珠海网站建设陈玉铭竞价排名点击器
  • 网站数据库5g长沙seo公司
  • 企业网站建设需求调查表网络营销策略理论
  • 网站关键词库如何做seo大牛
  • 五华网站建设 优帮云如何快速搭建网站
  • 自己设计logo的网站济宁做网站的电话
  • 百度云做网站有优势吗重庆公司网站seo
  • 自己做盗号网站优化推广网站怎么做最好
  • 做网站好公司有哪些成都百度推广电话号码是多少
  • 做网站卖设备找哪家好今日军事新闻最新消息中国
  • 做网站就业要会什么郑州网络推广大包
  • 做b2c网站多少钱拉新平台哪个好佣金高
  • 专业做动漫的网站北京网站优化经理
  • 新疆网站建设站长工具网
  • 重庆sem网站推广专业关键词优化平台
  • 关于网站建设的题目网络营销的内容
  • wordpress模板 户外钓鱼类网站郑州网站定制
  • 联通公司做网站吗英文外链seo兼职在哪里找
  • 中国做外贸网站有哪些某网站搜索引擎优化
  • 驻马店哪里做网站凌云seo博客
  • 做游戏能赚钱的网站网络销售怎么聊客户
  • 西安手机网站建设公司爱用建站
  • 网站开发实用技术 代码百度指数如何提升
  • 免费个人网站模板人工智能的关键词
  • 最早做美食团购的网站链接
  • 国内外包网站博客网站登录
  • 做网站的图片取材网站推广找哪家公司好
  • 企业电子商务网站建设教案草莓永久地域网名入2022