搭建RabbitMQ消息服务,整合SpringBoot实现收发消息

作者主页:Designer 小郑
作者简介:3年JAVA全栈开发经验,专注JAVA技术、系统定制、远程指导,致力于企业数字化转型,CSDN博客专家,蓝桥云课认证讲师。

目录

  • 一、前言
    • 1.1 什么是消息队列
    • 1.2 RabbitMQ 是什么
    • 1.3 为什么需要用到 RabbitMQ
    • 1.4 RabbitMQ 相比 Kafka 的优势
  • 二、搭建 RabbitMQ 环境
    • 2.1 安装 Erlang
      • 2.1.1 下载
      • 2.1.2 安装
      • 2.1.3 环境变量配置
    • 2.2 安装 RabbitMQ
      • 2.2.1 下载
      • 2.2.2 安装
      • 2.2.3 初始化
      • 2.2.4 验证
    • 2.3 配置外网访问
      • 2.3.1 添加新用户
      • 2.3.2 Virtual Host 配置
  • 三、整合 RabbitMQ 消息服务
    • 3.1 创建新的 SpringBoot 项目
    • 3.2 引入依赖
    • 3.3 配置文件
    • 3.4 创建消息发送工具类
    • 3.5 发消息功能测试
    • 3.6 创建消息接收工具类
    • 3.7 收消息功能测试
  • 四、总结

一、前言

1.1 什么是消息队列

消息队列是一种在应用程序之间传递数据的通信机制,它基于 发布-订阅 模式,将消息发送者(发布者)和消息接收者(订阅者)解耦,使得它们可以独立地进行消息的发送和接收。

在消息队列中,消息发送者将消息发送到队列中,而消息接收者则从队列中获取消息进行处理。消息队列提供了一种异步的通信方式,即发送者发送消息后不需要等待接收者的回复,而可以立即继续执行其他操作。同时,消息队列还可以实现消息的持久化存储,确保消息在发送和接收过程中的可靠性。

消息队列的应用场景非常广泛,例如:

  • 在分布式系统中,可以用消息队列来实现不同模块之间的解耦;
  • 在高并发系统中,可以利用消息队列来缓解系统压力;
  • 在实时数据处理中,可以将数据存储在消息队列中,再由数据处理模块进行处理。

在这里插入图片描述

1.2 RabbitMQ 是什么

RabbitMQ是一个开源的消息队列中间件,它实现了高级消息队列协议),并提供了可靠的消息传递机制。

RabbitMQ使用Erlang语言编写,具有高度可靠、可扩展、灵活和可插拔的特性,被广泛应用于分布式系统、微服务架构、异步任务处理等场景。

RabbitMQ基于生产者和消费者模型工作。生产者将消息发送到RabbitMQ的交换机,然后交换机将消息路由到一个或多个队列,消费者从队列中获取消息并进行处理。

RabbitMQ 支持多种消息传递模式,同时还提供了消息的持久化、消息优先级、消息确认机制等特性,确保消息的可靠性和可靠传输。

RabbitMQ是一个成熟、可靠的消息队列中间件,提供了强大的消息传递机制和丰富的特性,被广泛应用于分布式系统和异步消息处理中。

在这里插入图片描述

1.3 为什么需要用到 RabbitMQ

  1. 解耦:RabbitMQ通过消息队列实现了生产者和消费者的解耦。生产者将消息发送到队列中,而消费者从队列中获取消息并进行处理。这种解耦使得系统中的不同模块能够独立进行开发和部署,提高了系统的灵活性和可维护性。

  2. 异步通信:RabbitMQ提供了一种异步通信机制。生产者发送消息到队列后,不需要等待消费者立即处理,而可以继续执行其他操作。这种异步通信能够提升系统的并发性能和响应速度。

  3. 缓冲和削峰:RabbitMQ可以作为一个缓冲区,用于存储来自生产者的消息。这样可以避免生产者和消费者之间的直接耦合,同时也能够应对瞬时的高并发请求,减轻系统压力。

  4. 可靠性和可恢复性:RabbitMQ提供了持久化消息的功能,即使在消息队列或消费者故障的情况下,消息也可以得到保留和恢复。这种可靠性保证了消息的不丢失和可靠传递。

  5. 扩展性:RabbitMQ是一个可扩展的消息队列中间件,可以在需要的时候增加更多的消息队列和消费者节点,以应对不断增长的业务需求。

  6. 多语言支持:RabbitMQ提供了多种编程语言的客户端,如Java、Python、C#等,使得开发者可以选择合适自己的编程语言与RabbitMQ进行交互。

