当前位置: 首页 > news >正文

RocketMq方便测试,提供一个controller的接口,支持拉取消息,查看消息内容

通过一个REST API接口动态地启动RocketMQ的消费者,并基于传入的参数(topicNamefilterExpressionconsumerGroupId)决定要监听哪些消息。在Spring Boot项目中,这通常不是推荐的做法,因为消息消费者通常在应用启动时就配置好,并且持续运行,而不是被动态地创建和销毁。

不过,如果确实需要这样做,您可以考虑以下的设计思路:

方案概述

  • 创建一个服务,该服务能够根据传入的参数创建并管理RocketMQ消费者的实例。
  • 设计一个Controller,通过这个Controller接收到的参数来调用上述服务,动态启动消费者。
  • 由于这种设计涉及到动态管理和维护消费者实例,需要注意资源的释放和异常处理。

实现动态消费者管理服务

这个服务将负责根据参数创建和管理RocketMQ消费者实例。

import org.apache.rocketmq.client.apis.ClientException;
import org.apache.rocketmq.client.apis.consumer.PushConsumer;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;import java.util.Map;
import java.util.concurrent.ConcurrentHashMap;@Service
public class DynamicConsumerService {private final Map<String, PushConsumer> consumerMap = new ConcurrentHashMap<>();private final RocketMQConsumerService rocketMQConsumerService;@Autowiredpublic DynamicConsumerService(RocketMQConsumerService rocketMQConsumerService) {this.rocketMQConsumerService = rocketMQConsumerService;}public void startConsumer(String topicName, String filterExpression, String consumerGroupId) throws ClientException {if (consumerMap.containsKey(consumerGroupId)) {// 可能需要考虑停止或重置已存在的消费者return;}PushConsumer consumer = rocketMQConsumerService.createConsumer(topicName, filterExpression, consumerGroupId);consumer.start();consumerMap.put(consumerGroupId, consumer);}// 停止并移除消费者public void stopConsumer(String consumerGroupId) {PushConsumer consumer = consumerMap.remove(consumerGroupId);if (consumer != null) {consumer.shutdown();}}
}

这里createConsumer方法需要在RocketMQConsumerService中实现,返回一个配置好的PushConsumer实例,这个方法的实现与之前的startConsumer方法类似,但不会自动启动消费者。

实现Controller

然后,实现一个Controller来处理REST API请求,根据请求参数动态启动和停止消费者。

import org.apache.rocketmq.client.apis.ClientException;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.*;@RestController
@RequestMapping("/consumer")
public class DynamicConsumerController {private final DynamicConsumerService dynamicConsumerService;@Autowiredpublic DynamicConsumerController(DynamicConsumerService dynamicConsumerService) {this.dynamicConsumerService = dynamicConsumerService;}@PostMapping("/start")public String startConsumer(@RequestParam String topicName,@RequestParam String filterExpression,@RequestParam String consumerGroupId) {try {dynamicConsumerService.startConsumer(topicName, filterExpression, consumerGroupId);return "Consumer started for group: " + consumerGroupId;} catch (ClientException e) {e.printStackTrace();return "Failed to start consumer: " + e.getMessage();}}@PostMapping("/stop")public String stopConsumer(@RequestParam String consumerGroupId) {dynamicConsumerService.stopConsumer(consumerGroupId);return "Consumer stopped for group: " + consumerGroupId;}
}

注意事项

  • 动态创建和管理消费者实例是一个复杂的操作,可能会引入资源泄露、消息丢失等风险,特别是在生产环境中。
  • 确保在消费者不再需要时正确地停止和释放资源。
  • 考虑到消费者的启动和停止可能影响消息的连续性,这种设计更适用于测试环境或具有特定生命周期管理需求的场景。
http://www.lryc.cn/news/325602.html

相关文章:

  • win10 下Msys2编译FFmpeg的流程方法
  • 用 Delphi 做 FTP 服务器以及如何配置防火墙
  • 《SQL必知必会第五版》第十四章(组合查询)挑战题
  • elasticsearch+kibana安装部分问题:
  • Python---常用的web框架
  • Jenkins Docker 部署指南
  • 海外媒体宣发:商务视频推广数字化变革全解析-华媒舍
  • 文件服务: 功能介绍
  • php 快速入门(二)
  • java面试题|(1)多线程如何停止一个线程?
  • 使用阿里CICD流水线打包Java项目到阿里的docker镜像私仓,并自动部署到服务器启动服务
  • Mybatis的核心配置文件
  • 四川易点慧电子商务抖音小店:安全可靠,购物新选择
  • 基于数据沙箱与LLM用例自愈的UI自动化测试平台
  • 面试算法-117-组合总和 III
  • 邮件接口与第三方平台的集成的方式有哪些?
  • qrcode插件-生成二维码
  • 基于JavaSpringmvc+myabtis+html的鲜花商城系统设计和实现
  • [论文笔记] Dual-Channel Span for Aspect Sentiment Triplet Extraction
  • 【C语言】linux内核pci_enable_device函数和_PCI_NOP宏
  • 网络: 套接字
  • Day57-Nginx反向代理与负载均衡初步应用
  • 【PHP】通过PHP开启/暂停Apache、MySQL或其他服务
  • JAVA中spring介绍
  • latex下载与安装
  • JavaParser 手动安装和配置
  • 再次度过我的创作纪念日
  • 云电脑火爆出圈,如何选择和使用?--腾讯云、ToDesk云电脑、青椒云使用评测和攻略
  • webpack原理之-打包流程热更新HMR
  • SELinux详解