RabbitMQ初识

news2024/11/17 2:35:06

目录

Kafka

RocketMQ

RabbitMQ

MQ界面(它使用的端口号5672,界面是15672) 

如何添加一个虚拟机,点击右侧

Topics(通配符模式)

发布确认机制

持久性(可靠性保证的机制之一)


 

JDK17,Linux服务器Ubuntu

什么是MQ

实现了AMQP消息队列服务,当前主流消息中间件一。

AMQP:高级消息队列协议,是一个通用的应用层协议,通过统一消息服务的协议,为面向消息中间件设计,基于此协议的客户端与消息中间件可传递消息

MQ消息队列:

先进先出

同步通信:

A->B

异步通信:

A->消息队列->B 消息传递

MQ的作用:接收并且转发消息

1.异步解耦:

用户注册:

1)用户信息校验

2)插入数据库

3)发送邮件

生活中会有一些操作非常耗时,但是并不需要即使返回结果,可以借助MQ把这些操作异步化,比如用户注册之后,发送注册成功,可以作为异步任务处理,而不必等待这些操作完成之后,才告诉用户注册成功

2.流量削峰:在访问量剧增的情况下,应用仍然需要继续发挥作用,但是这样的突发流量并不常见,如果处理这类峰值为标准投入资源,肯定是浪费,所以关键时刻,使用MQ使关键组件支撑突发访问压力,不会因为突发流量而崩溃,比如xx关宣恋情,省钱之眼秒杀活动,可以使用MQ控制流量,请求排队,然后再系统根据自己能力逐渐处理这些请求

3.消息分发:当多个系统需要对同一数据做出相应时,可以使用MQ进行消息分发,比如支付成功之后,支付系统可以像MQ发消息,其他系统订阅该消息,这样就不需要轮询数据库了

每月付款

4.延时通知:在需要特定时间后发送通知的场景中,可以使用MQ的延迟消息功能,比如在电子商务平台中,如果用户下单后一定时间内未支付,可以使用延时消息队列在超时后自动取消订单。

Kafka

开始运用的目的是日志的手机和传输,追求高吞吐,性能卓越,单机吞吐十万级,但是功能比较简单,日志领域倒是比较成熟

RocketMQ

RocketMQ采用JAVA开发,由阿里巴巴开源,后捐赠给Apache

他设计时借鉴了Kafka,并做出改进,经多年双十一系例,适用于可靠性比较高,并且并发比较大的场景,比如互联网金融,但是支持的客户端语言不多,并且社区活跃一般(意味着遇到问题的话,没有很多的解决方案)

RabbitMQ

采用Erlang语言,MQ功能完善,并且几乎支持所有主流语言,开源界面也十分友好,性能比较好,吞吐量达到数万级别,社区活跃度也高,适合中小型公司,数据量没那么大,并发没那么高的场景

RabbitMQ安装需要Erlang语言的支持,在安装rabbitMq之前需要安装erlang

至于如何下载rabbitMq,看我前面docker的操作,之间拉镜像,然后看你需不需要保存本地

docker run -d  --name rabbitmq -p 15672:15672 -p 5672:5672 rabbitmq
docker exec -it 镜像名字 bash
rabbitmq-plugins enable rabbitmq_management

MQ界面(它使用的端口号5672,界面是15672) 

虚拟机,类似于mysql的database。

添加一个角色,那个黄色代表咩有任何权限,所以

点击进去后set就好了。

如何添加一个虚拟机,点击右侧

添加成功,guest有权限

AMQP:高级消息队列协议

import com.rabbitmq.client.Channel;
import com.rabbitmq.client.Connection;
import com.rabbitmq.client.ConnectionFactory;

import java.io.IOException;
import java.util.concurrent.TimeoutException;

