首页 > 其他分享 >springboot消息之JMS&AMQP简介

springboot消息之JMS&AMQP简介

时间:2022-11-30 19:05:21浏览次数:36  
标签:AMQP 队列 JMS 代理 发送者 消息 springboot

  • 大多应用中,可通过消息服务中间件来提升系统异步通信`扩展解耦能力.

       异步处理

springboot消息之JMS&AMQP简介_发送消息

    应用解耦

springboot消息之JMS&AMQP简介_其他_02

    流量削峰

springboot消息之JMS&AMQP简介_发送消息_03

  • 消息服务中有两个重要概念:消息代理和目的地(message broker     destination)

        当消息发送者发送消息以后,将由消息代理接管,消息代理保证消息传递到指定目的地.

  • 消息队列主要有两种形式的目的地
  1. 队列(queue):点对点消息通信
  2. 主题(topic):发布(publish)/订阅(subscribe)消息通信

点对点式:

-消息发送者发送消息,消息代理将其放入一个队列中,消息接收者从队列中获取消息内容,消息读取后被移除队列

-消息只有唯一的发送者和接受者,但并不是说只能有一个接收者

springboot消息之JMS&AMQP简介_其他_04

发布订阅式:

-发送者(发布者)发送消息到主题,多个接收者(订阅者)监听(订阅)这个主题,那么就会在消息到达时同时收到消息

springboot消息之JMS&AMQP简介_其他_05

================================================================================================

  • JMS(Java Message Service) JAVA消息服务:基于JVM消息代理的规范.ActiveMQ`HornetMQ是JMS实现
  • AMQP(Advanced Message Queuing Protocol):高级消息队列协议,也是一个消息代理的规范,兼容JMS.RabbitMQ是AMQP的                                                                    实现.

 

springboot消息之JMS&AMQP简介_发送消息_06

  • spring支持

   - spring-jms提供了对JMS的支持

  - spring-rabbit提供了对AMQP的支持

  - 需要ConnectionFactory的实现来连接消息代理

  - 提供JmsTemplate`RabbitTemplate来发送消息

  - @JmsListener(JMS)`@RabbitListener(AMQP)注解在方法上监听消息代理发布的消息

  - @EnableJms`@EnableRabbit开启支持

  • spring boot自动配置

  - JmsAutoConfiguration

 -  RabbitAutoConfiguration

标签:AMQP,队列,JMS,代理,发送者,消息,springboot
From: https://blog.51cto.com/u_12528551/5900185

相关文章

  • springboot消息之RabbitMQ简介
    RabbitMQ是一个有erlang开发的AMQP(AavancedMessageQueueProtocol)的开源实现核心概念:Publisher :消息的生产者,也是一个向交换器发布消息的客户端应用程序Mess......
  • springboot消息之AmqpAdmin管理组件的使用
    如果在使用@RabbitListener`@EnableRabbit注解之前没有在rabbitmq管理界面上创建exchange和queue,绑定规则,那么就可以在程序中使用AmqpAdmin管理组件测试类中添加,......
  • springboot任务之定时任务
    1-service包下新建ScheduleService类packagecom.example.springboottask.service;importorg.springframework.scheduling.annotation.Scheduled;importorg.springf......
  • springboot检索之springboot整合springdata elasticsearch
    1-修改pom.xml释放出注释<dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-data-elastic......
  • springboot之整合druid&配置数据源监控
    1-mavenrepository中搜索druid,引入druid数据源<!--https://mvnrepository.com/artifact/com.alibaba/druid--><dependency><groupId>com.alibaba</groupId>......
  • 使用向导spring initializer快速创建springboot应用
    1、 选择项目包含的依赖场景,向导会联网创建springboot项目将需要的东西删掉打开pom.xml后可以看到文件内容已自动写入将java目录变为sourcesroot,resources变......
  • springboot配置之外部配置加载顺序
    SpringBoot也可以从以下位置加载配置:1、命令行配置,多个配置用空格分开,--配置项=值java-jarspringboot-02-config-0.0.1-SNAPSHOT.jar--server.port=80872、来自java:comp......
  • springboot配置之配置文件加载位置
    1、springboot启动会扫描以下位置的application.properties或者application.yml文件作为springboot的配置文件,按照优先级从高到低的顺序。所有位置的文件都会被加载,高优先级......
  • springboot配置之@Conditional和自动配置报告
    1、@Conditional派生注解必须@Conditional指定的条件成立,才给容器中添加组件,配置类里面的所有内容才生效@Conditional扩展注解作用(是否满足当前的指定条件)@ConditionalOnJav......
  • springboot日志之日志框架分类和选择
    导入:小张写日志写了一个统一的接口层:日志门面(日志的一个抽象层):logging-abstract.jar给项目中导入具体的日志实现就可以了。以前写的zhanglogging.jar,zhanglogging-good.jar......