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

这篇具有很好参考价值的文章主要介绍了搭建RabbitMQ消息服务,整合SpringBoot实现收发消息。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

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

一、前言

1.1 什么是消息队列

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

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

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

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

搭建RabbitMQ消息服务,整合SpringBoot实现收发消息,Flag & 经验分享,java-rabbitmq,rabbitmq,spring boot,消息队列,中间件,云原生,kafka,原力计划

1.2 RabbitMQ 是什么

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

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

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

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

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

搭建RabbitMQ消息服务,整合SpringBoot实现收发消息,Flag & 经验分享,java-rabbitmq,rabbitmq,spring boot,消息队列,中间件,云原生,kafka,原力计划

1.3 为什么需要用到 RabbitMQ

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

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

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

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

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

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

搭建RabbitMQ消息服务,整合SpringBoot实现收发消息,Flag & 经验分享,java-rabbitmq,rabbitmq,spring boot,消息队列,中间件,云原生,kafka,原力计划

1.4 RabbitMQ 相比 Kafka 的优势

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

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

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

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

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

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

搭建RabbitMQ消息服务,整合SpringBoot实现收发消息,Flag & 经验分享,java-rabbitmq,rabbitmq,spring boot,消息队列,中间件,云原生,kafka,原力计划


二、搭建 RabbitMQ 环境

2.1 安装 Erlang

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

2.1.1 下载

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

搭建RabbitMQ消息服务,整合SpringBoot实现收发消息,Flag & 经验分享,java-rabbitmq,rabbitmq,spring boot,消息队列,中间件,云原生,kafka,原力计划

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

2.1.2 安装

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

搭建RabbitMQ消息服务,整合SpringBoot实现收发消息,Flag & 经验分享,java-rabbitmq,rabbitmq,spring boot,消息队列,中间件,云原生,kafka,原力计划

搭建RabbitMQ消息服务,整合SpringBoot实现收发消息,Flag & 经验分享,java-rabbitmq,rabbitmq,spring boot,消息队列,中间件,云原生,kafka,原力计划

搭建RabbitMQ消息服务,整合SpringBoot实现收发消息,Flag & 经验分享,java-rabbitmq,rabbitmq,spring boot,消息队列,中间件,云原生,kafka,原力计划

搭建RabbitMQ消息服务,整合SpringBoot实现收发消息,Flag & 经验分享,java-rabbitmq,rabbitmq,spring boot,消息队列,中间件,云原生,kafka,原力计划

搭建RabbitMQ消息服务,整合SpringBoot实现收发消息,Flag & 经验分享,java-rabbitmq,rabbitmq,spring boot,消息队列,中间件,云原生,kafka,原力计划

2.1.3 环境变量配置

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

ERLANG_HOME

搭建RabbitMQ消息服务,整合SpringBoot实现收发消息,Flag & 经验分享,java-rabbitmq,rabbitmq,spring boot,消息队列,中间件,云原生,kafka,原力计划

搭建RabbitMQ消息服务,整合SpringBoot实现收发消息,Flag & 经验分享,java-rabbitmq,rabbitmq,spring boot,消息队列,中间件,云原生,kafka,原力计划

验证命令如下:

erl -v

搭建RabbitMQ消息服务,整合SpringBoot实现收发消息,Flag & 经验分享,java-rabbitmq,rabbitmq,spring boot,消息队列,中间件,云原生,kafka,原力计划

2.2 安装 RabbitMQ

2.2.1 下载

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

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

2.2.2 安装

安装流程如下图所示。

搭建RabbitMQ消息服务,整合SpringBoot实现收发消息,Flag & 经验分享,java-rabbitmq,rabbitmq,spring boot,消息队列,中间件,云原生,kafka,原力计划

搭建RabbitMQ消息服务,整合SpringBoot实现收发消息,Flag & 经验分享,java-rabbitmq,rabbitmq,spring boot,消息队列,中间件,云原生,kafka,原力计划

搭建RabbitMQ消息服务,整合SpringBoot实现收发消息,Flag & 经验分享,java-rabbitmq,rabbitmq,spring boot,消息队列,中间件,云原生,kafka,原力计划

搭建RabbitMQ消息服务,整合SpringBoot实现收发消息,Flag & 经验分享,java-rabbitmq,rabbitmq,spring boot,消息队列,中间件,云原生,kafka,原力计划

2.2.3 初始化

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

搭建RabbitMQ消息服务,整合SpringBoot实现收发消息,Flag & 经验分享,java-rabbitmq,rabbitmq,spring boot,消息队列,中间件,云原生,kafka,原力计划
接着输入以下命令,完成初始化安装。

rabbitmq-plugins enable rabbitmq_management

