谷粒商城实战笔记-248-商城业务-消息队列-RabbitMQ简介

2024-08-23 19:44

本文主要是介绍谷粒商城实战笔记-248-商城业务-消息队列-RabbitMQ简介,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

  • 一,MQ基础
  • 二,JMS和AMQP
    • 1,二者区别
      • JMS
      • AMQP
      • 联系
      • 区别
    • 2,用法
      • 使用Spring-JMS
      • 使用Spring-Rabbit
      • Spring Boot自动配置

一,MQ基础

  1. 在大多数应用中,可以通过消息服务中间件来提升系统的异步通信能力和扩展解耦能力。

  2. 消息服务中有两个重要概念:消息代理(message broker)和目的地(destination)。当消息发送者发送消息后,消息代理会接管消息,并确保消息传递到指定的目的地。

  3. 消息队列主要有以下两种形式的目的地:

    • 队列(queue):用于点对点消息通信(point-to-point)。
    • 主题(topic):用于发布/订阅消息通信(publish/subscribe)。

根据您提供的文件内容,这里是一段关于消息队列通信模式和相关技术的介绍,具体内容如下:

  1. 点对点式通信

    • 消息发送者发送消息,消息代理将其放入一个队列中。
    • 消息接收者从队列中获取消息内容。
    • 消息读取后被移出队列。
    • 消息只有唯一的发送者和接收者,但并不是说只能有一个接收者。
  2. 发布订阅式通信

    • 发送者(发布者)发送消息到主题。
    • 多个接收者(订阅者)监听(订阅)这个主题。
    • 消息到达时,所有订阅者都会同时收到消息。
  3. JMS(Java Message Service)

    • 基于Java虚拟机(JVM)的消息代理规范。
    • ActiveMQ、HornetMQ等是JMS的实现。
  4. AMQP(Advanced Message Queuing Protocol)

    • 高级消息队列协议,也是一个消息代理的规范。
    • 兼容JMS。
    • RabbitMQ是AMQP的实现。

根据您提供的文件内容,这是一个比较JMS(Java Message Service)和AMQP(Advanced Message Queuing Protocol)的表格。下面是表格的内容和解释:

特征/协议JMS(Java Message Service)AMQP(Advanced Message Queuing Protocol)
定义Java API网络线级协议
跨语言
跨平台
Model提供两种消息模型: (1) Peer-2-Peer (2) Pub/sub提供了五种消息模型: (1) direct exchange (2) fanout exchange (3) topic exchange (4) headers exchange (5) system exchange 本质来讲,后四种和JMS的pub/sub模型没有太大差别, 仅是在路由机制上做了更详细的划分;
支持消息类型多种消息类型: TextMessage, MapMessage, BytesMessage, StreamMessage, ObjectMessage, Message(只有消息头和属性)byte[] 当实际应用时,有复杂的消息,可以将消息序列化后发送。
综合评价JMS定义了JAVA API层面的标准;在java体系中, 多个client均可以通过JMS进行交互,不需要应用修改代码,但是其对跨平台的支持较差;AMQP定义了wire-level层的协议标准;天然具有跨平台、跨语言特性。

根据您提供的文件内容,这是一段关于Spring框架对消息队列(MQ)的支持以及市场上常见的消息队列产品的介绍。以下是具体内容:

  1. Spring支持
  • spring-jms 提供了对 JMS 的支持。
  • spring-rabbit 提供了对 AMQP 的支持。
  • 需要 ConnectionFactory 的实现来连接消息代理。
  • 提供 JmsTemplateRabbitTemplate 来发送消息。
  • 使用 @JmsListener(JMS)、@RabbitListener(AMQP)注解在方法上监听消息代理发布的消息。
  • 使用 @EnableJms@EnableRabbit 开启对 JMS 和 AMQP 的支持。
  1. Spring Boot自动配置
  • JmsAutoConfiguration:Spring Boot 自动配置 JMS。
  • RabbitAutoConfiguration:Spring Boot 自动配置 RabbitMQ。
  1. 市面的MQ产品
  • 市面上常见的消息队列产品包括:
    • ActiveMQ
    • RabbitMQ
    • RocketMQ
    • Kafka

二,JMS和AMQP

1,二者区别

JMS(Java Message Service)和AMQP(Advanced Message Queuing Protocol)。

JMS

想象一下,你正在经营一家大型连锁咖啡店,你需要一个系统来管理来自各个门店的订单请求。在这个场景中,JMS就像是这家咖啡店内部使用的通信规范或规则手册,它规定了各个门店应该如何发送订单请求以及总部应该如何接收这些请求。

  • 角色

    • 生产者:相当于门店发送订单请求。
    • 消费者:相当于总部接收并处理这些订单请求。
    • 消息中间件:相当于咖啡店内部的消息传递系统,比如RabbitMQ、ActiveMQ等。
  • 特点

    • 平台独立性:就像在不同地区的门店都可以按照这套规则来发送订单。
    • 抽象层:JMS提供了一组API,允许开发者以统一的方式编写消息传递的应用程序,而不必关心底层的消息中间件的具体实现。

