<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
1.前面基於Springboot的單體專案介紹已經完結了,至於專案中的其他功能實現我這裡就不打算介紹了,因為涉及的知識點不難,而且都是簡單的CRUD操作,假如有興趣的話可以私信我我再看看要不要寫幾篇文章做個介紹。
2.完成上一階段的學習,我就投入到了微服務的學習當中,所用教學為B站上面黑馬的微服務教學。由於我的記性不是很好,所以對於新事物的學習我比較喜歡做筆記以加強理解,在這裡我會將筆記的重點內容做個總結髮布到“微服務學習”筆記欄目中。我是趙四,一名有追求的程式設計師,希望大家能多多支援,能給我點個關注就更好了。
建立一個Controller包並編寫一個測試類用於傳送訊息
package com.my.kafka.controller; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.kafka.core.KafkaTemplate; import org.springframework.web.bind.annotation.GetMapping; import org.springframework.web.bind.annotation.RestController; @RestController public class HelloController { @Autowired private KafkaTemplate<String,String> kafkaTemplate; @GetMapping("hello") public String helloProducer(){ kafkaTemplate.send("my-topic","Hello~"); return "ok"; } }
編寫測試類用於接收訊息:
package com.my.kafka.listener; import org.junit.platform.commons.util.StringUtils; import org.springframework.kafka.annotation.KafkaListener; import org.springframework.stereotype.Component; @Component public class HelloListener { @KafkaListener(topics = "my-topic") public void helloListener(String message) { if(StringUtils.isNotBlank(message)) { System.out.println(message); } } }
開啟瀏覽器輸入localhost:9991/hello,然後到控制檯檢視訊息,可以看到成功訊息監聽到並且進行了消費。
目前springboot整合後的kafka,因為序列化器是StringSerializer,這個時候如果需要傳遞物件可以有兩種方式:
方式一:可以自定義序列化器,物件型別眾多,這種方式通用性不強,這裡不做介紹。
方式二:可以把要傳遞的物件進行轉json字串,接收訊息後再轉為物件即可,本專案採用這種方式。
@GetMapping("hello") public String helloProducer(){ User user = new User(); user.setName("趙四"); user.setAge(20); kafkaTemplate.send("my-topic", JSON.toJSONString(user)); return "ok"; }
可以看到成功接收都物件引數,後期要使用該物件只需要將其轉換成User物件即可。
釋出文章之後,可能會由於文章出現某些錯誤或者其他原因,我們會在文章管理端實現文章的上下架功能(見下圖),也即當管理端實現對文章下架之後行動端將不會再展示該文章,只有該文章重新被上架之後才能在行動端看到該文章資訊。
後端接收到前端傳過來的引數之後要先做一個校驗,引數不為空才能繼續往下執行,首先應該根據前端傳過來的文章id(自媒體端文章id)查詢自媒體資料庫的文章資訊並判斷該文章是否已是釋出狀態,因為只有稽核成功併成功釋出了的文章才能進行上下架操作。自媒體端微服務對文章上下架狀態進行修改之後便可以向Kafka傳送一條訊息,該訊息為Map物件,裡面儲存的資料為行動端的文章id以及前端傳過來的上下架引數enable,當然要將該Map物件轉換成JSON字串才能進行傳送。
文章微服務監聽到Kafka傳送過來的訊息之後將JSON字串轉換成Map物件之後再獲取相關引數對行動端文章的上下架狀態進行修改。
<!-- kafkfa --> <dependency> <groupId>org.springframework.kafka</groupId> <artifactId>spring-kafka</artifactId> </dependency> <dependency> <groupId>org.apache.kafka</groupId> <artifactId>kafka-clients</artifactId> </dependency>
package com.my.common.constans; public class WmNewsMessageConstants { public static final String WM_NEWS_UP_OR_DOWN_TOPIC="wm.news.up.or.down.topic"; }
由於我是用Nacos來作為註冊中心,所以設定資訊放置在Nacos上面即可。
(1)自媒體端設定
spring: kafka: bootstrap-servers: 4.234.52.122:9092 producer: retries: 10 key-serializer: org.apache.kafka.common.serialization.StringSerializer value-serializer: org.apache.kafka.common.serialization.StringSerializer
(2)行動端設定
spring: kafka: bootstrap-servers: 4.234.52.122:9092 consumer: group-id: ${spring.application.name}-test key-deserializer: org.apache.kafka.common.serialization.StringDeserializer value-deserializer: org.apache.kafka.common.serialization.StringDeserializer
@Autowired private KafkaTemplate<String,String> kafkaTemplate; /** * 文章下架或上架 * @param id * @param enable * @return */ @Override public ResponseResult downOrUp(Integer id,Integer enable) { log.info("執行文章上下架操作..."); if(id == null || enable == null) { return ResponseResult.errorResult(AppHttpCodeEnum.PARAM_INVALID); } //根據id獲取文章 WmNews news = getById(id); if(news == null) { return ResponseResult.errorResult(AppHttpCodeEnum.DATA_NOT_EXIST,"文章資訊不存在"); } //獲取當前文章狀態 Short status = news.getStatus(); if(!status.equals(WmNews.Status.PUBLISHED.getCode())) { return ResponseResult.errorResult(AppHttpCodeEnum.PARAM_INVALID,"文章非釋出狀態,不能上下架"); } //更改文章狀態 news.setEnable(enable.shortValue()); updateById(news); log.info("更改文章上架狀態{}-->{}",status,news.getEnable()); //傳送訊息到Kafka Map<String, Object> map = new HashMap<>(); map.put("articleId",news.getArticleId()); map.put("enable",enable.shortValue()); kafkaTemplate.send(WmNewsMessageConstants.WM_NEWS_UP_OR_DOWN_TOPIC,JSON.toJSONString(map)); log.info("傳送訊息到Kafka..."); return ResponseResult.okResult(AppHttpCodeEnum.SUCCESS); }
(1)設定監聽器
package com.my.article.listener; import com.baomidou.mybatisplus.core.toolkit.StringUtils; import com.my.article.service.ApArticleService; import com.my.common.constans.WmNewsMessageConstants; import lombok.extern.slf4j.Slf4j; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Component; import org.springframework.kafka.annotation.KafkaListener; @Slf4j @Component public class EnableListener { @Autowired private ApArticleService apArticleService; @KafkaListener(topics = WmNewsMessageConstants.WM_NEWS_UP_OR_DOWN_TOPIC) public void downOrUp(String message) { if(StringUtils.isNotBlank(message)) { log.info("監聽到訊息{}",message); apArticleService.downOrUp(message); } } }
(2)獲取訊息並修改文章狀態
/** * 文章上下架 * @param message * @return */ @Override public ResponseResult downOrUp(String message) { Map map = JSON.parseObject(message, Map.class); //獲取文章id Long articleId = (Long) map.get("articleId"); //獲取文章待修改狀態 Integer enable = (Integer) map.get("enable"); //查詢文章設定 ApArticleConfig apArticleConfig = apArticleConfigMapper.selectOne (Wrappers.<ApArticleConfig>lambdaQuery().eq(ApArticleConfig::getArticleId, articleId)); if(apArticleConfig != null) { //上架 if(enable == 1) { log.info("文章重新上架"); apArticleConfig.setIsDown(false); apArticleConfigMapper.updateById(apArticleConfig); } //下架 if(enable == 0) { log.info("文章下架"); apArticleConfig.setIsDown(true); apArticleConfigMapper.updateById(apArticleConfig); } } else { throw new RuntimeException("文章資訊不存在"); } return ResponseResult.okResult(AppHttpCodeEnum.SUCCESS); }
到此這篇關於Springboot微服務專案整合Kafka實現文章上下架功能的文章就介紹到這了,更多相關Springboot整合Kafka內容請搜尋it145.com以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援it145.com!
相關文章
<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
综合看Anker超能充系列的性价比很高,并且与不仅和iPhone12/苹果<em>Mac</em>Book很配,而且适合多设备充电需求的日常使用或差旅场景,不管是安卓还是Switch同样也能用得上它,希望这次分享能给准备购入充电器的小伙伴们有所
2021-06-01 09:31:42
除了L4WUDU与吴亦凡已经多次共事,成为了明面上的厂牌成员,吴亦凡还曾带领20XXCLUB全队参加2020年的一场音乐节,这也是20XXCLUB首次全员合照,王嗣尧Turbo、陈彦希Regi、<em>Mac</em> Ova Seas、林渝植等人全部出场。然而让
2021-06-01 09:31:34
目前应用IPFS的机构:1 谷歌<em>浏览器</em>支持IPFS分布式协议 2 万维网 (历史档案博物馆)数据库 3 火狐<em>浏览器</em>支持 IPFS分布式协议 4 EOS 等数字货币数据存储 5 美国国会图书馆,历史资料永久保存在 IPFS 6 加
2021-06-01 09:31:24
开拓者的车机是兼容苹果和<em>安卓</em>,虽然我不怎么用,但确实兼顾了我家人的很多需求:副驾的门板还配有解锁开关,有的时候老婆开车,下车的时候偶尔会忘记解锁,我在副驾驶可以自己开门:第二排设计很好,不仅配置了一个很大的
2021-06-01 09:30:48
不仅是<em>安卓</em>手机,苹果手机的降价力度也是前所未有了,iPhone12也“跳水价”了,发布价是6799元,如今已经跌至5308元,降价幅度超过1400元,最新定价确认了。iPhone12是苹果首款5G手机,同时也是全球首款5nm芯片的智能机,它
2021-06-01 09:30:45