关于异步消息队列的详细解析,涵盖JMS模式对比、常用组件分析、Spring Boot集成示例及总结

news2025/4/18 12:29:15

以下是关于异步消息队列的详细解析,涵盖JMS模式对比、常用组件分析、Spring Boot集成示例及总结:


一、异步消息核心概念与JMS模式对比

1. 异步消息核心组件
组件作用
生产者发送消息到消息代理(如RabbitMQ、Kafka)。
消息代理中间件(如RabbitMQ、Kafka),负责消息存储、路由和分发。
消费者接收并处理消息。
队列/主题消息的容器,队列用于P2P,主题用于Pub/Sub。
消息需要传输的数据单元,可包含文本、JSON、二进制等。

2. JMS的两种消息模式
模式点对点(P2P)发布/订阅(Pub/Sub)
消息容器队列(Queue)主题(Topic)
消息处理每条消息被一个消费者处理每条消息被所有订阅者接收
消息存活消息被消费后从队列中删除消息存活时间短(通常由代理配置)
消费者角色消费者竞争消费消息消费者订阅主题,独立接收消息
适用场景任务分配(如订单处理)实时通知(如股票价格更新)

3. 常用消息队列对比

组件类型协议适用场景特点
ActiveMQJMS兼容OpenWire传统企业级应用开源、支持P2P和Pub/Sub,但性能较RabbitMQ低。
RabbitMQAMQPAMQP复杂路由需求(如死信队列)支持多种协议、插件丰富、轻量级、适合中小型系统。
Kafka分布式流处理Kafka Protocol高吞吐场景(如日志收集)高吞吐、持久化、支持水平扩展,但配置复杂。

二、Spring Boot集成RabbitMQ示例

1. 依赖配置
<!-- pom.xml -->
<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-amqp</artifactId>
</dependency>
2. 配置文件(application.yml)
spring:
  rabbitmq:
    host: localhost
    port: 5672
    username: guest
    password: guest
3. 生产者服务
@Service
public class MessageProducer {

    @Autowired
    private RabbitTemplate rabbitTemplate;

    // 发送到队列(P2P)
    public void sendToQueue(String message) {
        rabbitTemplate.convertAndSend("order.queue", message);
    }

    // 发送到主题(Pub/Sub)
    public void sendToTopic(String message) {
        rabbitTemplate.convertAndSend("stock.topic", "stock.routing.key", message);
    }
}
4. 消费者服务
@Component
public class MessageConsumer {

    // 接收队列消息
    @RabbitListener(queues = "order.queue")
    public void handleOrderMessage(String message) {
        System.out.println("Received order message: " + message);
    }

    // 接收主题消息
    @RabbitListener(bindings = @QueueBinding(
        value = @Queue,
        exchange = @Exchange(name = "stock.topic", type = "topic"),
        key = "stock.routing.key"
    ))
    public void handleStockMessage(String message) {
        System.out.println("Received stock update: " + message);
    }
}
5. 控制器示例
@RestController
public class MessageController {

    @Autowired
    private MessageProducer producer;

    @PostMapping("/send/order")
    public String sendOrderMessage(@RequestParam String message) {
        producer.sendToQueue(message);
        return "Message sent to order queue";
    }

    @PostMapping("/send/stock")
    public String sendStockMessage(@RequestParam String message) {
        producer.sendToTopic(message);
        return "Message sent to stock topic";
    }
}

三、Spring Cloud集成Kafka示例

1. 依赖配置
<!-- pom.xml -->
<dependency>
    <groupId>org.springframework.kafka</groupId>
    <artifactId>spring-kafka</artifactId>
</dependency>
2. 配置文件(application.yml)
spring:
  kafka:
    bootstrap-servers: localhost:9092
    producer:
      key-serializer: org.apache.kafka.common.serialization.StringSerializer
      value-serializer: org.apache.kafka.common.serialization.StringSerializer
    consumer:
      group-id: my-group
      auto-offset-reset: earliest
      key-deserializer: org.apache.kafka.common.serialization.StringDeserializer
      value-deserializer: org.apache.kafka.common.serialization.StringDeserializer
3. 生产者服务
@Service
public class KafkaProducer {

    @Autowired
    private KafkaTemplate<String, String> kafkaTemplate;

    public void send(String topic, String message) {
        kafkaTemplate.send(topic, message);
    }
}
4. 消费者服务
@Component
public class KafkaConsumer {

    @KafkaListener(topics = "my-topic")
    public void listen(String message) {
        System.out.println("Received message: " + message);
    }
}
5. 控制器示例
@RestController
public class KafkaController {

    @Autowired
    private KafkaProducer producer;

