kafka源码学习之--生产者原理

1.生产者发送消息

1.1 找到kafka生产者入口–这里通过KafkaTemplate发送消息

在这里插入图片描述

点击send()方法,进入doSend()
在这里插入图片描述

ProducerRecord主要是创建要发送到 Kafka 的记录,topic需要指定,其他参数可自配
在这里插入图片描述
KafkaTemplate通过工厂模式创建kafkaProducer

在这里插入图片描述

找到ProducerFactory的实现类进入DefaultKafkaProducerFactory的createProducer方法
在这里插入图片描述
找到创建kafkaProducer的位置
在这里插入图片描述

在kafkaProducer里面,创建kafkaProduce实例,并且创建了一个sender对象,启动了一个io线程
这个io线程就是kafka发送线程,生产者发送消息时,这个线程会被唤醒
在这里插入图片描述
kafkaProducer创建完成之后,在回到消息发送的位置
在这里插入图片描述

调用send()方法发送消息
在这里插入图片描述
在kafkaProducer sender发送线程被唤醒之前,kafkaProducer的main线程会进行几个逻辑处理

1.拦截器逻辑

在这里插入图片描述
走代码中可以看出,生产者可以实现你多个拦截器,形成一个拦截链
在这里插入图片描述

发送消息测试
在这里插入图片描述

2.用指定的序列化器分别对key,value进行序列化

在这里插入图片描述

3.指定分区器

kafka的消息会发送到partiton中,但是具体到哪个分区器,可以自己指定,没有指定的话,kafka已经实现自动分配,分4中情况
1.在指定partition情况下,直接将指定的partition作为partiton值
在这里插入图片描述
2.没有指定partiton但是自定义了分区器
在这里插入图片描述
在这里插入图片描述
3.没有指定partiton但是存在key的情况下,会使用默认的分区器DefaultPartitioner
在这里插入图片描述
4.在既没有指定partiton也没有指定key的情况下,第一次调用时,会随机生成一个整数(之后每次调用在这个基础上自增)然后将这个值对当前topic可用的partiton取余(轮询round-robin)
在这里插入图片描述
4.消息累加器
在这里插入图片描述
分区选择完成后,并没有立即将消息发送出去,而是把消息放进了一个累加器(ConcurrentMap)缓存起来,什么时候发送跟batch-size有关
在这里插入图片描述
在这里插入图片描述
kafka尽可能的保证消息先往一个分区里发送,当这个分区的batch-size已经不足以在继续追加存放消息,kafka会考虑更换一个pattition分区继续往该分区的的累加器里累加消息,如果再次追加失败,这个时候kafka会新建batch,不会在尝试了,新建与否通过这个参数控制abortForNewBatch
在这里插入图片描述

在这里插入图片描述

最后唤醒sender线程发送消息
在这里插入图片描述

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值