使用 Spring Cloud Bus 在微服务之间传递消息示例_当前热文

2023-04-23 02:18:08 来源:腾讯云


(资料图)

下面是一个完整的示例,演示如何使用 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 在微服务之间传递消息示例_当前热文

2023-04-23

焦点报道:江上送客白居易_江上赠李龟年

2023-04-23

即时:原单是什么_原单

2023-04-23

一季度规模暴增超900%!冠军基金经理蔡嵩松:人工智能浪潮不可逆 或将成为未来最强产业趋势

2023-04-23

【国际锐评】世界地球日 太平洋不该成为日本排污的垃圾场 环球速递

2023-04-22

环球热点!冻疮止痒的方法有哪些_冻疮止痒的方法

2023-04-22

商务部部长王文涛会见法国工商界代表

2023-04-22

环球微资讯!高龄能不能转行做程序员?

2023-04-22

夏季腌黄瓜怎么做 夏季腌黄瓜怎么做好吃_视焦点讯

2023-04-22

拳皇克拉克 每日焦点

2023-04-22

热门看点:鹿晗演唱会官宣海报解读视频,究竟是怎么一回事?

2023-04-22

周末踏青赏花、大型赛事出行提示 环球速看料

2023-04-22

清风头条丨常德市工信局开展“家庭助廉 团团圆圆”主题活动|热点评

2023-04-22

屯昌县气象台发布雷雨大风黄色预警【Ⅲ级/较重】【2023-04-22】_当前关注

2023-04-22

河南省周口市2023-04-22 14:46发布大风蓝色预警

2023-04-22

玻利维亚总统访问委内瑞拉 两国签署13项合作协议-报道

2023-04-22

济源示范区农科院开展“书香济源”全民阅读暨“4·23”世界读书日“好书推荐”活动-天天实时

2023-04-22

现代简约风格阐述_现代简约风格说明

2023-04-22

全球观焦点:多型海军主战舰艇将面向公众开放 海军将在22个城市举行军营开放活动

2023-04-22

AKIRA回应与林志玲生二胎:不是想生就能生|世界滚动

2023-04-22

怎么做豆沙馅_豆沙馅的做法

2023-04-22

python-异常处理和错误调试-asyncio中的错误调试(二)

2023-04-22

2023年一季度SUV投诉指数排行:车机问题再度暴雷

2023-04-22

焦点信息:多因素激发光伏设备企业扩产热情 TOPCon电池赛道引关注

2023-04-22

天天新动态:没基础的人该怎么学中级会计

2023-04-22

下级对上级的用语_下级对上级请知道怎么说

2023-04-22

连续第二年实施免息 2023年国家助学贷款哪些政策值得关注

2023-04-22

速递!枪手争冠主动变被动!收官赛程难度大 较曼城仍存一优势

2023-04-22

环球下周看点:信息量很大!美股Q1财报季即将迎来最高潮 世界播报

2023-04-22

又懒又想玩户外烧烤?超省心,便携易用一次性烧烤炉满足你!含速燃木炭~

2023-04-22

Copyright ©  2015-2023 今日频道网版权所有  备案号:沪ICP备2023005074号-40   联系邮箱:5 85 59 73 @qq.com