【焦点热闻】使用 Spring Cloud Bus 在微服务之间传递消息示例

来源:腾讯云时间:2023-04-21 16:30:29


(资料图)

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

关键词:

相关阅读

推荐阅读

【焦点热闻】使用 Spring Cloud Bus 在微服务之间传递消息示例

【焦点热闻】使用 Spring Cloud Bus 在微服务

下面是一个完整的示例,演示如何使用SpringCloudBus在微服务之间传递消息。该示例包含两个微服务,一个是消更多

2023-04-21 16:30:29
今日天气实况

今日天气实况

今日天气实况更多

2023-04-21 16:10:37
枸杞适合什么季节吃 枸杞哪时候食用比较好

枸杞适合什么季节吃 枸杞哪时候食用比较好

1、枸杞一年四季都可以吃,其中春季最适合吃枸杞。2、春天,万物复苏,人体阳气渐渐升发。枸杞味甘平补,春更多

2023-04-21 15:25:02
新民快评|何必“杠”天气 快讯

新民快评|何必“杠”天气 快讯

凡有歧义的,尽量避用更多

2023-04-21 15:21:55
祝贺!工业互联网标识解析国家顶级节点(重庆)注册量突破200亿

祝贺!工业互联网标识解析国家顶级节点(重庆)注册

4月19日,记者从两江新区获悉,工业互联网国家顶级节点(重庆)(下称:重庆顶级节点)取得突破性进展,累计标更多

2023-04-21 15:30:13
相约安徽·向春而行|纸鸢香草“双微”改造,为游客创造更好的旅游体验 世界观察

相约安徽·向春而行|纸鸢香草“双微”改造,为游

相约安徽·向春而行|纸鸢香草“双微”改造,为游客创造更好的旅游体验更多

2023-04-21 15:23:37
海康威视:面向智能安防场景训练了百亿级参数的大模型

海康威视:面向智能安防场景训练了百亿级参数的大

4月19日电,海康威视在互动平台表示,为了支持大模型的研发,公司自建了业内一流的数据中心,面向智能安防更多

2023-04-21 13:51:51
花生长牙了到底还能不能吃(花生长牙子了能吃吗) 精选

花生长牙了到底还能不能吃(花生长牙子了能吃吗)

1、花生长芽是可以吃的。2、大多数人会认为发芽的花生和发芽的土豆一样,都会产生有毒的物质。实际上不是这更多

2023-04-21 13:44:47
+ 点击查看更多精彩
字节跳动计划投资“大量资金”开发VR领域
    据 Protocol 报道,字节跳动正在认真考虑进入虚拟现实(VR)领域...
任天堂Switch曝光:合作伙伴招聘新游戏机开发工程师
    据外媒报道称,任天堂即将推新一代Switch,其中一个最有力的证据...
途牛发布纳斯达克股价不合规通知函
    4月18日,在途牛收到纳斯达克股价不合规通知函后,途牛方面发布声...
一加新机现身:搭载天玑8100处理器,主打快充和游戏
    今天,一款型号显示为PGKM10的一加新机现身GeekBench,这款新机搭...
紫光国微:预计2022年第一季度净利润同比增长69.9%
    紫光国微发布公告称,预计2022年第一季度归属于上市公司股东的净...
斯坦福大学建造小型太阳能电池板原型
    日前,斯坦福大学的研究人员已经建造了一个小型太阳能电池板原型...
    资讯播报