问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501

通过Spring Cloud Stream 进行 RoctetMQ 消息操作

发布网友 发布时间:2024-10-22 19:47

我来回答

1个回答

热心网友 时间:2024-10-22 20:04

Spring Cloud Stream 简介

Spring Cloud Stream 是一个框架,用于构建与共享消息系统连接的高度可扩展的事件驱动微服务。 该框架提供了一个灵活的编程模型,该模型基于已经建立和熟悉的 Spring 习惯用法和最佳实践,包括对持久 pub/sub 语义、消费者组和有状态分区的支持。

Spring Cloud Stream支持哪些消息中间件

Spring Cloud Stream 支持的消息中间件如下图所示:

快速使用设置依赖(pom)

对于依赖,我们需要注意 spring-boot``spring-cloud``spring-cloud-alibaba版本对应关系即可。

<properties><maven.compiler.target>1.8</maven.compiler.target><maven.compiler.source>1.8</maven.compiler.source><spring.boot.version>2.2.4.RELEASE</spring.boot.version><spring.cloud.version>Hoxton.SR1</spring.cloud.version><spring.cloud.alibaba.version>2.2.0.RELEASE</spring.cloud.alibaba.version></properties><dependencyManagement><dependencies><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-parent</artifactId><version>${spring.boot.version}</version><type>pom</type><scope>import</scope></dependency><dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-dependencies</artifactId><version>${spring.cloud.version}</version><type>pom</type><scope>import</scope></dependency><dependency><groupId>com.alibaba.cloud</groupId><artifactId>spring-cloud-alibaba-dependencies</artifactId><version>${spring.cloud.alibaba.version}</version><type>pom</type><scope>import</scope></dependency></dependencies></dependencyManagement><dependencies><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId></dependency><dependency><groupId>com.alibaba.cloud</groupId><artifactId>spring-cloud-starter-stream-rocketmq</artifactId></dependency></dependencies>设置配置(yml)

配置 ?rocketmq需要的一些基础配置信息。

spring:cloud:stream:bindings:input:destination: TestTopicgroup: TestGroupoutput:destination: TestTopicrocketmq:binder:name-server: 127.0.0.1:9876server:port: 18080设置启动类@EnableBinding({Source.class, Sink.class})@SpringBootApplicationpublic class RocketMQApplication {public static void main(String[] args) {SpringApplication.run(RocketMQApplication.class, args);}}消息生产者

主要是实现发消息

@Componentpublic class RocketMQProducer {@Resourceprivate Source source;public void sendMessage(String msg) {Map<String, Object> headers = new HashMap<>();headers.put(MessageConst.PROPERTY_TAGS, "testTag");MessageHeaders messageHeaders = new MessageHeaders(headers);Message<String> message = MessageBuilder.createMessage(msg,messageHeaders);this.source.output().send(message);}}消息消费者

主要是用来接受消息, 并且打印消息的内容。

@Componentpublic class TestTopicConsumer {@StreamListener(Sink.INPUT)public void onMessage(String messsage) {System.out.println("received message:" + messsage + " from binding:" + Sink.INPUT);}}测试

我们编写一个 TestController类,对外提供一个发消息的接口,去调用发消息,实现发消息。

@RestController@RequestMapping("/MQTest")public class TestController {@Resourceprivate RocketMQProducer producer;@RequestMapping("/sendMessage")public String sendMessage(String message) {producer.sendMessage(message);return "send message success";}}

测试发消息,执行命令 curl http://127.0.0.1:18080/MQTest/sendMessage\?message\=hahha , 返回结果如下:服务端控制台输出如下:

总结

本文简答的对 Spring Cloud Stream ?整合 RockectMQ 做了实践,但是在我们在实际开发过程中,这样来做是远远不够的,注意这个只是案例,后面我也会分享项目中正真使用的方案。

原文:https://juejin.cn/post/7104282113075068965
声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com
日语鼻浊音怎么个读法,我是自学的,背完50音图之后看这个有点乱。_百度... 日语中的鼻浊音一定要发吗 日语的鼻浊音到底是什么鬼 日语 哪两行有鼻浊音? 日语里面有没有鼻浊音啊,就是"か"那一行,是否当不是句首时就读鼻... 魔兽世界奶僧和踏风武僧pve和pvp分别用什么雕文和天赋,求大神! pvp奶僧拿550双手好还是单手好 魔兽世界5.0熊猫武增要什用什么装备武器 问一下,长城4S店的销售顾问待遇怎样 慎重词语解释 分析Spring Cloud Stream 消费者端的工作流程 8千瓦汽油发电机耗油量是多少? 情人老公敲诈勒索我40万精神补偿费怎么办 ...包装袋时是否需要将自身企业获QS编号印制上去,如不印,如何处理,依 ... 丛林之狐怎么拿武器? 产品包装盒 丛林之狐的画质问题!高分!!! 丛林之狐的问题 国内一线鞋业品牌都有哪些? 足球鞋哪一种好 股东直接诉讼是什么 私募基金是做什么 婴儿床垫怎么选择?用什么材质好?2022婴儿床垫品牌推荐(可优比,慕思... 抽油烟电容坏多久会烧电机 抽油烟机电容损坏后多久容易导致电机... 陋巷箪瓢 贫贱之知 独脚铜人概述 500多颗树木被他人肆意全部砍伐,报警说公安来了说不规他们管,怎么... 口袋妖怪竞技场金银游戏背景 狗吃芒果会有什么后果 在古代,"字"是什么意思 喝纯净水好还是矿泉水好!! 我有一个新的红色的箱子 怎么翻译? 使命召唤9僵尸模式银行的地下室(就是升级武器的地下室)怎么开_百度知 ... 翻译为英语 失物招领 红色的钱包 许多钱 两周 在书架上 在操场上 英语... 使命召唤9僵尸模式大迁徙如何从第一 站直接去第五站取钱 ...一个裙子是红色的。非常漂亮它只要6元 我还有一个棕色的乒乓球拍 是... AutoCAD 2007建筑制图实例导航目录 办理广发信用卡需要多久?可以加急办理吗? AutoCAD 2009建筑制图100例目录 当鸟的好处有哪些?拜托各位了 3Q AutoCAD全套室内图纸绘制自学手册内容简介 "英特纳雄耐尔"的真正含义是什么? 对于初次来英国游玩的游客,有哪些建议或贴士值得分享? 去英国旅游有哪些建议值得参考? 深圳锦辉印刷厂公司简介 宝安福永彩页印刷厂,彩页印刷厂,说明书,彩盒。手提纸袋,礼品盒... 帮我想一个,中间带有“寻梦”2字的网名,最少要8字以上的,最好是幸福... ...帮做个好看的网名喔,要包括守护雅儿这4个字,字要是繁体或火星文都... ...点儿的情侣网名,最好是短点儿的,最好是两个字的 ,就像半夏,微凉,可以...