public class ProducerDemo {
    public static void main(String[] args) throws IOException, TimeoutException {
        //建立连接需要信息 1。IP 2.端口号 3.账号 4.密码 5。虚拟机
        //1.建立连接
        ConnectionFactory connectionFactory=new ConnectionFactory();
        connectionFactory.setHost("47.98.61.112");
        connectionFactory.setPort(5672);
        connectionFactory.setUsername("guest");
        connectionFactory.setPassword("guest");
        connectionFactory.setVirtualHost("bite");
        Connection connection=connectionFactory.newConnection();

        //2.开启信道
        Channel channel= connection.createChannel();
        //3.声明交换机,使用内置交换机
        /**
         * queueDeclare(String queue,boolean durable,boolean exclusive,boolean outoDelete,Map<String,Object>arguments)
         * 参数说明
         * queue:队列名称
         * durable:可持久化
         * exclusive:是否独占
         * autoDelete:是否自动删除
         * arguments:参数
         */
        //4.声明队列
        channel.queueDeclare("hello",true,false,false,null);
        //5.发送消息
        /**
         * basicPublish(String exchange,String routingKey,BasicProperties props,byte[]body)
         * 参数说明:
         * exchange:交换机名称
         * routingKey:内置交换机,routingKey和队列名称保持一致
         * props:属性配置
         * body:消息
         */
        String msq="hello rabbitmq~";
        channel.basicPublish("","hello",null,msq.getBytes());
        System.out.println("我喜欢消息成功");
        //6.资源释放
        channel.close();
        connection.close();
    }
}

我们可以看到图中发送成功

假如我们不去释放资源,那么他就不结束

那么此处他就还在连接

消费者代码与生产者代码相似

1.创建链接

2.创建Channel

3.声明一个队列Queue

4.消费消息

5.释放资源

生产者不生产,请问我怎么消费捏?

为什么消费者需要声明队列:

消费者启动时候,需要制定订阅的队列,如果当时队列不存在,消费者会报错

消费者接受消息

import com.rabbitmq.client.*;

import java.io.IOException;
import java.util.concurrent.TimeoutException;

public class ConsumerDemo {
    /**
     * 1.创建连接
     * 2.创建Channel
     * 3.声明队列(可以省略,前提生产者声明好了,生产者要在消费者启动之前,声明好,最好声明)
     * 4。消费消息
     * 5。释放资源
     */
    public static void main(String[] args) throws IOException, TimeoutException, InterruptedException {
        ConnectionFactory connectionFactory=new ConnectionFactory();
        connectionFactory.setHost("47.98.61.112");
        connectionFactory.setPort(5672);
        connectionFactory.setUsername("guest");
        connectionFactory.setPassword("guest");
        connectionFactory.setVirtualHost("bite");
        Connection connection=connectionFactory.newConnection();
        //2.创建Channel
        Channel channel=connection.createChannel();
        //3.声明队列
        channel.queueDeclare("hello",true,false,false,null);
        //4.消费消息
        /**basicConsume(String queue,boolean autoAck,Consumer callback)
         * 参数说明:
         * queue:队列名称
         * autoAck:是否自动确认
         * callback:接收到消息后,执行的逻辑
         */
        DefaultConsumer consumer=new DefaultConsumer(channel){
            //从队列中收到消息,就会执行的方法
            @Override
            public void handleDelivery(String consumerTag, Envelope envelope, AMQP.BasicProperties properties, byte[] body) throws IOException {
                //TODO
                System.out.println("接收到消息"+new String(body));
            }
        };
        channel.basicConsume("hello",true,consumer);
        Thread.sleep(2000);
        //5。释放资源
        channel.close();
        connection.close();

    }


}

如果我们不去声明队列,那么就会报下面的错误,如果声明了,就算你把之前的队列删除,他会再给你声明。

RabbitMQ工作模式

上面两个只是起到了消息转发,所以没画,但是rabbitMQ不用上面这两个模式,其余的用

发布订阅模式,对应的是Fanout广播/扇出?

RoutingKey:发送的话指定      BindingKey:是RoutingKey的一种,是一种用来绑定的RoutingKey(路由键:生产者将消息发给交换器时,指定的一个字符串,用来告诉交换机应该如何处理这个消息)

Direct:定向,把消息交给指定routingkey的队列(Routing模式)

Topic通配符:把消息交给符合routing Pattermn路由模式的队列

使用绑定的时候,需要的路由键时BindingKey

发送消息的时候,需要的路由键时RoutingKey

4.路由模式(发布订阅模式的变种):

Topics(通配符模式)

