欧美一级特黄大片做受成人-亚洲成人一区二区电影-激情熟女一区二区三区-日韩专区欧美专区国产专区

springboot中怎么實現(xiàn)kafa指定offset消費

小編給大家分享一下springboot中怎么實現(xiàn)kafa指定offset消費,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

成都創(chuàng)新互聯(lián)公司是專業(yè)的樂山網(wǎng)站建設(shè)公司,樂山接單;提供成都網(wǎng)站建設(shè)、網(wǎng)站建設(shè),網(wǎng)頁設(shè)計,網(wǎng)站設(shè)計,建網(wǎng)站,PHP網(wǎng)站建設(shè)等專業(yè)做網(wǎng)站服務(wù);采用PHP框架,可快速的進行樂山網(wǎng)站開發(fā)網(wǎng)頁制作和功能擴展;專業(yè)做搜索引擎喜愛的網(wǎng)站,專業(yè)的做網(wǎng)站團隊,希望更多企業(yè)前來合作!

kafka消費過程難免會遇到需要重新消費的場景,例如我們消費到kafka數(shù)據(jù)之后需要進行存庫操作,若某一時刻數(shù)據(jù)庫down了,導致kafka消費的數(shù)據(jù)無法入庫,為了彌補數(shù)據(jù)庫down期間的數(shù)據(jù)損失,有一種做法我們可以指定kafka消費者的offset到之前某一時間的數(shù)值,然后重新進行消費。

首先創(chuàng)建kafka消費服務(wù)

@Service@Slf4j//實現(xiàn)CommandLineRunner接口,在springboot啟動時自動運行其run方法。public class TspLogbookAnalysisService implements CommandLineRunner { @Override public void run(String... args) {  //do something }}

kafka消費模型建立

kafka server中每個主題存在多個分區(qū)(partition),每個分區(qū)自己維護一個偏移量(offset),我們的目標是實現(xiàn)kafka consumer指定offset消費。

在這里使用consumer-->partition一對一的消費模型,每個consumer各自管理自己的partition。