    @PostMapping("/send/kafka")
    public String sendMessage(@RequestParam String message) {
        producer.send("my-topic", message);
        return "Message sent to Kafka topic";
    }
}

四、总结与选择建议

场景推荐组件原因
复杂路由需求RabbitMQ支持AMQP协议,插件丰富,适合死信队列、延迟队列等高级功能。
高吞吐/大数据量Kafka毫秒级延迟、水平扩展能力强,适合日志收集、流处理。
传统企业级应用ActiveMQ兼容JMS规范,适合遗留系统集成。

关键代码总结

  1. RabbitMQ核心注解

    • @RabbitListener:标注消费者方法。
    • RabbitTemplate:发送消息的核心类。
  2. Kafka核心注解

    • @KafkaListener:标注消费者方法。
    • KafkaTemplate:发送消息的核心类。
  3. Spring配置

    • 通过application.yml配置连接信息。
    • 使用@EnableRabbit(RabbitMQ)或@EnableKafka(Kafka)启用支持。

注意事项

  • 消息可靠性:确保消息持久化、消费者确认机制(ACK)。
  • 性能优化:合理设置线程池、批量发送消息。
  • 监控与告警:集成Prometheus/Grafana监控队列状态。

通过上述配置和代码示例,可以快速实现Spring Boot应用中的异步消息处理,提升系统解耦和扩展性。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2335554.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【Docker】离线安装Docker

背景 离线安装Docker的必要性&#xff0c;第一&#xff0c;在目前数据安全升级的情况下&#xff0c;很多外网已经基本不好访问了。第二&#xff0c;如果公司有对外部署的需求&#xff0c;那么难免会存在对方只有内网的情况&#xff0c;那么我们就要做到学会离线安装。 下载安…

极简cnn-based手写数字识别程序

1.先看看识别效果&#xff1a; 这个程序识别的是0~9的一组手写数字&#xff0c;这是最终的识别效果&#xff0c;为1&#xff0c;代表识别成功&#xff0c;0为失败。 然后数据源是&#xff1a;ds deeplake.load(hub://activeloop/optical-handwritten-digits-train)里面是一组…

C++核心机制-this 指针传递与内存布局分析

示例代码 #include<iostream> using namespace std;class A { public:int a;A() {printf("A:A()的this指针&#xff1a;%p!\n", this);}void funcA() {printf("A:funcA()的this指针&#xff1a;%p!\n", this);} };class B { public:int b;B() {prin…

vue3 history路由模式刷新页面报错问题解决

在使用history路由模式时刷新网页提示404错误&#xff0c;这是改怎么办呢。 官方解决办法 https://router.vuejs.org/zh/guide/essentials/history-mode.html

PHP爬虫教程:使用cURL和Simple HTML DOM Parser

一个关于如何使用PHP的cURL和HTML解析器来创建爬虫的教程&#xff0c;特别是处理代理信息的部分。首先&#xff0c;我需要确定用户的需求是什么。可能他们想从某个网站抓取数据&#xff0c;但遇到了反爬措施&#xff0c;需要使用代理来避免被封IP。不过用户没有提到具体的目标网…

3.2.2.1 Spring Boot配置静态资源映射

在Spring Boot中配置静态资源映射&#xff0c;可以通过默认路径或自定义配置实现。默认情况下&#xff0c;Spring Boot会在classpath:/static/等目录下查找静态资源。若需自定义映射&#xff0c;可通过实现WebMvcConfigurer接口的addResourceHandlers方法或在全局配置文件中设置…

# 更换手机热点后secureCRT无法连接centOS7系统

更换手机热点后secureCRT无法连接centOS7系统 一、问题描述 某些情况下&#xff0c;我们可能使用手机共享热点而给电脑联网。本来用一个手机热点共享网络时&#xff0c;SecureCRT可以正常连接到CentOS 7虚拟机&#xff0c;当更换一个手机热点时&#xff0c;突然发现SecureCR…

jupyter notebook 无法启动- markupsafe导致

一、运行jupyter notebook和Spyder报错&#xff1a;(已安装了Anaconda&#xff0c;以前可打开) 1.背景&#xff1a;为了部署机器学习模型&#xff0c;按教程直接安装了flask 和markupsafe&#xff0c;导致jupyter notebook&#xff0c;Spyder 打不开。 pip install flas…

CTF web入门之命令执行 完整版

web29 文件名过滤 由于flag被过滤,需要进行文件名绕过,有以下几种方法: 1.通配符绕过 fla?.* 2.反斜杠绕过 fl\ag.php 3.双引号绕过 fl’‘ag’.php 还有特殊变量$1、内联执行等 此外 读取文件利用cat函数,输出利用system、passthru 、echo echo `nl flag.php`; ec…