RPC通信

发布确认机制

RabbitMQ消息可靠性的机制:他只是保证他可以正确发送到rabbitmq,生产者将Channel设置为Confirm模式(通过调用,channel.confirmSelect完成后,发布的每一条消息,都会获得一个唯一的ID,生产者可以将这些序列号与消息关联起来,以便于跟踪消息的状态

2.当消息被RabbitMq服务器接受并且处理之后,服务器会异步的向生产者发送一个确认(ACK)给生产者(包含消息的唯一iD),表明消息已经送达。

AcknowledgeMode.NONE:

这种模式下,消息一旦投递给消费者,不管消费者是否成功处理了消息,RabbitMQ就会自动确认消息,从RabbitMQ队列中移除消息,如果消费者处理消息失败,消息可能会丢失.

消费者正常处理:MQ删除相应消息

消费者异常处理:MQ删除相应消息

AcknowledgeMode.AUTO(默认)

这种模式下,消费者在消息处理成功时候,会自动确认消息,但是如果处理过程抛出异常,则不会确认消息

消费者正常处理:MQ正常确认

消费者异常处理:弹出一直弹错误(因为他会一直重新发消息)

AcknowledgeMode.MANUAL

手动确认模式下,消费者必须在成功处理消息后显式调用basicAck方法来确认消息,如果消息未被确认,RabbitMQ会认为消息尚未被成功处理,并且会在消费者可用时重新投递该消息,这种模式提高了消息处理的可靠性,因为即使消费者处理消息后失效,消息也不会丢失,而是可以被重新处理。

持久性(可靠性保证的机制之一)

RabbitMQ退出,由于某种原因崩溃时候,会忽视队列和消息,所以这也就需要持久化来帮助

RabbitMQ持久化包括三个部分,交换器持久化,队列的持久化,消息的持久化

交换机持久化是通过声明交换机,将durable设置为true,这可以理解为存硬盘上了,相当于将交换机的属性在服务器内部保存,当MQ的服务器发生意外或者关闭后,RabbitMQ不需要重新建立交换机,交换机会自动建立,相当于一直存在。

默认是持久化。

这样就是非持久化

持久化队列

非持久化队列

消息存储在队列中

消息持久化,需要队列持久化+消息持久化

只设置了队列持久化,MQ重启后消息会丢失

只设置消息持久化,MQ重启后,队列会丢失。消息也会丢失。

消息持久化的源码是判断是否是Message对象,假如是这个对象,就直接原封不动的返回.

测试场景

1.交换机 持久化       -数据不丢失

               非持久化    -数据丢失(交换机都丢了)

队列     持久化          -依然存在不丢失

             消息持久化  -消息存在,没有丢失

             消息非持久化 -消息丢失,队列没丢。

队列 非持久化          -队列都丢失了,你也看不到消息了

        消息持久化       -消息丢失,队列还在。

        消息非持久化   -队列也丢失了,消息也丢失

在持久化消息正确存入RabbitMQ之后,还有一段时间,(虽然很短,但是也不能忽视)才能存入磁盘中,RabbitMQ并不会每条消息都进行同步存盘的处理,可能仅仅保存到操作系统缓存之中而不是物理磁盘之中,如果这段时间内,RabbitMQ服务节点发生了宕机或者重启等异常情况,消息保存,还没来得及罗盘,那么这些消息将会丢失。

引入RabbitMQ的仲裁队列,假如主节点在此特殊节点挂掉,可以自动切换从节点,有效的保证高可用性,除非整个集群都挂掉(此方法也不保证100%可靠,但是配置了仲裁队列要比没有配置仲裁队列的可靠性要高很多,实际生产环境中的关键业务队列一般都会设置仲裁队列

2.还可以在发送端引入事务机制或者发送方确认机制,保证消息已经正确的发送并且存储至RabbitMQ。

小知识

int范围-127 -127 存储放到栈里面存储,超过200,地址可能有问题

springboot项目启动要注意,把那个该死的application放到最外面,不然无法找到里面的Mapping。

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

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

相关文章

recyclerView(kotlin)

recyclerView的优点 使用viewHolderRecycledViewPool的方式复用资源&#xff0c;提高性能利用LayoutManager&#xff0c;可根据不同需求使用不同的布局&#xff0c;且可以方便使用对应布局提供的方法&#xff0c;如快速定位item等。RecyclerView 提供了一个 ItemAnimator 接口…

msvcp110丢失怎么解决?三种方法教你修复msvcp110.dll丢失

1. msvcp110.dll 概述 1.1 定义与作用 msvcp110.dll 是 Microsoft Visual C 2012 Redistributable Package 的一部分&#xff0c;它是一个动态链接库&#xff08;DLL&#xff09;文件&#xff0c;对运行时环境至关重要。这个文件包含了 C 标准库的实现&#xff0c;为基于 Vis…

ssm智能社区管理系统的设计与实现

系统包含&#xff1a;源码论文 所用技术&#xff1a;SpringBootVueSSMMybatisMysql 免费提供给大家参考或者学习&#xff0c;获取源码请私聊我 目 录 目 录 III 1 绪论 1 1.1 研究背景 1 1.2 目的和意义 1 1.3 论文结构安排 2 2 相关技术 3 2.1 SSM框架介绍 3 2.2 B…

代码质量管理 SonarScanner 扫描分析实战

在软件开发过程中&#xff0c;代码质量管理是一个至关重要但往往被忽视的环节。糟糕的代码不仅会增加维护成本&#xff0c;还可能导致不可预见的Bug和系统崩溃。如何用更有效的工具来保障代码质量呢&#xff1f;今天&#xff0c;我们将聚焦 SonarScanner&#xff0c;一个高效的…

51单片机的智能水温控制系统【proteus仿真+程序+报告+原理图+演示视频】

1、主要功能 该系统由AT89C51/STC89C52单片机LCD1602显示模块温度传感器继电器LED和按键等模块构成。适用于智能热水器控制、泳池水温控制系统等相似项目。 可实现功能: 1、LCD1602实时显示水温信息和上下限 2、温度传感器DS18B20采集水体温度 3、当温度低于下限&#xff0…

如何更改CubeIDE的字体大小

开门见山&#xff0c;CubeIDE整个软件都是基于eclipse的&#xff0c;所以这种操作完全互通。 代码字体 ①点击Window->Preference ②在这个选项卡内&#xff0c;单击Apperance栏目下的Colors and Fonts&#xff0c;然后选中C/C/Editor栏目下的C/C Editor Text Font&#x…

OBOO鸥柏:布局于为元宇宙AI人工智能产业保障LCD液晶显示终端

新华网快讯&#xff0c;于10月7日消息&#xff0c;有投资者在互动平台向OBOO鸥柏提问&#xff1a;您好 请问作为中国专注于商用液晶显示屏领域的科技公司&#xff0c;公司有哪些工业/商用显示产品应用于数字化元宇宙AI人工智能领域&#xff1f;能否着重介绍下对于AI展馆展厅如何…

springboot宿舍管理-计算机毕业设计源码40740

摘要 宿舍管理系统作为一种利用信息技术改善学生住宿管理的工具&#xff0c;在大学宿舍管理中具有重要的实际意义。本文通过对国内外研究现状的调查和总结&#xff0c;探讨了宿舍管理系统的论文主题、研究背景、研究目的、研究意义以及主要研究内容。 首先&#xff0c;宿舍管理…

Python的pandas库基本操作(数据分析)

一、安装&#xff0c;导入 1、安装 使用包管理器安装&#xff1a; pip3 install pandas 2、导入 import pandas as pd as是为了方便引用起的别名 二、DateFrame 在Pandas库中&#xff0c;DataFrame 是一种非常重要的数据结构&#xff0c;它提供了一种灵活的方式来存储和…

Python数据分析教程09:层次分析法的方根法和求和法的实现

目录 1 求和法计算权重的方法以及代码示例 1.1 理论原理 1.2 代码实现 2 方根法计算权重的方法以及代码示例 2.1 理论方法 2.2 代码实现 感谢B站博主的视频:https://www.bilibili.com/video/BV1At421E7jE 作者详细推导了方根法和求和法两类方案的计算过程,有兴趣的同学…

若依项目搭建(黑马经验)

欢迎你搜索和了解到若依&#xff0c;这个项目是从黑马课程的一个实践&#xff0c;更多的项目经历和平台搭建期待着我们的共同学习&#xff01; 关于若依 若依是一套全部开源的快速开发平台&#xff0c;毫无保留给个人及企业免费使用。 前端采用Vue、Element UI。后端采用Sprin…

初识Mysql/备份,基础指令

1&#xff0c;MySQL登录指令&#xff1a; mysql -h 127.0.0.1 -P3306 -u -p 其中&#xff0c;-h指明登录部署了mysql服务的主机 -P指明要访问的端口号&#xff0c; -u指明登录用户 -p输入密码 2&#xff0c;数据库基础 mysql&#xff1a;表示的是客户端 mysqld&…

大学生课程设计报告--基于JavaGUI的贪吃蛇

前言 ​ 贪吃蛇游戏是一个基础且经典的视频游戏,它适合作为学习编程的人进行一些更深入的学习,可以更加了解关于循环,函数的使用,以及面向对象是如何应用到实际项目中的; ​ 不仅如此,贪吃蛇游戏的规则在思考后可以拆分,有利于学生将更多精力去设计游戏的核心逻辑,而…

​ ​视觉任务大一统!图像生成,编辑,翻译三合一!全能视觉助手PixWizard来袭!

文章链接&#xff1a;https://arxiv.org/pdf/2409.15278 github链接&#xff1a;https://github.com/AFeng-x/PixWizard 亮点直击 任务统一&#xff1a;针对视觉任务的多样性&#xff0c;提出将其框架化为图像到图像的转换问题&#xff0c;并通过后处理将生成的可视化效果转化…

【论文速看】DL最新进展20241009-图像生成、多模态、医学扩散模型、行人重识别

目录 【图像生成】【多模态】【医学扩散模型】【行人重识别】 【图像生成】 [2024] CAR: Controllable Autoregressive Modeling for Visual Generation 论文链接&#xff1a;https://arxiv.org/pdf/2410.04671 代码链接&#xff1a;https://github.com/MiracleDance/CAR 可控…

windows C++-避免死锁(上)

下面通过“哲学家就餐问题”说明了如何使用 concurrency::join 类来避免在应用程序中发生死锁。 在软件应用中&#xff0c;如果两个或多个进程分别留有资源&#xff0c;且相互等待另一进程释放其他资源&#xff0c;就会发生死锁。 “哲学家就餐问题”是在多个并发进程之间共享…

掌握甘特图,没有Excel也能轻松制作的技巧

甘特图是项目管理中常用工具&#xff0c;由亨利甘特发明。不擅长Excel者可用ZohoProjects等软件创建甘特图&#xff0c;其直观展示项目时间和任务&#xff0c;支持实时协作、工时管理等功能&#xff0c;广泛应用于各领域项目管理。 一、甘特图的由来 甘特图最初是由工程师和管…

反射在Go语言中的具体应用场景

在Go语言中&#xff0c;反射&#xff08;Reflection&#xff09;是一种强大的特性&#xff0c;它允许程序在运行时检查、修改和操作变量的类型信息。 尽管反射在性能上通常不如直接操作&#xff0c;但它在某些特定场景下非常有用。 反射在Go语言中的具体应用场景&#xff1a;…

YOLO11模型推理 | 目标检测与跟踪 | 实例分割 | 关键点估计 | OBB旋转目标检测

前言 本文分享YOLO11的模型推理&#xff0c;检测任务包括物体分类、目标检测与跟踪、实例分割 、关键点估计、旋转目标检测等。 首先安装YOLO11 官方默认安装方式 通过运行 pip install ultralytics 来快速安装 Ultralytics 包 安装要求&#xff1a; Python 版本要求&…

leetcode125:验证回文串

如果在将所有大写字符转换为小写字符、并移除所有非字母数字字符之后&#xff0c;短语正着读和反着读都一样。则可以认为该短语是一个 回文串 。 字母和数字都属于字母数字字符。 给你一个字符串 s&#xff0c;如果它是 回文串 &#xff0c;返回 true &#xff1b;否则&#…