Rocketmq--案例二

1 用户微服务订阅消息

1 修改 shop-user 模块配置

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xsi:schemaLocation="http://maven.apache.org/POM/4.0.0
http://maven.apache.org/xsd/maven-4.0.0.xsd">
  <parent>
    <artifactId>springcloud-alibaba</artifactId>
    <groupId>com.itheima</groupId>
    <version>1.0-SNAPSHOT</version>
  </parent>
  <modelVersion>4.0.0</modelVersion>
  <artifactId>shop-user</artifactId>
  <dependencies>
    <dependency>
      <groupId>com.itheima</groupId>
      <artifactId>shop-common</artifactId>
      <version>1.0-SNAPSHOT</version>
    </dependency>
    <dependency>
      <groupId>com.alibaba.cloud</groupId>
      <artifactId>spring-cloud-starter-alibaba-nacos-
discovery</artifactId>
    </dependency>
    <dependency>
      <groupId>org.apache.rocketmq</groupId>
      <artifactId>rocketmq-spring-boot-starter</artifactId>
      <version>2.0.2</version>
    </dependency>
    <dependency>
      <groupId>org.apache.rocketmq</groupId>
      <artifactId>rocketmq-client</artifactId>
      <version>4.4.0</version>
    </dependency>
  </dependencies>
</project>

2 修改主类

@SpringBootApplication
@EnableDiscoveryClient
public class UserApplication {
  public static void main(String[] args) {
    SpringApplication.run(UserApplication.class, args);
 }
}

3 修改配置文件

server:
port: 8071
spring:
application:
 name: service-user
datasource:
 driver-class-name: com.mysql.jdbc.Driver
 url: jdbc:mysql:///shop?
serverTimezone=UTC&useUnicode=true&characterEncoding=utf-8&useSSL=true
 username: root
 password: root
jpa:
 properties:
  hibernate:
   hbm2ddl:
    auto: update
   dialect: org.hibernate.dialect.MySQL5InnoDBDialect
cloud:
 nacos:
  discovery:
   server-addr: 127.0.0.1:8848
rocketmq:
name-server: 192.168.109.131:9876

4 编写消息接收服务

package com.itheima.service;
//发送短信的服务
@Slf4j
@Service
@RocketMQMessageListener(consumerGroup = "shop-user", topic = "order-topic")
public class SmsService implements RocketMQListener<Order> {
  @Override
  public void onMessage(Order order) {
    log.info("收到一个订单信息{},接下来发送短信", JSON.toJSONString(order));
 }
}

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
RocketMQ EventBridge 是一个实时事件流转服务,它基于 Apache RocketMQ 构建,用于将数据从一个系统传输到另一个系统。它通过实时数据流转来支持异构系统之间的消息传递,帮助实现系统之间的解耦和消息的高效传递。 一个典型的案例是将电商网站的订单数据传输到数据分析系统。电商网站上每个用户提交的订单都会实时生成一个事件,这个事件包含了订单的相关信息。为了利用这些数据进行用户行为分析、销售分析等业务功能,这些订单事件需要在实时传输过程中被收集,并发送到数据分析系统。 使用 RocketMQ EventBridge,可以通过以下步骤实现这个案例: 1. 在电商网站的订单系统中,配置一个事件生产者将每个订单事件发送到 RocketMQ 的事件主题中。 2. 在数据分析系统中,配置一个事件消费者监听 RocketMQ 的事件主题,并将订单事件数据持久化存储到数据分析系统数据库中。 3. 在数据分析系统中实现对订单事件的解析和处理逻辑,例如提取订单信息,计算销售额,生成报表等等。 通过以上步骤,电商网站的订单数据就能实时传输到数据分析系统,从而帮助实现了用户行为分析、销售分析等业务功能。 RocketMQ EventBridge 的优势在于其可靠性和扩展性。它基于 RocketMQ 提供的高性能和可靠性消息传递机制,能够确保订单事件的可靠传输和实时处理。同时,RocketMQ EventBridge 还支持多个消费者订阅同一个事件主题,以支持多个系统对订单事件的处理。这为系统的扩展和升级提供了更大的灵活性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

chuxuezhe_987

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值