中间件-RabbitMQ

news2025/1/12 21:05:36

文章目录

  • 1.什么是MQ
    • 1.1 特点
    • 1.2 MQ产品分类
  • 2.RabbitMQ
    • 2.1.RabbitMQ介绍
    • 2.2.使用Docker安装RabbitMQ
  • 3.SpringBoot中使用RabbitMQ
    • 3.1.SpringAMQP
    • 3.2使用步骤

1.什么是MQ

RabbitMQ官方文档

消息队列(Message Queue,简称MQ):是在消息的传输过程中保存消息的容器。用于分布式系统之间进行异步通信

1.1 特点

解耦

在这里插入图片描述

异步

在这里插入图片描述

削峰

在这里插入图片描述

1.2 MQ产品分类

RabbitMQActiveMQRocketMQKafka
公司社区RabbitApacheApache 阿里Apache
开发语言ErlangJavaJavaScala&Java
协议AMQPOpenWire、AUTO、Stomp、MQTT自定义自定义
单机吞吐量万级万级(最差)十万级十万级
消息延迟微妙级毫秒级毫秒级毫秒以内
特性并发能力很强,延时很低老牌产品,文档较多MQ功能比较完备,扩展性佳只支持主要的MQ功能,毕竟是为大数据领域准备的。
  1. 中小型软件公司,建议选 RabbitMQ. 一方面,erlang 语言天生具备高并发的特性,RabbitMQ 的社区十分活跃,可以解决开发过程中遇到的bug,这点对于中小型公司来说十分重要。不考虑 RocketMQ 和 kafka 的原因是中小型软件公司不如互联网公司,数据量没那么大,选消息中间件,应首选功能比较完备的,所以 kafka 和 RocketMQ 排除。
  2. 大型软件公司,根据具体使用在 RocketMQ 和 kafka 之间二选一。一方面,大型软件公司,具备足够的资金搭建分布式环境,也具备足够大的数据量。针对 RocketMQ,大型软件公司也可以抽出人手对 RocketMQ 进行定制化开发,毕竟国内有能力改JAVA源码的人,还是相当多的。至于 kafka ,根据业务场景选择,如果有日志采集功能,肯定是首选 kafka 了。

2.RabbitMQ

2.1.RabbitMQ介绍

RabbitMQ是实现了高级消息队列协议(AMQP)的开源消息代理软件(亦称面向消息的中间件)。

2007年,Rabbit 技术公司基于 AMQP 标准采用 Erlang 语言开发的 RabbitMQ1.0 发布。

AMQP,即 Advanced Message Queuing Protocol(高级消息队列协议),是一个网络协议,是应用层协议的一个开放标准,为面向消息的中间件设计。基于此协议的客户端与消息中间件可传递消息,并不受客户端/中间件不同产品,不同的开发语言等条件的限制。2006年,AMQP规范发布。类似HTTP。
在这里插入图片描述

  • 生产者(Publisher):发送消息的应用
  • 消费者(Consumer):接收消息的应用
  • 队列(Queue):存储消息的缓存,一个队列queue存多条消息
  • 消息(Message):由生产者通过RabbitMQ发送给消费者的信息,消息存储在消息队列queue中
  • 连接(Connection):连接RabbitMQ和应用服务器的TCP连接
  • 通道(Channel):连接里的一个虚拟通道。发送或接收消息都是通过通道进行的
  • 交换机(Exchange):生产者发送消息先发送到交换机,再由交换机发送到队列中并保存在队列里。(相当于中转站)
  • 绑定(Binding):绑定是队列和交换机的一个关联连接。一个绑定就是基于路由键将交换器和消息队列连接起来的路由规则,所以可以将交换器理解成一个由绑定构成的路由表。
  • 路由键(Routing key):路由键是供交换机查看并根据键来决定如何分发消息到队列的一个键。(可以说是消息的目的地址)
  • 用户(Users):在RabbitMQ中,可以通过指定的用户名和密码进来连接。每个用户可以分配不同的权限,例如读权限,写权限以及在实例里进行配置的权限。
  • 服务器实体(Broker):表示消息队列服务器实体。
  • 虚拟主机(Virtual Host):虚拟主机,表示一批交换器、消息队列和相关对象。虚拟主机是共享相同的身份认证和加密环境的独立服务器域。每个 vhost 本质上就是一个 mini 版的 RabbitMQ 服务器,拥有自己的队列、交换器、绑定和权限机制。vhost 是 AMQP 概念的基础,必须在连接时指定,RabbitMQ 默认的 vhost 是 / 。

