一、概述
1、大多应用中,可通过消息服务中间件来提升系统异步通信、扩展解耦能力;
2、消息服务中两个重要概念:
消息代理(message broker) 和 目的地(destination)
当消息发送者发送消息以后,将由消息代理接管,消息代理保证消息传递到指定目的地。
3、消息队列主要有两种形式的目的地
(1)队列(queue) :点对点消息通信(point-to-point)
(2)主题(topic) :发布(publish) /订阅(subscribe)消息通信
4、点对点式:
消息发送者发送消息,消息代理将其放入一个队列中,消息接收者从队列中获取消息内容,消息读取后被移出队列
消息只有唯一的发送者和接受者,但并不是说只能有一个接收者
5、发布订阅式:
发送者(发布者)发送消息到主题,多个接收者(订阅者)监听(订阅)这个主题,那么就会在消息到达时同时收到消息
6、JMS(Java Message Service) JAVA消息服务:
基于JVM消息代理的规范。 ActiveMQ、 HornetMQ是JMS实现
7、AMQP(Advanced Message Queuing Protocol)
高级消息队列协议,也是一个消息代理的规范,兼容JMS
RabbitMQ是AMQP的实现
二、消息服务的优点
1、异步处理
2、应用解耦
3、流量削峰
三、JMS 和 AMQP 的对比
四、Spring Boot 对消息服务的支持
1、Spring 支持
(1)spring-jms 提供了对JMS的支持
(2)spring-rabbit 提供了对AMQP的支持
(3)需要 ConnectionFactory 的实现来连接消息代理
(4)提供JmsTemplate、 RabbitTemplate来发送消息
(5)@JmsListener(JMS)、 @RabbitListener(AMQP)注解在方法上监听消息代理发布的消息
(6)@EnableJms、 @EnableRabbit开启支持
2、SpringBoot 自动配置
JmsAutoConfiguration
RabbitAutoConfiguration
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】博客园社区专享云产品让利特惠,阿里云新客6.5折上折
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 没有源码,如何修改代码逻辑?
· 一个奇形怪状的面试题:Bean中的CHM要不要加volatile?
· [.NET]调用本地 Deepseek 模型
· 一个费力不讨好的项目,让我损失了近一半的绩效!
· .NET Core 托管堆内存泄露/CPU异常的常见思路
· 微软正式发布.NET 10 Preview 1:开启下一代开发框架新篇章
· DeepSeek R1 简明指南:架构、训练、本地部署及硬件要求
· 没有源码,如何修改代码逻辑?
· NetPad:一个.NET开源、跨平台的C#编辑器
· 面试官:你是如何进行SQL调优的?