搭建RabbitMQ消息服务,整合SpringBoot实现收发消息,Flag & 经验分享,java-rabbitmq,rabbitmq,spring boot,消息队列,中间件,云原生,kafka,原力计划

2.2.4 验证

打开浏览器,输入:

http://localhost:15672

账号密码都是:

guest

搭建RabbitMQ消息服务,整合SpringBoot实现收发消息,Flag & 经验分享,java-rabbitmq,rabbitmq,spring boot,消息队列,中间件,云原生,kafka,原力计划
搭建RabbitMQ消息服务,整合SpringBoot实现收发消息,Flag & 经验分享,java-rabbitmq,rabbitmq,spring boot,消息队列,中间件,云原生,kafka,原力计划

2.3 配置外网访问

2.3.1 添加新用户

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

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

搭建RabbitMQ消息服务,整合SpringBoot实现收发消息,Flag & 经验分享,java-rabbitmq,rabbitmq,spring boot,消息队列,中间件,云原生,kafka,原力计划

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

搭建RabbitMQ消息服务,整合SpringBoot实现收发消息,Flag & 经验分享,java-rabbitmq,rabbitmq,spring boot,消息队列,中间件,云原生,kafka,原力计划

2.3.2 Virtual Host 配置

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

搭建RabbitMQ消息服务,整合SpringBoot实现收发消息,Flag & 经验分享,java-rabbitmq,rabbitmq,spring boot,消息队列,中间件,云原生,kafka,原力计划

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

搭建RabbitMQ消息服务,整合SpringBoot实现收发消息,Flag & 经验分享,java-rabbitmq,rabbitmq,spring boot,消息队列,中间件,云原生,kafka,原力计划

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


三、整合 RabbitMQ 消息服务

3.1 创建新的 SpringBoot 项目

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

搭建RabbitMQ消息服务,整合SpringBoot实现收发消息,Flag & 经验分享,java-rabbitmq,rabbitmq,spring boot,消息队列,中间件,云原生,kafka,原力计划

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

搭建RabbitMQ消息服务,整合SpringBoot实现收发消息,Flag & 经验分享,java-rabbitmq,rabbitmq,spring boot,消息队列,中间件,云原生,kafka,原力计划

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.167
    port: 5672
    username: zwz
    password: 123456
    listener:
      simple:
        retry:
          enabled: true
          max-attempts: 5
          initial-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 设置连接IP
        connectionFactory.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. 创建连接Connection
            connection = connectionFactory.newConnection("ZWZ-Connection");
            //3. 通过连接获取通道Channel
            channel = 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 函数即可。

搭建RabbitMQ消息服务,整合SpringBoot实现收发消息,Flag &amp; 经验分享,java-rabbitmq,rabbitmq,spring boot,消息队列,中间件,云原生,kafka,原力计划

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