Java 开发工具:从 Eclipse 到 IntelliJ IDEA 的进化之路

Java 开发工具&#xff1a;从 Eclipse 到 IntelliJ IDEA 的进化之路 在 Java 开发的历史长河中&#xff0c;开发工具的演变不仅改变了程序员的编码方式&#xff0c;也深刻影响了整个行业的开发效率和代码质量。从 Eclipse 到 IntelliJ IDEA&#xff0c;这不仅是工具的更替&…

GPT - 2 文本生成任务全流程

数据集下载 数据预处理 import json import pandas as pdall_data []with open("part-00018.jsonl",encoding"utf-8") as f:for line in f.readlines():data json.loads(line)all_data.append(data["text"])batch_size 10000for i in ran…

红宝书第四十三讲:基于资料的数据可视化工具简单介绍:D3.js 与 Canvas绘图

红宝书第四十三讲&#xff1a;基于资料的数据可视化工具简单介绍&#xff1a;D3.js 与 Canvas绘图12 资料取自《JavaScript高级程序设计&#xff08;第5版&#xff09;》。 查看总目录&#xff1a;红宝书学习大纲 一、D3.js&#xff1a;数据驱动文档的王者 1 核心特性&#x…

深入理解 Vue 的数据代理机制

何为数据代理&#xff1f; 通过一个对象代理对另一个对象中的属性的操作&#xff08;读/写&#xff09;&#xff0c;就是数据代理。 要搞懂Vue数据代理这个概念&#xff0c;那我们就要从Object.defineProperty()入手 Object.defineProperty()是Vue中比较底层的一个方法&…

Java excel导入/导出导致内存溢出问题,以及解决方案

excel导入/导出导致内存溢出问题&#xff0c;以及解决方案 1、内存溢出问题导入功能重新修正&#xff0c;采用SAX的流式解析数据。并结合业务流程。导出功能&#xff1a;由于精细化了业务流程&#xff0c;导致比较代码比较冗杂&#xff0c;就只放出最简单的案例。 1、内存溢出问…

10 个最新 CSS 功能已在所有主流浏览器中得到支持

前言 CSS 不断发展&#xff0c;新功能使我们的工作更快、更简洁、更强大。得益于最新的浏览器改进&#xff08;Baseline 2024&#xff09;&#xff0c;许多新功能现在可在所有主要引擎上使用。以下是您可以立即开始使用的10 CSS新功能。 1. Scrollbar-Gutter 和 Scrollbar-Co…

思科模拟器的单臂路由,交换机,路由器,路由器只要两个端口的话,连接三台电脑该怎么办,划分VLAN,dotlq协议

单臂路由 1. 需求&#xff1a;让三台电脑互通 2. 在二层交换机划分vlan&#xff0c;并加入&#xff1b; 3. 将连接二层交换机和路由器的端口f0/4改为trunk模式 4. 路由器&#xff1a;进入连接路由器的f0/0端口将端口开启 5. 进入每个vlan设dotlq协议并设网络IP&#xff08…

14 nginx 的 dns 缓存的流程

前言 这个是 2020年11月 记录的这个关于 nginx 的 dns 缓存的问题 docker 环境下面 前端A连到后端B 前端B连到后端A 最近从草稿箱发布这个问题的时候, 重新看了一下 发现该问题的记录中仅仅是 定位到了 nginx 这边的 dns 缓存的问题, 但是 并没有到细节, 没有到 具体的 n种…

实战教程:使用JetBrians Rider快速部署与调试PS5和Xbox上的UE项目

面向主机游戏开发者的重大新闻&#xff01;在2024.3版本中&#xff0c;JetBrains Rider 增加了对 PlayStation5 和 Xbox 游戏主机的支持&#xff0c;您可以直接在您喜欢的游戏主机上构建、部署和调试 Unreal Engine 和自定义游戏引擎。 JetBrains Rider现在支持主机游戏开发&am…

专题十五:动态路由——BGP

一、BGP的基本概念 BGP&#xff08;Border Gateway Protocol&#xff0c;边界网关协议&#xff09;是一种用于在不同自治系统&#xff08;AS&#xff09;之间交换路由信息的外部网关协议&#xff08;EGP&#xff09;。通过TCP179端口建立连接。目前采用BGP4版本&#xff0c;IP…

hive数仓要点总结

1.OLTP和OLAP区别 OLTP&#xff08;On-Line Transaction Processing&#xff09;即联机事务处理&#xff0c;也称为面向交易的处理过程&#xff0c;其基本特征是前台接收的用户数据可以立即传送到计算中心进行处理&#xff0c;并在很短的时间内给出处理结果&#xff0c;是对用…