环球聚焦:使用 Spring Cloud Bus 在微服务之间传递消息示例
2023-04-23 17:12:53 腾讯云


(资料图片仅供参考)

下面是一个完整的示例,演示如何使用 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

热门推荐

文章排行

  1. 2023-04-23环球聚焦:使用 Spring Cloud Bus 在微服务之间传递消息示例
  2. 2023-04-23山东省首家中学“科学家精神教育基地”成立|环球播报
  3. 2023-04-23【香坊真香 · 书香香坊】书香陪伴 “悦”读美好 | 建筑街道开展“世界读书日”主题活动
  4. 2023-04-23类风湿病人血沉正常了说明什么_类风湿血沉高怎么办|微资讯
  5. 2023-04-23商务部:我国的外贸形势依然复杂严峻
  6. 2023-04-23如何用河石和垫脚石建造人行道 每日讯息
  7. 2023-04-23水涨船高!五一假期多地现酒店刺客:热门城市上调5倍_微头条
  8. 2023-04-23短蕊越橘
  9. 2023-04-23焦点简讯:谷歌裁员万人,高管却集体涨薪?CEO去年获超2亿美元股权激励
  10. 2023-04-23移动wifi是什么原理_移动wifi是什么|天天资讯
  11. 2023-04-232023年南海区桂城街道免费两癌筛查服务指引-焦点速讯
  12. 2023-04-23敲定了!梅西离队倒计时60天,法国媒体终于变脸,网友:早干嘛了 当前快讯
  13. 2023-04-23即时焦点:“小厨师”上线,王贾桥小学学子共享美好“食”光!
  14. 2023-04-23注意!4月26日起,工业北路局部道路将施工
  15. 2023-04-23中国足彩网竞彩23日推荐:赫根重回胜轨|最新消息
  16. 2023-04-23剑指黑八!巴特勒三节30分率队大胜 两度重摔腰臀缠冰袋引关注
  17. 2023-04-23甘肃省数据信息产业发展再添新动能
  18. 2023-04-23安徽省全民健身展示大赛在天长启幕
  19. 2023-04-23首季经济形势|一季度经济形势怎么看?如何扩内需、强信心?——国家发展改革委新闻发布会回应当前经济热点 世界观天下
  20. 2023-04-23漫悦湾物业按5级标准收费 业主反映绿化无人管理垃圾遍地-天天观热点