Spring整合RabbitMQ

一、RabbitMQ简介

        RabbitMQ是一个消息中间件,常见的消息中间件还有ActiveMQRocketMQKafka等、其中ActiveMQ算是比较老的技术了,RocketMQ为阿里团队研发的其特点和RabbitMQ差不多、而Kafka则侧重于吞吐量。消息中间件的主要功能,流量削峰、解耦合、异步通知。本文主要介绍RabbitMQ的安装、MQ工作原理的简单介绍和springboot项目整合MQ案例。

二、RabbitMQ安装

         推荐使用docker安装。前提条件先安装docker,关于docker的讲解本文就不详细介绍,在"/"根目录下创建doker目录,再创建mq目录,结构如下图:

mq-start.sh启动脚本,data为挂载数据的目录,启动后自动生成。 

mq-start.sh详情

#!/bin/bash
docker rm -f rabbitmq 
docker run -d \
-v /docker/mq/data:/var/lib/rabbitmq \
-p 5672:5672 -p 15672:15672 --name rabbitmq --restart=always \
--hostname myRabbit rabbitmq:3-management

创建 mq-start.sh文件后使用 chmod +x mq-start.sh 增加可执行权限。

启动mq直接执行命令:"./mq-start.sh",docker会自动删除原来的镜像再拉去指定的镜像启动。

 5672为RabbitMQ默认端口15672为网页控制台端口,都需要在云服务器控制台的安全组策略添加这两个端口使得外部可以访问。

启动成功后打开浏览器输入服务器地址:15672,弹出控制台登录页面则安装启动成功!

默认用户名:guest,默认密码:guest

登录成功后主页面如下,然后我们创建一个admin用户,角色设置为administrator,以后就通过admin用户进行操作。

 至此RabbitMQ安装启动完毕!

三、SpringBoot整合RabbitMQ

1.创建项目填写信息和选择rabbitmq依赖

创建成功后刷新maven依赖。

 此外还需要的依赖如下:

        <dependency>
            <groupId>com.fasterxml.jackson.core</groupId>
            <artifactId>jackson-databind</artifactId>
            <version>2.9.5</version>
        </dependency>

项目结构如下:

 config 配置,consumer 消息消费者,producer 消息生产方

 2.配置连接和操作对象

        看了我之前的文章的朋友都知道spring 提供了自动配置类,里面规定了该配什么或者一些默认值,如图mq的自动配置类为 RabbitAutoConfiguration

 个人喜欢用yml配置,详情如下:

spring:
  rabbitmq:
    host: 127.0.0.1 ---改为服务器地址
    port: 5672
    username: admin
    password: admin
    virtual-host: /

3.配置交换机和消息队列(注解方式)

package com.example.mq.config;

import org.springframework.amqp.core.Binding;
import org.springframework.amqp.core.BindingBuilder;
import org.springframework.amqp.core.FanoutExchange;
import org.springframework.amqp.core.Queue;
import org.springframework.amqp.rabbit.connection.ConnectionFactory;
import org.springframework.amqp.rabbit.core.RabbitTemplate;
import org.springframework.amqp.support.converter.Jackson2JsonMessageConverter;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;

@Configuration
public class MQConfig {
    //将数据自动的转为json发送出去
    @Bean
    public RabbitTemplate rabbitTemplate(ConnectionFactory connectionFactory) {
        RabbitTemplate rabbitTemplate = new RabbitTemplate(connectionFactory);
        rabbitTemplate.setMessageConverter(new Jackson2JsonMessageConverter());
        return rabbitTemplate;
    }

    /**
     * 申明一个FanoutExchange
     * 名字:hot_send_fanout_exchange
     * 开启持久化
     * 自动删除关闭
     *
     * @return
     */
    @Bean
    public FanoutExchange e1() {
        return new FanoutExchange("hot_send_fanout_exchange", true, false);
    }

    /**
     * 申明一个队列
     * 名字:q1
     *
     * @return
     */
    @Bean
    public Queue q1() {
        return new Queue("q1", true);
    }

    /**
     * 申明一个队列
     * 名字:q2
     *
     * @return
     */
    @Bean
    public Queue q2() {
        return new Queue("q2", true);
    }

    /**
     * 将q1 绑定到 hot_send_fanout_exchange
     *
     * @return
     */
    @Bean
    public Binding bin1() {
        return BindingBuilder.bind(q1()).to(e1());
    }

    /**
     * 将q2 绑定到 hot_send_fanout_exchange
     *
     * @return
     */
    @Bean
    public Binding bin2() {
        return BindingBuilder.bind(q2()).to(e1());
    }

}

        启动项目后能在mq控制台看到自己创建的交换机和消息队列就成功了,若失败请仔细检查配置文件地址和maven依赖是否正确结合控制台错误信息排查错误。 

4.发送消息

@Component
public class MsgProducer {
    @Resource
    private RabbitTemplate rabbitTemplate;

    public void send(String exchangeName, String routingKey, Object msg) {
        rabbitTemplate.convertAndSend(exchangeName, routingKey, msg);
    }
}

发送消息主要靠 RabbitTemplateconvertAndSend方法,这个方法很多重载但参数大多如下:String exchange:交换机名称
String routingKey:路由键
Object object:数据 上面配置了以json形式发送

4.接收消息

@Component
@RabbitListener(queues = {"q1"})
public class MsgReceive {
    @RabbitHandler
    public void getMsg(byte[] msg) {
        System.out.println(new String(msg));
    }
}

只需要2个注解@RabbitListener@RabbitHandler其中RabbitListener配置监听队列的名称,RabbitHandler标记方法为处理信息的方法。

6.测试

@SpringBootTest
class DemoMqApplicationTests {
    @Autowired
    private MsgProducer msgProducer;

    class User {
        private String name;
        private int age;

        public void setName(String name) {
            this.name = name;
        }

        public String getName() {
            return name;
        }

        public int getAge() {
            return age;
        }

        public void setAge(int age) {
            this.age = age;
        }
    }

    @Test
    void contextLoads() {
        User user = new User();
        user.setAge(18);
        user.setName("zhangsan");
        msgProducer.send("hot_send_fanout_exchange", "", user);
    }

}

就这样消息的发送和接收都完成了,入门案例就到此为止了。朋友们可以尝试定义其它类型的交换机比如topic exchange 来通过routing key 指定路由到特定的消息队列里。

关于RabbitMQ的高级用法如延时队列和死信队列实现分布式事务等在后续文章为大家分享,如果对本文有任何疑惑欢迎留言,大家一起学习、共同进步!

  • 29
    点赞
  • 34
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
回答: Spring整合RabbitMQ主要包括以下几个步骤。首先,创建一个生产者类,例如ProducerTest,其中使用@Autowired注解注入RabbitTemplate对象,并使用convertAndSend方法发送消息到指定的队列,例如"spring_queue"。然后,创建一个消费者类,例如TopicTotalReceiver,使用@RabbitListener注解指定要监听的队列,例如"topic.woman",并在方法上使用@RabbitHandler注解处理接收到的消息。最后,在spring-rabbitmq-producer.xml文件中配置队列、交换机和绑定,例如使用<rabbit:queue>配置队列,使用<rabbit:direct-exchange>配置Direct类型的交换机,以及使用<rabbit:binding>进行绑定操作。这样就完成了SpringRabbitMQ整合配置。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *3* [Spring 整合RabbitMQ](https://blog.csdn.net/weixin_42947972/article/details/115219861)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}}] [.reference_item style="max-width: 50%"] - *2* [SpringBoot整合RabbitMQ](https://blog.csdn.net/K_kzj_K/article/details/106642250)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值