首页 > 编程语言 > 详细

Spring Boot 与消息 (JMS、AMQP、RabbitMQ)

时间:2019-08-05 10:04:08      阅读:98      评论:0      收藏:0      [点我收藏+]

一、概述

  1. 大多应用中,可通过消息服务中间件来提升系统异步通信、扩展解耦能力
  2. 消息服务中两个重要概念:
    1. 消息代理(message broker)和目的地(destination)
    2. 当消息发送者发送消息以后,将由消息代理接管,消息代理保证消息传递到指定目
      的地。

       
  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 的实现

 

JMS & AMQP区别 

 

技术分享图片

 

 

 8. Spring 支持

  • spring-jms提供了JMS的支持
  • spring-rabbit提供了AMQP的支持
  • 需要ConnectionFactory的实现来实现代理
  • 提供JmsTemplate、RabbitTemplate来发送消息
  • @JmsListener(JMS) 、@RabbitListener (AMQP)注解在方法上监听消息代理发布的消息
  • @EnableJms、@EnableRabbit开启支持

9. Spring Boot 配置

  • JmsAutoConfiguration
  • RabbitAutoConfiguration

 

Spring Boot 与消息 (JMS、AMQP、RabbitMQ)

原文:https://www.cnblogs.com/guchunchao/p/11301272.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!