使用 Spring Cloud Bus 在微服务之间传递消息示例

时间:2023-04-23 02:10:55 来源: 腾讯云


(相关资料图)

下面是一个完整的示例,演示如何使用 Spring Cloud Bus 在微服务之间传递消息。该示例包含两个微服务,一个是消息发送者,另一个是消息接收者。

首先,我们需要创建一个 Spring Boot 项目,并添加 Spring Cloud Bus 和 RabbitMQ 的依赖。在 pom.xml 文件中添加以下依赖:

    org.springframework.cloud    spring-cloud-starter-bus-amqp    2.2.1.RELEASE    org.springframework.boot    spring-boot-starter-web    2.2.1.RELEASE    org.springframework.boot    spring-boot-starter-amqp    2.2.1.RELEASE

在创建的项目中,我们定义了一个消息类型 MyMessage,该类型包含一个字符串类型的 content 属性。

javaCopy codepublic class MyMessage implements Serializable {    private static final long serialVersionUID = 1L;    private String content;    public MyMessage(String content) {        this.content = content;    }    public String getContent() {        return content;    }    public void setContent(String content) {        this.content = content;    }}

然后,我们创建了一个消息发送者,该发送者使用 Spring Cloud Bus 发送消息。

@RestControllerpublic class MyController {    @Autowired    private MessageSender messageSender;    @PostMapping("/send")    public void sendMessage(@RequestBody MyMessage message) {        messageSender.sendMessage(message);    }}@Servicepublic class MessageSender {    private static final Logger LOGGER = LoggerFactory.getLogger(MessageSender.class);    @Autowired    private MessageChannel output;    public void sendMessage(MyMessage message) {        LOGGER.info("Sending message: {}", message.getContent());        output.send(MessageBuilder.withPayload(message).build());    }}@Servicepublic class MessageListener {    private static final Logger LOGGER = LoggerFactory.getLogger(MessageListener.class);    @StreamListener(target = Sink.INPUT, condition = "headers["type"]=="MyMessage"")    public void handleMessage(MyMessage message) {        LOGGER.info("Received message: {}", message.getContent());    }}

在这个例子中,我们创建了一个 MyController 类,该类定义了一个发送消息的 API 接口,接收一个 MyMessage 类型的参数,将参数传递给 MessageSender 类的 sendMessage() 方法。

MessageSender 类定义了一个 sendMessage() 方法,该方法使用 Spring Cloud Stream 的 output 消息通道发送消息。

MessageListener 类定义了一个 handleMessage() 方法,该方法使用 @StreamListener 注解监听 Spring Cloud Stream 的 input 消息通道,并根据消息类型过滤消息。当有符合条件的消息到达时,handleMessage() 方法会被自动调用,处理接收到的消息。

在以上代码中,我们使用了 @Autowired 注解自动注入了 MessageSender 和 MessageListener 类,这是 Spring Boot 自带的依赖注入功能。

运行应用程序后,我们可以使用 Postman 工具或其他 HTTP 工具发送 HTTP POST 请求,将消息发送到消息发送者的 API 接口,如下所示:

POST http://localhost:8080/send HTTP/1.1Content-Type: application/json{    "content": "Hello, World!"}

当消息到达时,消息接收者会打印消息内容,如下所示:

2023-04-19 09:24:47.836  INFO 29740 --- [afka-listener-1] com.example.demo.M

标签:

精彩推送

环球关注:回天新材:4月20日融资买入790.72万元,融资融券余额1.93亿元

4月20日,回天新材(300041)融资买入790 72万元,融资偿还1042 06万元,融资净卖出251 34万元,融资...

来源:2023.04.21

盛讯达:本次交易已于2022年12月完成交割_全球热资讯

盛讯达(300518)04月19日在投资者关系平台上答复了投资者关心的问题。投资者:宇瑞科技的收购现在处于什...

来源:2023.04.21

环球速看:让农村孩子在家门口上好学

从去年起,浙江省天台县石梁学校与赤城中学的部分七年级学生有了新的上学体验:两校选择等量学生混合编...

来源:2023.04.21

3分,3篮板,3失误,3犯规!这表现,怎么好意思问湖人要顶薪?_环球热讯

3分,3篮板,3失误,3犯规!这表现,怎么好意思问湖人要顶薪?,比斯利,里夫斯,湖人主场,孟菲斯灰熊队,威...

来源:2023.04.21

水的来源有哪些 水的来源资料

今天来聊聊关于水的来源有哪些,水的来源资料的文章,现在就为大家来简单介绍下水的来源有哪些,水的来...

来源:2023.04.21

渑池县法院为25为农民工兄弟讨回工资

4月13日,渑池县人民法院在该院接待中心给来自河南息县、湖北公安县的25位农民工兄弟代表,办理追回工资...

来源:2023.04.21

天天热消息:山高新能源集团(01250.HK)1月份累计总发电量约41.38万兆瓦时 同比增长46.1%

格隆汇4月19日丨山高新能源集团(01250 HK)宣布,根据公司现有的初步统计,2023年1月集团按合并报表口径完成发

来源:2023.04.21

如何有效激发学习动机_如何有效学习-速看

1、首先,要学会听课:有准备的去听,也就是说听课前要先预习,找出不懂的知识、发现问题,带着知识点和...

来源:2023.04.21

每日热门:市场监管总局:重点打击“刷单炒信”等8类违法行为

记者今天从市场监管总局召开的新闻发布会上获悉,2022年,全国市场监管部门共查办民生领域违法案件20 6...

来源:2023.04.21

新闻快讯

X 关闭

X 关闭

新闻快讯