搭建RabbitMQ消息服务,整合SpringBoot实现收发消息,Flag &amp; 经验分享,java-rabbitmq,rabbitmq,spring boot,消息队列,中间件,云原生,kafka,原力计划
搭建RabbitMQ消息服务,整合SpringBoot实现收发消息,Flag &amp; 经验分享,java-rabbitmq,rabbitmq,spring boot,消息队列,中间件,云原生,kafka,原力计划

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 设置连接IP
        connectionFactory.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. 创建连接Connection
            connection = connectionFactory.newConnection("ZWZ-Connection");
            //3. 通过连接获取通道Channel
            channel = connection.createChannel();
            //4. 通过通道创建交换机,声明队列,绑定关系,路由key,发送消息,接收消息
            String queueName = "ZWZ-TOPIC";
            //5. 接收消息并消费消息
            channel.basicConsume(queueName, true, new DeliverCallback() {
                @Override
                public void handle(String consumerTag, Delivery message) throws IOException {
                    System.out.println("接收到的消息内容是:" + new String(message.getBody(), "UTF-8"));
                }
            }, new CancelCallback() {
                @Override
                public 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消息服务,整合SpringBoot实现收发消息,Flag &amp; 经验分享,java-rabbitmq,rabbitmq,spring boot,消息队列,中间件,云原生,kafka,原力计划

四、总结

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


搭建RabbitMQ消息服务,整合SpringBoot实现收发消息,Flag &amp; 经验分享,java-rabbitmq,rabbitmq,spring boot,消息队列,中间件,云原生,kafka,原力计划文章来源地址https://www.toymoban.com/news/detail-704814.html

到了这里,关于搭建RabbitMQ消息服务,整合SpringBoot实现收发消息的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 【RabbitMQ与SpringBoot集成测试收发消息】

    安装环境:虚拟机VMWare + Centos7.6 + Maven3.6.3 + JDK1.8 RabbitMQ版本:rabbitmq-server-3.8.8-1.el7.noarch.rpm 编程工具Idea + 运行JDK为17 在RabbitMQ的UI界面或命令行上 创建新的Virtual Host ,取名为 vhtest02 ,如下图所示: 使用Idea的 Spring Initializr 创建生产者工程 springrabbitmqtest ,坐标如下: 配置

    2024年02月13日
    浏览(38)
  • 消息队列-RabbitMQ:延迟队列、rabbitmq 插件方式实现延迟队列、整合SpringBoot

    1、延迟队列概念 延时队列内部是有序的 , 最重要的特性 就体现在它的 延时属性 上,延时队列中的元素是希望在指定时间到了以后或之前取出和处理,简单来说, 延时队列就是用来存放需要在指定时间被处理的元素的队列。 延迟队列使用场景: 订单在十分钟之内未支付则

    2024年02月22日
    浏览(54)
  • 207、SpringBoot 整合 RabbitMQ 实现消息的发送 与 接收(监听器)

    1、ContentUtil 先定义常量 2、RabbitMQConfig 创建队列的两种方式之一: 配置式: 在容器中配置 org.springframework.amqp.core.Queue 类型的Bean,RabbitMQ将会自动为该Bean创建对应的队列。 就是在配置类中创建一个生成消息队列的@Bean。 问题: 用 @Configuration 注解声明为配置类,但是项目启动

    2024年02月06日
    浏览(57)
  • 一文带你如何用SpringBoot+RabbitMQ方式来收发消息

    预告了本篇的内容:利用RabbitTemplate和注解进行收发消息,还有一个我临时加上的内容:消息的序列化转换。 本篇会和SpringBoot做整合,采用自动配置的方式进行开发,我们只需要声明RabbitMQ地址就可以了,关于各种创建连接关闭连接的事都由Spring帮我们了~ 交给Spring帮我们管

    2024年02月09日
    浏览(41)
  • SpringBoot 2.2.5 整合RabbitMQ,实现Topic主题模式的消息发送及消费

    1、simple简单模式 消息产生着§将消息放入队列 消息的消费者(consumer) 监听(while) 消息队列,如果队列中有消息,就消费掉,消息被拿走后,自动从队列中删除(隐患 消息可能没有被消费者正确处理,已经从队列中消失了,造成消息的丢失)应用场景:聊天(中间有一个过度的服务器;p端,c端

    2024年02月02日
    浏览(47)
  • SpringCloudStream集成RabbitMQ实现消息收发

    ​ SpringCloudStream 是一个构建高扩展和事件驱动的微服务系统的框架,用于连接共有消息系统,官网地址: spring.io/projects/sp… 。整体上是把各种花里胡哨的MQ产品抽象成了一套非常简单的统一的编程框架,以实现事件驱动的编程模型。社区官方实现了RabbitMQ,Apache Kafka,Kaf

    2024年02月03日
    浏览(39)
  • 使用StreamBridge实现RabbitMq 消息收发 && ack确认 && 延时消息

    下载地址:link 1.下载完成放到rabbitmq安装目录plugins下 2.执行命令启用插件 3.重启mq Exchanges - add a new exchange - type 出现x-delayed-message即安装成功

    2024年02月11日
    浏览(44)
  • 【SpringBoot框架篇】35.kafka环境搭建和收发消息

    kafka依赖java环境,如果没有则需要安装jdk kafka3.0版本后默认自带了zookeeper,3.0之前的版本需要单独再安装zookeeper,我使用的最新的3.6.1版本。 cd到kafka的安装根目录后,执行下面命令指令 zookeeper.properties 文件路径启动zookeeper,默认启动的zk服务使用内存是512m,可以修改 zookeeper-server

    2024年01月18日
    浏览(42)
  • Springboot整合RabbitMQ消息中间件

    spring-boot-rabbitmq–消息中间件整合 前言:RabbitMQ的各种交换机说明 1、直连交换机 生产者发布消息时必须带着routing-key,队列绑定到交换机时必须指定binding-key ,且routing-key和binding-key必须完全相同,如此才能将消息路由到队列中 直连交换机通常用来循环分发任务给多个workers,

    2024年02月11日
    浏览(47)
  • 消息队列——spring和springboot整合rabbitmq

    目录 spring整合rabbitmq——生产者 rabbitmq配置文件信息 倒入生产者工程的相关代码 简单工作模式 spring整合rabbitmq——消费者 spring整合rabbitmq——配置详解 SpringBoot整合RabbitMQ——生产者  SpringBoot整合RabbitMQ——消费者   使用原生amqp来写应该已经没有这样的公司了 创建两个工程

    2024年02月16日
    浏览(54)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包