2.2.使用Docker安装RabbitMQ

# 1.拉取RabbitMQ镜像
~]$ docker pull rabbitmq:3.10.6
# 2.创建容器并运行
~]$ docker run \
 -e RABBITMQ_DEFAULT_USER=rabbitmq \ #登录用户名
 -e RABBITMQ_DEFAULT_PASS=123456 \  #登录密码
 --name rabbitmq \
 --hostname rabbitmq \
 --restart=always \		#Docker启动容器启动
 -p 15672:15672 \			
 -p 5672:5672 \
 -d \
 rabbitmq:3.10.6
 # 3.进入容器内部
~]$ docker exec -it rabbitmq /bin/bash
rabbitmq-plugins enable rabbitmq_management  # 开启WEB界面管理插件

#修改 management_agent.disable_metrics_collector = false
cd /etc/rabbitmq/conf.d/
echo management_agent.disable_metrics_collector = false > management_agent.disable_metrics_collector.conf
 
#退出容器
exit

#重启rabbitmq容器
~]$ docker restart rabbitmq

在这里插入图片描述
在这里插入图片描述

3.SpringBoot中使用RabbitMQ

3.1.SpringAMQP

SpringBoot中提供了一个spring-boot-starter-amqp依赖用于简化RabbitMQ 在Spring中开发应用。

SpringAMQP 是基于 AMQP 协议定义的一套API,提供了模板来发送和接收消息。包含两部分,spring-amqp 是基础抽象,spring-rabbit 是底层默认实现。 SpringAMQP 提供了三个功能:

  • 自动声明队列、交换机及其绑定关系
  • 基于注解的监听器模式,异步接收消息 (消费者)
  • 封装了 RabbitTemplate 工具,用于发送消息 (生产者)

SpringAMQP 是基于 RabbitMQ 封装的一套模板,配合 SpringBoot 让 RabbitMQ 使用变得非常简单

SpringAMQP 的官方地址:https://spring.io/projects/spring-amqp

3.2使用步骤

引入依赖

<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-amqp</artifactId>
</dependency>

创建生产者测试类

@SpringBootTest
public class ProducerTest {
    @Test
    public void testSendMessage() throws IOException, TimeoutException {
        // 1.建立连接
        ConnectionFactory factory = new ConnectionFactory();
        // 1.1.设置连接参数
        factory.setHost("192.168.6.131");
        factory.setPort(5672);
        factory.setVirtualHost("/");
        factory.setUsername("rabbitmq");
        factory.setPassword("123456");
        // 1.2.建立连接
        Connection connection = factory.newConnection();

        // 2.创建通道Channel
        Channel channel = connection.createChannel();

        // 3.创建队列
        String queueName = "basic.queue";
        channel.queueDeclare(queueName, false, false, false, null);

        // 4.发送消息
        String message = "hello, rabbitmq!";
        channel.basicPublish("", queueName, null, message.getBytes());
        System.out.println("发送消息成功:【" + message + "】");

        // 5.关闭通道和连接
        channel.close();
        connection.close();
    }
}

创建消费者测试类

public class ConsumerTest {

    @SneakyThrows
    public static void main(String[] args) throws IOException{
        // 1.建立连接
        ConnectionFactory factory = new ConnectionFactory();
        // 1.1.设置连接参数
        factory.setHost("192.168.6.131");
        factory.setPort(5672);
        factory.setVirtualHost("/");
        factory.setUsername("rabbitmq");
        factory.setPassword("123456");
        // 1.2.建立连接
        Connection connection = factory.newConnection();
        // 2.创建通道Channel
        Channel channel = connection.createChannel();
        // 3.创建队列
        String queueName = "basic.queue";
        channel.queueDeclare(queueName, false, false, false, null);
        // 4.订阅消息
        channel.basicConsume(queueName, true, new DefaultConsumer(channel){
            @Override
            public void handleDelivery(String consumerTag, Envelope envelope,
                                       AMQP.BasicProperties properties, byte[] body) throws IOException {
                // 5.处理消息
                String message = new String(body);
                System.out.println("接收到消息:【" + message + "】");
            }
        });
        System.out.println("等待接收消息。。。。");
    }
}

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

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