@Service@Slf4jpublic class TspLogbookAnalysisService implements CommandLineRunner { //聲明kafka分區(qū)數(shù)相等的消費線程數(shù),一個分區(qū)對應(yīng)一個消費線程 private static final int consumeThreadNum = 9; //特殊指定每個分區(qū)開始消費的offset private List<Long> partitionOffsets = Lists.newArrayList(1111,1112,1113,1114,1115,1116,1117,1118,1119);  private ExecutorService executorService = Executors.newFixedThreadPool(consumeThreadNum); @Override public void run(String... args) {  //循環(huán)遍歷創(chuàng)建消費線程  IntStream.range(0, consumeThreadNum)    .forEach(partitionIndex -> executorService.submit(() -> startConsume(partitionIndex))); }}

kafka consumer對offset的處理

聲明kafka consumer的配置類

private Properties buildKafkaConfig() { Properties kafkaConfiguration = new Properties(); kafkaConfiguration.put(ConsumerConfig.BOOTSTRAP_SERVERS_CONFIG, ""); kafkaConfiguration.put(ConsumerConfig.GROUP_ID_CONFIG, ""); kafkaConfiguration.put(ConsumerConfig.MAX_POLL_RECORDS_CONFIG, ""); kafkaConfiguration.put(ConsumerConfig.AUTO_COMMIT_INTERVAL_MS_CONFIG, ""); kafkaConfiguration.put(ConsumerConfig.KEY_DESERIALIZER_CLASS_CONFIG, ""); kafkaConfiguration.put(ConsumerConfig.VALUE_DESERIALIZER_CLASS_CONFIG, ""); kafkaConfiguration.put(ConsumerConfig.AUTO_OFFSET_RESET_CONFIG,""); kafkaConfiguration.put(ConsumerConfig.ENABLE_AUTO_COMMIT_CONFIG, ""); ...更多配置項 return kafkaConfiguration;}

創(chuàng)建kafka consumer,處理offset,開始消費數(shù)據(jù)任務(wù)#

private void startConsume(int partitionIndex) { //創(chuàng)建kafka consumer KafkaConsumer<String, byte[]> consumer = new KafkaConsumer<>(buildKafkaConfig()); try {  //指定該consumer對應(yīng)的消費分區(qū)  TopicPartition partition = new TopicPartition(kafkaProperties.getKafkaTopic(), partitionIndex);  consumer.assign(Lists.newArrayList(partition));  //consumer的offset處理  if (collectionUtils.isNotEmpty(partitionOffsets) && partitionOffsets.size() == consumeThreadNum) {   Long seekOffset = partitionOffsets.get(partitionIndex);   log.info("partition:{} , offset seek from {}", partition, seekOffset);   consumer.seek(partition, seekOffset);  }    //開始消費數(shù)據(jù)任務(wù)  kafkaRecordConsume(consumer, partition); } catch (Exception e) {  log.error("kafka consume error:{}", ExceptionUtils.getFullStackTrace(e)); } finally {  try {   consumer.commitSync();  } finally {   consumer.close();  } }}

消費數(shù)據(jù)邏輯,offset操作

private void kafkaRecordConsume(KafkaConsumer<String, byte[]> consumer, TopicPartition partition) { while (true) {  try {   ConsumerRecords<String, byte[]> records = consumer.poll(TspLogbookConstants.POLL_TIMEOUT);   //具體的處理流程   records.forEach((k) -> handleKafkaInput(k.key(), k.value()));   //?很重要:日志記錄當前consumer的offset,partition相關(guān)信息(之后如需重新指定offset消費就從這里的日志中獲取offset,partition信息)   if (records.count() > 0) {    String currentOffset = String.valueOf(consumer.position(partition));    log.info("current records size is:{}, partition is: {}, offset is:{}", records.count(), consumer.assignment(), currentOffset);   }    //offset提交     consumer.commitAsync();  } catch (Exception e) {   log.error("handlerKafkaInput error{}", ExceptionUtils.getFullStackTrace(e));  } }}

以上是“springboot中怎么實現(xiàn)kafa指定offset消費”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學習更多知識,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!

本文名稱:springboot中怎么實現(xiàn)kafa指定offset消費
網(wǎng)頁鏈接:http://aaarwkj.com/article22/pdegjc.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供品牌網(wǎng)站建設(shè)、品牌網(wǎng)站設(shè)計、網(wǎng)站設(shè)計品牌網(wǎng)站制作、軟件開發(fā)標簽優(yōu)化

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

成都seo排名網(wǎng)站優(yōu)化
亚洲一区二区三区久久精品| 亚洲国产精品中文字幕一区久久| 在线播放精品免费不卡 | av天堂五月在线观看| 成人在线一区二区三区观看| 国产91高清视频在线观看| 久久国产精品一区免费观看| 欧美日韩亚洲精品一区二区三区| 日本亚洲精品一区二区三| 亚洲av日韩av高潮| 日本区一区二区三视频| 精品人妻二区中文字幕| 成人精品欧美欧美一级乱黄| 成熟性性生活免费视频| 日韩av高清不卡一区二区三区| 日韩三级黄片在线观看| 中文字幕一区二区三区久久| 亚洲精品91在线中文字幕| 在线视频网友自拍偷拍| 国产精品精品国产色婷婷| 国内外成人皇色视频| 国产成人啪精品视频免费| 成人中文字幕日韩电影| 99久久精品人妻少妇一| 日本写真视频一区二区三区| 亚洲熟妇人妻一区二区三区| 亚洲欧洲精品真人av蜜臀| 婷婷精品国产欧美精品亚洲| 日本人妻系列中文字幕| 精精国产xxxx视频在线不卡| 好狼色欧美激情国产区| 二区三区成人在线观看| 亚洲巨大黑人一区二区三区| 中文字幕乱码日韩在线| 中文字幕乱码伊人三级| 久久夜色一区二区三区| 日本a级免费大片网站| 亚洲成色在线综合剧情网站| 免费久久人人爽人人爽| 亚洲一区在线观看激情| 国产av毛片一区二区|