Kafka源码之异步发送模式
异步发送消息
在发送消息的时候设置回调函数:
data:image/s3,"s3://crabby-images/3a624/3a624e6662e45482c6e40f21bc93841a968d0fac" alt=""
调⽤KafkaProducer的send⽅法,该⽅法接收要发送的消息批,同时接收回调对象:
data:image/s3,"s3://crabby-images/400b2/400b25c4eb52d9c845f8da1b43027e6d142a5288" alt=""
doSend的实现:
data:image/s3,"s3://crabby-images/709f8/709f88cf5c7aed7233ccabba61cc864d95fe461c" alt=""
累加器append的实现:
data:image/s3,"s3://crabby-images/85dc8/85dc837de949421ef68024ee135329e51d450f6f" alt=""
tryAppend的实现:
data:image/s3,"s3://crabby-images/63aa4/63aa4ebafeda62fbada3f3b453c1b1d6b7b71011" alt=""
data:image/s3,"s3://crabby-images/f70e4/f70e42c08116872b28281b64690addb022f3ec7b" alt=""
Sender的run⽅法调⽤:
data:image/s3,"s3://crabby-images/65541/6554163d5f95973551e8d602db988c9df1476965" alt=""
sendProducerData的实现:
data:image/s3,"s3://crabby-images/210d6/210d6640f70327f25bce2a2b76c94b31d8c6e9e6" alt=""
sendProducerRequests的实现:
data:image/s3,"s3://crabby-images/cb5d4/cb5d46c7da5f1027542bcedcf9931cb36046d801" alt=""
data:image/s3,"s3://crabby-images/99968/9996898a3345a4c9f37528ef590d0411cbb9dd5b" alt=""
上述⽅法如果得到broker的响应,就回调 handleProduceResponse ⽅法:
data:image/s3,"s3://crabby-images/91d96/91d9693bee914ec0ab179446c920f14dee12d489" alt=""
该⽅法对响应的处理:
data:image/s3,"s3://crabby-images/62c9c/62c9c206f18017b741d3fe2ea984b2b9f26d9bf2" alt=""
completeBatch的实现:
data:image/s3,"s3://crabby-images/7fa0a/7fa0a3daf51fe492b5f9665ceec215bbff2b53b6" alt=""
data:image/s3,"s3://crabby-images/a95ab/a95abb2d8f245b665f8e4ef3fb85008a413db5f7" alt=""
completeBatch的实现:
data:image/s3,"s3://crabby-images/a6baf/a6baf3c14372b25e6c7095ecf1b3ca13c9024958" alt=""
batch的done⽅法:
data:image/s3,"s3://crabby-images/9d38e/9d38ebfca50cf709912a319511e998b93b8ec13f" alt=""
触发回调函数的执⾏:
data:image/s3,"s3://crabby-images/9a2d9/9a2d994833443f4178d30598ebd5764444b5ce38" alt=""
上图中执⾏⽤户设置的callback函数的onCompletion⽅法:
data:image/s3,"s3://crabby-images/06969/0696999a30a284f42787ec3fbf2c0116d998d1d9" alt=""
由于上述⽅法都是在Sender线程中调⽤,因此回调的onCompletion⽅法的执⾏也是异步的,跟⽤户的producer.send⽅法不在同⼀个线程。
回调的异步执⾏即是⽣产的异步发送模式。
本博客所有文章除特别声明外,均采用 CC BY-NC-SA 4.0 许可协议。转载请注明来自 WeiJia_Rao!