相关文章

SpringBoot+Vue实现校园二手系统。前后端分离技术【完整功能介绍+实现详情+源码】

前言 文章内容有点长&#xff0c;建议打开右侧目录导航栏查看。 这个系统基本上可以改造为其它类似的系统。后台管理基本上一致。前台进行一些页面样式的改造就可以变成一个新的系统。有时间&#xff0c;做几个变体系统。 闲的无聊&#xff0c;把大学时候做的一个系统进行了重…

git源代码管理

文章目录 git源代码管理git单人本地仓库操作创建远程仓库&#xff08;github为例&#xff09;多人开发与冲突分支操作SSH&#xff08;安全外壳协议&#xff09; git源代码管理 文档连接&#xff1a;https://git-scm.com/docs git是用于源代码管理&#xff0c;方便多人协同开发…

架构整洁之道上篇(编程范式设计原则)

目录 1.概述 2.编程范式 2.1.结构化编程 2.2.面向对象编程 2.3.函数式编程 3.设计原则 3.1.单一职责原则 3.2.开闭原则 3.3.里氏替换原则 3.4.接口隔离原则 3.5.依赖反转原则 4.小结 1.概述 软件架构的终极目标是&#xff0c;用最小的人力成本来满足构建和维护该系…

2023 操作系统 R 复习大纲( 适用于太理软件 21 级)

目录 01.操作系统的定义 02.操作系统的基本类型及特征 1.批处理操作系统&#xff08;单、多道&#xff09; 2.分时操作系统 3.实时操作系统 03.操作系统的功能及特征 04.进程的定义、特征 05.进程基本状态及其转换原因 06.进程互斥、同步 07.进程控制块的内容、作用 …

Java数据类型之整数类型与浮点数

标识符&#xff08;名字&#xff09; 作用域 离其最近的大括号 { } &#xff01;&#xff01;&#xff01; 数据类型的分类 赋值时&#xff0c;不可超过数据类型的范围&#xff08;不可越界&#xff09; 常量的进制转换 tips&#xff1a;给变量赋值时&#xff0c;值可以为不同…

从代码层面理解Transformer

跑通 代码使用的是 https://github.com/jadore801120/attention-is-all-you-need-pytorch, commit-id 为: 132907d 各模块粗览 Transformer 主要包括一堆参数, 以及encoder和decoder forward的时候主要做了如下操作. 先 pad_mask过encoder过decoder输出logit 从train.py …

C语言-【指针一】-【什么是指针/指针类型】

对于初学者来说&#xff0c;是不是一提到指针&#xff0c;大家就头疼啊&#xff0c;哈哈哈&#xff0c;当然&#xff0c;它都这么“吓人”了&#xff0c;那么在C语言中扮演的角色也很重要&#xff0c;当然&#xff0c;它也是C语言中的一个特色&#xff0c;如果我们把它拿下的话…

ESP32CAM,点亮一个LED(Arduino平台)

前言 &#xff08;1&#xff09;在此&#xff0c;吐槽一下乐鑫的函数介绍&#xff0c;真的难找。恶心的一批。气死我了。 &#xff08;2&#xff09;接下来我将会介绍我是如何找到ESP32的Arduino平台的函数库的。你将会知道为啥我这么大的戾气。 &#xff08;3&#xff09;同时…

linux系统中输入与输出重定向

什么是输入输出重定向 我们在日常工作中最常用的是输出重定向&#xff0c;输出重定向就是将原本要打印到屏幕中的信息重定向到一个文件中。而输入重定向呢就是指把文件导入到命令中去&#xff0c;听起来是不是有点抽象啊&#xff0c;后面看博主举例说明就很好理由啦。 输出重定…

通讯录信息管理系统

系列文章 任务50 通讯录信息管理系统 文章目录 系列文章一、实践目的与要求1、目的2、要求 二、课题任务三、总体设计1.存储结构及数据类型定义2.程序结构3.所实现的功能函数4、程序流程图 四、小组成员及分工五、 测试插入按编号查找按姓名查找按城市查找更新排序浏览删除统计…