在这里插入图片描述

1.4 RabbitMQ 相比 Kafka 的优势

RabbitMQ 提供了简单易用的 API 和管理界面,使得开发者可以快速上手并进行配置和管理,相比之下,Kafka 的配置和管理相对复杂一些。

RabbitMQ 支持多种消息传递模式和消息的路由选择机制,可以根据需求进行灵活的消息处理,而Kafka更适用于大规模的高吞吐量流式处理,通常使用发布-订阅模式。

RabbitMQ 具备持久化消息、消息确认机制等特性,可以确保消息的可靠传输,而 Kafka 通过多副本机制和消息日志的方式,提供了高度可靠性的消息传递。

RabbitMQ 可以通过设置队列的限流策略和消费者的消费速率来进行流量控制和削峰处理,能够保护消费者免受过多的消息推送,而Kafka则将消费者的消费速率控制交给消费者自身,在高并发场景下可能需要额外处理。

RabbitMQ 提供了多种编程语言的客户端,开发者可以根据自己的编程需求选择合适的客户端进行交互,而Kafka的客户端主要集中在Java语言上,对其他语言的支持相对较少。

RabbitMQ 拥有庞大的开源社区和丰富的生态系统,提供了丰富的插件和集成工具,方便开发者进行扩展和集成,Kafka的生态系统相对较小,但在大数据领域有广泛的应用和支持。

在这里插入图片描述


二、搭建 RabbitMQ 环境

2.1 安装 Erlang

Erlang 是 RabbitMQ 消息服务的基础环境,就像 Java 的 JDK 一样,是必须安装的。

2.1.1 下载

Erlang 官网下载地址:下载地址。

在这里插入图片描述

因为我们要把 RabbitMQ 服务装在服务器上,所以同学们可以在服务器上下载 Erlang 安装包,或者下载后手动上传至服务器。

2.1.2 安装

下载完成后双击安装包,按照提示流程正常安装即可,截图如下所示。

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

2.1.3 环境变量配置

变量名如下,变量值是安装的路径,如下图所示。

ERLANG_HOME

在这里插入图片描述

在这里插入图片描述

验证命令如下:

erl -v

在这里插入图片描述

2.2 安装 RabbitMQ

2.2.1 下载

RabbitMQ 需要在 Github 中下载,下载地址。

RabbitMQ 版本需要和 Erlang 对应,本文安装的是 3.9.5 版本。

2.2.2 安装

安装流程如下图所示。

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

2.2.3 初始化

安装完成后,使用 cmd 窗口,进入 RabbitMQ 的 sbin 目录,如下图所示。

在这里插入图片描述
接着输入以下命令,完成初始化安装。

rabbitmq-plugins enable rabbitmq_management

在这里插入图片描述

2.2.4 验证

打开浏览器,输入:

http://localhost:15672

账号密码都是:

guest

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

2.3 配置外网访问

2.3.1 添加新用户

RabbitMQ 默认端口为15672,用户名和密码都为guest,是不允许外部访问的。

所以我们要添加新用户,实现外网访问,操作流程如下图所示。

在这里插入图片描述

点击添加后,输入新用户的账号和密码,如下图所示。

在这里插入图片描述

2.3.2 Virtual Host 配置

Virtual Host 需要允许添加的用户访问,如下图所示。

在这里插入图片描述

进入子界面后,选择用户后提交,如下图所示。

在这里插入图片描述

然后,我们就完成了外网访问的配置。


三、整合 RabbitMQ 消息服务

3.1 创建新的 SpringBoot 项目

打开 IDEA 工具,新建项目,如下图所示。

在这里插入图片描述

新项目创建完成后,如下图所示。

在这里插入图片描述

3.2 引入依赖

首先,请在 pom.xml 中引入依赖,代码如下。

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

3.3 配置文件

application.yml 配置如下。

spring:rabbitmq:host: 118.126.82.167port: 5672username: zwzpassword: 123456listener:simple:retry:enabled: truemax-attempts: 5initial-interval: 2s