AMQP

现在,想象你的咖啡店决定扩展业务,不仅要在本地使用这套系统,还要与其他合作伙伴共享这套订单管理系统。这时候,你需要一套更加开放的标准来保证不同系统之间能够顺畅沟通。AMQP就是这样一个标准,它是一种开放的协议,定义了消息如何在网络上传输。

  • 角色

    • 生产者:依然相当于门店发送订单请求。
    • 消费者:相当于总部或其他合作伙伴接收并处理这些订单请求。
    • 消息中间件:相当于实现了AMQP协议的消息队列服务,比如RabbitMQ就是一个支持AMQP的中间件。
  • 特点

    • 协议规范:AMQP定义了消息在网络上传输的具体格式和流程,确保不同的系统之间可以相互通信。
    • 开放性和互操作性:就像你的咖啡店不仅可以与本地门店交流,还可以与其他城市的合作伙伴甚至国际上的合作伙伴交流。

联系

  • 目的相同:两者都是为了实现分布式系统之间的消息传递。
  • 依赖于消息中间件:都需要有一个消息中间件来作为消息的传递枢纽。
  • 实现消息传递:都可以实现消息的发布/订阅模式或者点对点模式。

区别

  • 适用范围

    • JMS:主要用于Java环境,提供了Java API,因此更适合Java应用程序。
    • AMQP:是一个开放的协议,可以跨语言、跨平台使用,适用于更广泛的开发环境。
  • 灵活性和扩展性

    • JMS:提供了一套固定的API接口,虽然简化了开发过程,但可能限制了一些高级功能的实现。
    • AMQP:作为一个开放的协议,支持更多的特性和定制选项,可以更好地满足复杂需求。

2,用法

以下是一些示例代码,说明如何在Spring框架中使用spring-jmsspring-rabbit来支持JMS和AMQP消息队列,以及如何使用Spring Boot的自动配置功能。

使用Spring-JMS

  1. 配置ConnectionFactory:首先,您需要配置一个ConnectionFactory,这通常在XML配置文件或Java配置类中完成。
@Bean
public ConnectionFactory connectionFactory() {// 配置ConnectionFactory,例如使用ActiveMQreturn new ActiveMQConnectionFactory(url, username, password);
}
  1. 配置JmsTemplate:使用ConnectionFactory创建JmsTemplate
@Bean
public JmsTemplate jmsTemplate(ConnectionFactory connectionFactory) {JmsTemplate template = new JmsTemplate(connectionFactory);// 其他配置...return template;
}
  1. 定义消息监听器:使用@JmsListener注解定义监听特定目的地的方法。
@Component
public class MyMessageListener {@JmsListener(destination = "myQueue")public void receiveMessage(String message) {// 处理接收到的消息}
}
  1. 开启JMS支持:在配置类上使用@EnableJms注解。
@Configuration
@EnableJms
public class JmsConfig {// 配置类内容
}

使用Spring-Rabbit

  1. 配置ConnectionFactory:与JMS类似,首先配置ConnectionFactory
@Bean
public ConnectionFactory rabbitConnectionFactory() {// 配置RabbitMQ的ConnectionFactoryreturn new CachingConnectionFactory(host, port, username, password);
}
  1. 配置RabbitTemplate:使用ConnectionFactory创建RabbitTemplate
@Bean
public RabbitTemplate rabbitTemplate(ConnectionFactory connectionFactory) {RabbitTemplate template = new RabbitTemplate(connectionFactory);// 其他配置...return template;
}
  1. 定义消息监听器:使用@RabbitListener注解定义监听特定队列的方法。
@Component
public class MyRabbitListener {@RabbitListener(queues = "myQueue")public void handleMessage(String message) {// 处理接收到的消息}
}
  1. 开启RabbitMQ支持:在配置类上使用@EnableRabbit注解。
@Configuration
@EnableRabbit
public class RabbitConfig {// 配置类内容
}

Spring Boot自动配置

Spring Boot提供了自动配置功能,可以简化上述配置步骤。如果您使用的是Spring Boot,通常只需要添加相应的依赖并进行少量配置即可。

  1. 添加依赖:在pom.xmlbuild.gradle中添加Spring-JMS或Spring-Rabbit的依赖。