超好玩C++控制台打飞机小游戏,附源码

我终于决定还是把这个放出来。 视频在这&#xff1a;https://v.youku.com/v_show/id_XNDQxMTQwNDA3Mg.html 具体信息主界面上都有写。 按空格暂停&#xff0c;建议暂停后再升级属性。 记录最高分的文件进行了加密。 有boss&#xff08;上面视频2分47秒&#xff09;。 挺好…

轻松转换CAJ文件为PDF格式:免费工具和技巧

在处理中国知网&#xff08;CNKI&#xff09;数据库中的CAJ文件时&#xff0c;将其转换为更常用的PDF格式可以提供更广泛的共享和便捷的阅读体验。本文将介绍一种免费的工具和一些技巧&#xff0c;帮助您轻松地将CAJ文件转换为PDF格式。我们将使用记灵在线工具进行操作。 记灵…

推荐几本提高程序员职业素养的书

如果你是一名程序员&#xff0c;想要提长自己&#xff0c;那么这几本书推荐给你。 1、好代码 &#xff0c;坏代码 为了写出优良的代码&#xff0c;我们必须对手上的方案有合理的判断&#xff0c;并彻底想清楚特定方法的结果&#xff08;好的和坏的&#xff09;。为此&#xff…

F检验.医学统计实例详解

F检验是一种重要的医学统计方法&#xff0c;常用于检验两个或多个样本的方差是否相等&#xff0c;也被称为方差齐性检验。方差齐性检验是医学研究中的基本方法&#xff0c;因为许多重要的统计分析都要求样本方差相等&#xff0c;如方差分析、t检验等。以下将介绍F检验的基本原理…

简单上手Scrapy框架

创建一个Scrapy框架的爬虫程序 安装Scrapy库&#xff0c;直接通过pycharm搜索Scrapy进行安装即可 在终端执行 scrapy startproject 项目名 scrapy startproject Learn 示例 即可创建名为Learn的Scrapy程序&#xff0c;成功创建项目后&#xff0c;会已项目名称创建一个文件夹&…

FTP和SSH连接远程终端Ubuntu

安装好ubuntu后是默认没有ssh服务和ftp服务的&#xff0c;我们需要自己解决一下这个问题 SSH 更新软件列表和软件 sudo apt-get update sudo apt-get upgrade安装ssh sudo apt-get install ssh启动ssh服务 sudo /etc/init.d/ssh start修改ssh服务配置文件 sudo vim /etc/…

前端工程化:发布一个属于自己的规范 npm 包

初始化项目 首先在github创建一个仓库&#xff0c;协议选择MIT&#xff0c;gitignore选择Node&#xff0c;添加README.md描述文件。使用git clone将项目克隆到本地。cd 进入目录&#xff0c;使用vscode打开&#xff08;终端输入code . 命令即可&#xff09;。 然后创建一个合理…

CentOS-7 安装 MariaDB-10.8

一、安装之前删除已存在的 Mysql/MariaDB 1 查找存在的 MariaDB # 注意大小写 rpm -qa | grep MariaDB # rpm -qa 列出所有被安装的rpm package &#xff08;-qa:query all&#xff09; rpm -qa | grep mariadb # grep &#xff08;缩写来自Globally search a Regular Expre…

C++ 折叠参数包:悄然增强编程效率

前言 欢迎来到&#x1f496;小K&#x1f496;的&#x1f49e;C专栏&#x1f49e;&#xff0c;本节将为大家带来折叠参数包的详细讲解&#xff0c;折叠参数包为C模板编程提供了更加灵活和强大的工具&#xff0c;可以提高代码的简洁性和可读性&#xff0c;看完后希望对你有收获 文…

室内外融合定位UWB信标定位方案

大家好&#xff0c;我是北京华星智控公司小智&#xff0c;今天我给大家介绍室内外融合定位系统方案&#xff0c;该方案室外采用北斗卫星定位技术室内采用UWB定位技术从而实现室内外精确定位无缝切换&#xff0c;实现室内外的融合定位。 室内外融合定位系统&#xff0c; 该方案…