3.4 创建消息发送工具类

请同学们创建 SimpleProducer 工具类,代码如下。

package cn.zwz.send;import com.rabbitmq.client.Channel;
import com.rabbitmq.client.Connection;
import com.rabbitmq.client.ConnectionFactory;public class SimpleProducer {public static void main(String[] args) {//1. 创建连接工程ConnectionFactory connectionFactory = new ConnectionFactory();//1.1 设置连接IPconnectionFactory.setHost("118.126.82.167");//1.2 设置连接端口connectionFactory.setPort(5672);//1.3 设置用户名connectionFactory.setUsername("zwz");//1.4 设置密码connectionFactory.setPassword("123456");//1.5 设置虚拟访问节点,就是消息发送的目标路径connectionFactory.setVirtualHost("/");Connection connection = null;Channel channel = null;try {//2. 创建连接Connectionconnection = connectionFactory.newConnection("ZWZ-Connection");//3. 通过连接获取通道Channelchannel = connection.createChannel();//4. 通过通道创建交换机,声明队列,绑定关系,路由key,发送消息,接收消息String queueName = "ZWZ-TOPIC";/*** channel.queueDeclare有5个参数* params1: 队列的名称* params2: 是否要持久化, false:非持久化 true:持久化* params3: 排他性,是否独占队列* params4: 是否自动删除,如果为true,队列会随着最后一个消费消费完后将队列自动删除,false:消息全部消费完后,队列保留* params5: 携带的附加参数*/channel.queueDeclare(queueName, true, false, false, null);//5. 消息内容String message = "HELLO World!";//6. 将消息发送到队列channel.basicPublish("", queueName, null, message.getBytes());System.out.println("消息发送成功");} catch (Exception e) {e.printStackTrace();} finally {//7. 关闭通道if (channel != null && channel.isOpen()) {try {channel.close();} catch (Exception e) {e.printStackTrace();}}//8. 关闭连接if (connection != null && connection.isOpen()) {try {connection.close();} catch (Exception e) {e.printStackTrace();}}}}
}

3.5 发消息功能测试

发消息很简单,运行 main 函数即可。

在这里插入图片描述

发送成功后,后台可以接收到数据,如下图所示。

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

3.6 创建消息接收工具类

请同学们创建 SimpleConsumer 工具类,代码如下。

package cn.zwz.send;import com.rabbitmq.client.*;import java.io.IOException;public class SimpleConsumer {public static void work() {//1. 创建连接工程ConnectionFactory connectionFactory = new ConnectionFactory();//1.1 设置连接IPconnectionFactory.setHost("118.126.82.167");//1.2 设置连接端口connectionFactory.setPort(5672);//1.3 设置用户名connectionFactory.setUsername("zwz");//1.4 设置密码connectionFactory.setPassword("123456");//1.5 设置虚拟访问节点,就是消息发送的目标路径connectionFactory.setVirtualHost("/");Connection connection = null;Channel channel = null;try {//2. 创建连接Connectionconnection = connectionFactory.newConnection("ZWZ-Connection");//3. 通过连接获取通道Channelchannel = connection.createChannel();//4. 通过通道创建交换机,声明队列,绑定关系,路由key,发送消息,接收消息String queueName = "ZWZ-TOPIC";//5. 接收消息并消费消息channel.basicConsume(queueName, true, new DeliverCallback() {@Overridepublic void handle(String consumerTag, Delivery message) throws IOException {System.out.println("接收到的消息内容是:" + new String(message.getBody(), "UTF-8"));}}, new CancelCallback() {@Overridepublic void handle(String consumerTag) throws IOException {System.out.println("消息接收失败。。。");}});System.out.println("开始接受消息。。。。");//阻断程序System.in.read();} catch (Exception e) {e.printStackTrace();} finally {//7. 关闭通道if (channel != null && channel.isOpen()) {try {channel.close();} catch (Exception e) {e.printStackTrace();}}//8. 关闭连接if (connection != null && connection.isOpen()) {try {connection.close();} catch (Exception e) {e.printStackTrace();}}}}
}

接着在启动类上配置运行,代码如下。

package cn.zwz.send;import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;@SpringBootApplication
public class SendApplication {public static void main(String[] args) {new SimpleConsumer().work();SpringApplication.run(SendApplication.class, args);}
}

3.7 收消息功能测试

请同学们运行 SpringBoot 启动类,然后再次发送消息,就可以看到消息内容了,如下图所示。

在这里插入图片描述

四、总结

本文首先简单介绍了 RabbitMQ,然后和 Kafka 等热门消息队列进行对比,最后演示了 RabbitMQ 的完整安装配置整合流程,帮助零基础的小白入门 RabbitMQ 开发。


在这里插入图片描述

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

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

相关文章

Linux:【Mysql】Centos7安装mysql8.0

目录 一、环境及版本介绍 二、安装前准备 三、开始安装 一、环境及版本介绍 Linux环境&#xff1a;Centos7 Mysql版本&#xff1a;8.0.26 安装时使用的用户&#xff1a;root 二、安装前准备 1.1、下载Centos7镜像 网上寻找相关资源即可 1.2、下载VMwareWorkstation Pro并…

【LeetCode-中等题】208. 实现 Trie (前缀树)

文章目录 题目方法一&#xff1a;利用数组构建26叉树方法二&#xff1a;利用哈希表构建26叉树 题目 方法一&#xff1a;利用数组构建26叉树 插入图示&#xff1a; 全搜索和前缀搜索&#xff1a; 注意&#xff1a;全局匹配匹配完直接返回插入时的标志位 而前缀匹配时&#xff…

OpenWrt系统开发笔记

openWrt英文官网&#xff1a; https://openwrt.org/ 中文官网&#xff1a; http://www.openwrt.org.cn/ 一、开发环境及编译 在github上有两个源码使用的比较多   一个是lede,地址为&#xff1a;https://github.com/coolsnowwolf/lede   另一个为OpenWrt的官方源码&#…

Redis 管道

1. 面试题 1.1 如何优化频繁命令往返造成的性能瓶颈? 1.2 问题由来 Redis是一种基于客户端-服务端模型以及请求/响应协议的TCP服务。一个请求会遵循以下步骤&#xff1a; 1 客户端向服务端发送命令分四步(发送命令→命令排队→命令执行→返回结果)&#xff0c;并监听Socket返…

Redis 复制(replica)

1. 是什么 1.1 官网地址 https://redis.io/docs/management/replication/ 1.2 一句话 1. 就是主从复制&#xff0c;master以写为主&#xff0c;slave以读为主 2. 当master数据变化的时候&#xff0c;自动将新的数据异步同步到其它slave数据库 2. 能干嘛 1. 读写分离 2. 容灾…

智能化电力运维:数字孪生的崭露头角

随着科技的不断发展&#xff0c;数字孪生技术在各个领域的应用愈发广泛&#xff0c;尤其在电力运维领域&#xff0c;它正发挥着革命性的作用。数字孪生是一种虚拟仿真技术&#xff0c;通过实时模拟真实世界的物理对象或过程&#xff0c;可以从多方面为电力运维带来改变&#xf…

PEX装机

目录 一、PXE是什么&#xff1f; 二、PXE的组件&#xff1a; vsftpd/httpd/nfs tftp dhcp 三、配置vsftpd 四、配置tftp 1.安装tftp-server 2.启动tftp 五、准备pxelinx.0文件、引导文件、内核文件 1.准备pxelinux.0文件 2.准备引导文件、内核文件 六、配置dhcp …

实时操作系统Freertos开坑学习笔记:(八):信号量、事件标志组、任务通知机制

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 文章目录 前言一、信号量的简介1.信号量与队列的区别&#xff1f; 二、二值信号量及其实例1.什么是二值信号量2.二值信号量相关API函数3.二值信号量实例 三、计数型信号量四、…

TD3算法

TD3算法 全称Twin Delayed DDPG&#xff0c;是对DDPG算法的继承、发展和改进&#xff0c;论文 改进如下&#xff1a; T w i n \mathcal{T}win Twin&#xff1a;使用了两个critic来评估actor的动作价值&#xff0c;对应两个critic target&#xff0c;一个actor target&#xff0…

ChatGPT 超有用提示词 练习雅思口语

目录 Prompts &#x1f53b;作为一个英语口语老师和提高英语口语 方法1&#xff1a;口语简单练习 方法2&#xff1a;角色扮演练习口语 作为一个英语翻译/英语作文优化师/稿件校对 作为一个”职位”面试官 学习英文单词 演员 苏菲 玛索 阿尔弗雷多詹姆斯帕西诺 要孝顺…

联合教育部高等学校科学研究发展中心,阿依瓦科技创新教育专项正式发布!

7 月 24 日&#xff0c;教育部科技发展中心官网发布了《中国高校产学研创新基金&#xff0d;阿依瓦科技创新教育专项申请指南》。 针对高校在人工智能、智能制造、智慧校园、大数据等领域科研和教研的创新研究&#xff0c;教育部高等学校科学研究发展中心与阿依瓦(北京)技术有…

Android 自定义View之圆形进度条

很多场景下都用到这种进度条&#xff0c;有的还带动画效果&#xff0c; 今天我也来写一个。 写之前先拆解下它的组成&#xff1a; 底层圆形上层弧形中间文字 那我们要做的就是&#xff1a; 绘制底层圆形&#xff1b;在同位置绘制上层弧形&#xff0c;但颜色不同&#xff…

2651. 计算列车到站时间

文章目录 Tag题目来源题目解读解题思路方法一&#xff1a;数学 知识回忆除法运算 写在最后 Tag 【数学】 题目来源 2651. 计算列车到站时间 题目解读 给你一个列车预计到达时间点和一个列车延误的时间&#xff0c;请返回列车实际的到达时间。 解题思路 方法一&#xff1a;数…

C语言每日一练--Day(16)

本专栏为c语言练习专栏&#xff0c;适合刚刚学完c语言的初学者。本专栏每天会不定时更新&#xff0c;通过每天练习&#xff0c;进一步对c语言的重难点知识进行更深入的学习。 今日练习题关键字&#xff1a;寻找奇数 峰值 二分查找 &#x1f493;博主csdn个人主页&#xff1a;小…

C# 基础面试题(万字)

1.选择题 1. 简述下面选项能够捕获运算溢出的异常类型的有 &#xff1f; A)Exception B)SystemException C)ArithmeticException D)OverflowException 试题回答&#xff1a;AD 2. 程序员可使用&#xff08;&#xff09;语句以程序方式引发异常 &#xff1f; A)run B)try C)th…

jframe生成柱状图片+图片垂直合并+钉钉机器人推送

需求&#xff1a; 后端根据数据自动生成2个图片&#xff0c;然后把两张图片合并成一张图片&#xff0c;再发到钉钉群里&#xff0c;涉及到定时生成和推送&#xff0c;当时我们测试同事说他们写定时脚本放到服务器上&#xff0c;然后让我提供生成图片的方法和钉钉机器人的逻辑 天…

【计算机网络】UDP协议详解

目录 前言 端口号的拓展 端口号范围划分 netstat pidof UDP协议 UDP协议端格式 UDP的特点 面向数据报 UDP的缓冲区 UDP使用注意事项 基于UDP的应用层协议 前言 我们前面讲完了http和https协议&#xff0c;它们都属于应用层&#xff0c;按照TCP/IP五层模…

2023国赛数学建模C题模型代码

C题代码全部都完成了&#xff0c;可以看文末名片 我们先看C题的一个背景 在生鲜商超中,蔬菜类商品保鲜期短,且品相会随销售时间增加而变差。商超需要根据历史销售和需求每天进行补货。由于蔬菜品种众多、产地不同,补货时间在凌晨,商家须在不明确具体单品和价格的情况下进行补…

如何排查网站及APP数据泄露的源头

近年来数据泄露安全事件频发&#xff0c;在今年的hw网络安全攻防演练中&#xff0c;获取敏感信息、数据泄露等漏洞的得分也越来越高&#xff0c;我们SINE安全近十年来成功的帮助了许多客户&#xff0c;查找到了数据泄露的原因&#xff0c;在这里向大家分享我们的经验与心得&…

端口已被占用

报的错误 Exception in thread "Thread-76" java.net.BindException: Address already in use: bindat sun.nio.ch.Net.bind0(Native Method)at sun.nio.ch.Net.bind(Net.java:433)at sun.nio.ch.Net.bind(Net.java:425)at sun.nio.ch.ServerSocketChannelImpl.bind…