  2. 配置application.properties或application.yml:配置连接信息和目的地名称。

# JMS配置示例
spring.jms.activemq.broker-url=tcp://localhost:61616
spring.jms.queue-names=myQueue# RabbitMQ配置示例
spring.rabbitmq.host=localhost
spring.rabbitmq.port=5672
spring.rabbitmq.queue=myQueue
  1. 使用自动配置:Spring Boot会自动配置ConnectionFactoryJmsTemplateRabbitTemplate等组件,并注册相应的监听器容器。

这篇关于谷粒商城实战笔记-248-商城业务-消息队列-RabbitMQ简介的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1100322

相关文章

网页解析 lxml 库--实战

lxml库使用流程 lxml 是 Python 的第三方解析库,完全使用 Python 语言编写,它对 XPath表达式提供了良好的支 持,因此能够了高效地解析 HTML/XML 文档。本节讲解如何通过 lxml 库解析 HTML 文档。 pip install lxml lxm| 库提供了一个 etree 模块,该模块专门用来解析 HTML/XML 文档,下面来介绍一下 lxml 库

hdu1180(广搜+优先队列)

此题要求最少到达目标点T的最短时间,所以我选择了广度优先搜索,并且要用到优先队列。 另外此题注意点较多,比如说可以在某个点停留,我wa了好多两次,就是因为忽略了这一点,然后参考了大神的思想,然后经过反复修改才AC的 这是我的代码 #include<iostream>#include<algorithm>#include<string>#include<stack>#include<

性能分析之MySQL索引实战案例

文章目录 一、前言二、准备三、MySQL索引优化四、MySQL 索引知识回顾五、总结 一、前言 在上一讲性能工具之 JProfiler 简单登录案例分析实战中已经发现SQL没有建立索引问题,本文将一起从代码层去分析为什么没有建立索引? 开源ERP项目地址:https://gitee.com/jishenghua/JSH_ERP 二、准备 打开IDEA找到登录请求资源路径位置

C#实战|大乐透选号器[6]:实现实时显示已选择的红蓝球数量

哈喽,你好啊,我是雷工。 关于大乐透选号器在前面已经记录了5篇笔记,这是第6篇; 接下来实现实时显示当前选中红球数量,蓝球数量; 以下为练习笔记。 01 效果演示 当选择和取消选择红球或蓝球时,在对应的位置显示实时已选择的红球、蓝球的数量; 02 标签名称 分别设置Label标签名称为:lblRedCount、lblBlueCount

业务中14个需要进行A/B测试的时刻[信息图]

在本指南中,我们将全面了解有关 A/B测试 的所有内容。 我们将介绍不同类型的A/B测试,如何有效地规划和启动测试,如何评估测试是否成功,您应该关注哪些指标,多年来我们发现的常见错误等等。 什么是A/B测试? A/B测试(有时称为“分割测试”)是一种实验类型,其中您创建两种或多种内容变体——如登录页面、电子邮件或广告——并将它们显示给不同的受众群体,以查看哪一种效果最好。 本质上,A/B测

ASIO网络调试助手之一:简介

多年前,写过几篇《Boost.Asio C++网络编程》的学习文章,一直没机会实践。最近项目中用到了Asio,于是抽空写了个网络调试助手。 开发环境: Win10 Qt5.12.6 + Asio(standalone) + spdlog 支持协议: UDP + TCP Client + TCP Server 独立的Asio(http://www.think-async.com)只包含了头文件,不依

【学习笔记】 陈强-机器学习-Python-Ch15 人工神经网络(1)sklearn

系列文章目录 监督学习:参数方法 【学习笔记】 陈强-机器学习-Python-Ch4 线性回归 【学习笔记】 陈强-机器学习-Python-Ch5 逻辑回归 【课后题练习】 陈强-机器学习-Python-Ch5 逻辑回归(SAheart.csv) 【学习笔记】 陈强-机器学习-Python-Ch6 多项逻辑回归 【学习笔记 及 课后题练习】 陈强-机器学习-Python-Ch7 判别分析 【学

系统架构师考试学习笔记第三篇——架构设计高级知识(20)通信系统架构设计理论与实践

本章知识考点:         第20课时主要学习通信系统架构设计的理论和工作中的实践。根据新版考试大纲,本课时知识点会涉及案例分析题(25分),而在历年考试中,案例题对该部分内容的考查并不多,虽在综合知识选择题目中经常考查,但分值也不高。本课时内容侧重于对知识点的记忆和理解,按照以往的出题规律,通信系统架构设计基础知识点多来源于教材内的基础网络设备、网络架构和教材外最新时事热点技术。本课时知识

poj 3190 优先队列+贪心

题意: 有n头牛,分别给他们挤奶的时间。 然后每头牛挤奶的时候都要在一个stall里面,并且每个stall每次只能占用一头牛。 问最少需要多少个stall,并输出每头牛所在的stall。 e.g 样例: INPUT: 51 102 43 65 84 7 OUTPUT: 412324 HINT: Explanation of the s

poj 2431 poj 3253 优先队列的运用

poj 2431: 题意: 一条路起点为0, 终点为l。 卡车初始时在0点,并且有p升油,假设油箱无限大。 给n个加油站,每个加油站距离终点 l 距离为 x[i],可以加的油量为fuel[i]。 问最少加几次油可以到达终点,若不能到达,输出-1。 解析: 《挑战程序设计竞赛》: “在卡车开往终点的途中,只有在加油站才可以加油。但是,如果认为“在到达加油站i时,就获得了一