【SpringBoot】【分布式事务】【RocketMQ】整合消息队列,从单机到集群

分布式事务基本概念:   https://blog.csdn.net/Timeguys/article/details/107646845

 

 

一、使用:

一、引入依赖:

 <dependency>
            <groupId>org.apache.rocketmq</groupId>
            <artifactId>rocketmq-spring-boot-starter</artifactId>
            <version>2.0.3</version>
        </dependency>

二、举例:生产者创建订单---->生产者发送消息----->MQ服务接受消息----->消费者监听消息并减库存

【生产者】:

application.yml

rocketmq:
  name-server: 192.168.85.128:9876 # rocketMQ地址
  producer:
    group: producer-group-test  # 生产者的组名需要和消费者监听consumerGroup一致

业务代码:

@Service
public class OrderServiceImpl extends ServiceImpl<OrderMapper, TbOrder> implements OrderService {

    @Resource
    private RocketMQTemplate rocketMQTemplate;

    @Override
    public void create() {
        //创建订单--> 发送消息 --> 消息发送成功后调用本地事务提交 -->
        TbOrder order = new TbOrder();
        order.setCount(10);
        order.setMoney(BigDecimal.valueOf(10));
        order.setProductId(1L);
        order.setStatus(1);
        order.setUserId(1L);
        sendMsg(order);
    }
    @Override
    public void sendMsg(TbOrder order){
        /**
         * String txProducerGroup, 生产者分组
         * String destination,  topic
         *  Message<?> message, 消息
         *  Object arg  消息参数
         */
        Message<String> build = MessageBuilder.withPayload(JSONObject.toJSONString(order)).build();
        rocketMQTemplate.sendMessageInTransaction("tx-producer-group","txmsg-topic",build , null);
    }
}

创建  ProducerTxmsgListener 并实现 RocketMQLocalTransactionListener:

@Component
// txProducerGroup 的值和发送事务消息指定的 txProducerGroup 相同 
@RocketMQTransactionListener(txProducerGroup = "txmsg-producer-group")
public class ProducerTxmsgListener implements RocketMQLocalTransactionListener {
    @Resource
    private OrderService orderService;

    /**
     * @Description: 执行本地事务提交
     */
    @Override
    @Transactional
    public RocketMQLocalTransactionState executeLocalTransaction(Message message, Object o) {
        try {
            TbOrder tbOrder = JSONObject.parseObject(message.getPayload().toString(), TbOrder.class);
            System.out.println(tbOrder);
            orderService.save(tbOrder);
            return RocketMQLocalTransactionState.COMMIT; //变更消息状态为:可消费
        }catch (Exception e){
            return RocketMQLocalTransactionState.ROLLBACK; //本地事务执行异常,将消息遗弃
        }
    }

    /**
     * @Description: 检查本地事务是否执行成功
     */
    @Override
    public RocketMQLocalTransactionState checkLocalTransaction(Message message) {

        TbOrder tbOrder = JSONObject.parseObject(message.getPayload().toString(), TbOrder.class);
        TbOrder order = orderService.getById(tbOrder.getId());
        // 不为null 则表示执行成功
        if (order != null){
            return RocketMQLocalTransactionState.COMMIT; //变更消息状态为:可消费
        }
        // 执行本地事务发生问题或还没执行完成, UNKNOWN 表示会继续回查
        return RocketMQLocalTransactionState.UNKNOWN;
    }
}

【消费者】:

application.yml

rocketmq:
  name-server: 127.0.0.1:9876 # rocketMQ地址
  producer:
    group: producer-test-group  # 生产者的组名需要和消费者监听consumerGroup一致

创建MyListener 并实现 RocketMQListener 接口:

// topic 对应生产者发消息是的topic
@RocketMQMessageListener(topic = "test-topic" , consumerGroup = "consumer-group")
public class MyListener implements RocketMQListener<String> {

    @Override
    public void onMessage(String message) {
        //执行 减库存业务  如果发生异常,则消息会隔段时间再次消费 
        System.out.println(message);
    }
}

 

原理图:

 

 

 

  

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值