前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Springboot整合RabbitMQ ,用心看完这一篇就够了

Springboot整合RabbitMQ ,用心看完这一篇就够了

作者头像
I Teach You 我教你
发布2023-07-18 18:10:36
5650
发布2023-07-18 18:10:36
举报
文章被收录于专栏:王二麻子IT技术交流园地
下载安装

RabbitMQ官网:https://www.rabbitmq.com/

  1. 下载地址 RabbitMQ下载链接在Github中,可以从官网处https://www.rabbitmq.com/#getstarted点击进入,也可以直接输入地址进入:https://github.com/rabbitmq/rabbitmq-server/releases。
  2. 选择版本 Linux CentOS版本:rabbitmq-server-3.11.15-1.el8.noarch.rpm Windows版本:rabbitmq-server-3.11.15.exe
  3. 安装ErLang 由于RabbitMQ是采用ErLang语言开发的,所以需要ErLang支持,下载地址 https://www.erlang.org/downloads,选择对应的版本即可。 Windows安装ErLang相对简单,就是一直下一步即可,Linux安装较麻烦,以下介绍CentOS中安装ErLang步骤。
安装Erlang环境
  1. 检查Linux是否有erlang环境
代码语言:javascript
复制
1erl
  1. 安装GCC、GCC-C++、Openssl等模块,安装过就不需要安装了
代码语言:javascript
复制
1yum -y install make gcc gcc-c++ kernel-devel m4 ncurses-devel openssl-devel 
  1. 安装驱动UnixODBC
代码语言:javascript
复制
1yum install unixODBC unixODBC-devel
  1. 解压ErLang安装包,并进入文件夹
代码语言:javascript
复制
1tar -zxvf otp_src_25.3.2.tar.gz
2cd otp_src_25.3.2
  1. 进行编译配置
  • 5.1. 如果没有JDK,或者就是新的Linux环境用如下命令:
代码语言:javascript
复制
1./configure --prefix=/usr/local/erlang --enable-hipe --enable-threads --enable-smp-support --enable-kernel-poll --without-javac
  • 5.2. 如果有JDK环境用上面或者下面命令(建议直接用上面命令):
代码语言:javascript
复制
1./configure --prefix=/usr/local/erlang

其中APPLICATIONS DISABLED 标示是必须要安装的,另外两个项目可以忽略,我们上上面--without-javac忽略了java编译,出现这个就算配置成功了。

  1. 编译安装
代码语言:javascript
复制
1./configure --prefix=/usr/local/erlang
  1. 将erlang的启动软链到/usr/local/bin/下
  • 7.1. 配置快捷方式(比较偷懒的方法)
代码语言:javascript
复制
1ln -s /usr/local/erlang/bin/erl /usr/local/bin/
  • 7.2. 配置erlang环境
代码语言:javascript
复制
1vim /etc/profile

追加如下配置

代码语言:javascript
复制
1export ERLANG_HOME=/usr/local/erlang
2export PATH=$PATH:$ERLANG_HOME/bin
  1. 重新加载profile
代码语言:javascript
复制
1source /etc/profile
  1. 测试
代码语言:javascript
复制
1erl
安装RabbitMQ
代码语言:javascript
复制
1yum install rabbitmq-server-3.11.15-1.el8.noarch.rpm
  1. 常用命令
代码语言:javascript
复制
1# 启动
2service rabbitmq-server start
3# 查看状态
4rabbitmqctl status
5# 启用插件 (图像化界面)
6rabbitmq-plugins enable rabbitmq_management
7# 重启
8service rabbitmq-server restart
  1. 其它操作在图形化界面中均可完成,这里不做详细解释
Springboot 链接 RabbitMQ
  1. Maven依赖
代码语言:javascript
复制
1<!--rabbitmq-->
2<dependency>
3    <groupId>org.springframework.boot</groupId>
4    <artifactId>spring-boot-starter-amqp</artifactId>
5</dependency>
  1. application.yml
代码语言:javascript
复制
1spring:
2  # 配置RabbitMq 服务器
3  rabbitmq:
4    host: 127.0.0.1
5    port: 5672
6    username: guest
7    password: guest
8    # 虚拟host可以不设置,默认/
9    virtual-host: /

注意:里面的虚拟host配置项不是必须的,我自己在rabbitmq服务上创建了自己的虚拟host,所以我配置了;你们不创建,就不用加这个配置项(默认写 :virtual-host: /)。

  1. 接着我们先使用下direct exchange(直连型交换机),创建RabbitDirectProducerConfig.java(对于队列和交换机持久化以及连接使用设置,在注释里有说明,后面的不同交换机的配置就不做同样说明了):
代码语言:javascript
复制
 1package cn.xuexiluxian.crm.websocket.config;
 2
 3import cn.xuexiluxian.open.common.constant.Constants;
 4import org.springframework.amqp.core.Binding;
 5import org.springframework.amqp.core.BindingBuilder;
 6import org.springframework.amqp.core.DirectExchange;
 7import org.springframework.amqp.core.Queue;
 8import org.springframework.context.annotation.Bean;
 9import org.springframework.context.annotation.Configuration;
10
11
12/**
13 * RabbitMQ直连配置
14 */
15@Configuration
16public class RabbitDirectProducerConfig {
17    //队列 起名:TestDirectQueue
18    @Bean
19    public Queue crmProducerDirectQueue() {
20        // durable:是否持久化,默认是false,持久化队列:会被存储在磁盘上,当消息代理重启时仍然存在,暂存队列:当前连接有效
21        // exclusive:默认也是false,只能被当前创建的连接使用,而且当连接关闭后队列即被删除。此参考优先级高于durable
22        // autoDelete:是否自动删除,当没有生产者或者消费者使用此队列,该队列会自动删除。
23        // return new Queue("TestDirectQueue",true,true,false);
24        //一般设置一下队列的持久化就好,其余两个就是默认false
25        return new Queue(Constants.RABBITMQ_DEFAULT_QUEUE,true);
26    }
27
28    //Direct交换机 起名:TestDirectExchange
29    @Bean
30    DirectExchange crmProducerDirectExchange() {
31        //  return new DirectExchange("TestDirectExchange",true,true);
32        return new DirectExchange(Constants.RABBITMQ_DEFAULT_DIRECT_EXCHANGE,true,false);
33    }
34
35    //绑定  将队列和交换机绑定, 并设置用于匹配键:TestDirectRouting
36    @Bean
37    Binding bindingProducerDirect() {
38        return BindingBuilder.bind(crmProducerDirectQueue()).to(crmProducerDirectExchange()).with(Constants.RABBITMQ_DEFAULT_DIRECT_ROUTING);
39    }
40
41    @Bean
42    DirectExchange lonelyDirectExchange() {
43        return new DirectExchange("lonelyDirectExchange");
44    }
45}
  1. 测试生产者
  • 4.1. 注入
代码语言:javascript
复制
1@Autowired
2private RabbitTemplate rabbitTemplate;
  • 4.1. 发送消息
代码语言:javascript
复制
1rabbitTemplate.convertAndSend(Constants.RABBITMQ_DEFAULT_DIRECT_EXCHANGE, Constants.RABBITMQ_DEFAULT_DIRECT_ROUTING, "Hello RabbitMQ");
  1. 配置消费者
  • 5.1. Maven依赖参考上面第一步
  • 5.2. 消费者配置类RabbitDirectConsumerConfig.java
代码语言:javascript
复制
 1package cn.xuexiluxian.crm.websocket.config;
 2
 3import cn.xuexiluxian.open.common.constant.Constants;
 4import org.springframework.amqp.core.Binding;
 5import org.springframework.amqp.core.BindingBuilder;
 6import org.springframework.amqp.core.DirectExchange;
 7import org.springframework.amqp.core.Queue;
 8import org.springframework.context.annotation.Bean;
 9import org.springframework.context.annotation.Configuration;
10
11/**
12 * @Author : JCccc
13 * @CreateTime : 2019/9/3
14 * @Description :
15 **/
16@Configuration
17public class RabbitDirectConsumerConfig {
18    @Bean
19    public Queue crmConsumerDirectQueue() {
20        return new Queue(Constants.RABBITMQ_DEFAULT_QUEUE,true);
21    }
22
23    //Direct交换机
24    @Bean
25    DirectExchange crmConsumerDirectExchange() {
26        return new DirectExchange(Constants.RABBITMQ_DEFAULT_DIRECT_EXCHANGE);
27    }
28
29    //绑定:将队列和交换机绑定,并设置用于匹配键
30    @Bean
31    Binding bindingConsumerDirect() {
32        return BindingBuilder.bind(crmConsumerDirectQueue()).to(crmConsumerDirectExchange()).with(Constants.RABBITMQ_DEFAULT_DIRECT_ROUTING);
33    }
34}
  1. 监听器
代码语言:javascript
复制
1@Component
2@RabbitListener(queues = Constants.RABBITMQ_DEFAULT_QUEUE) //监听的队列名称
3public class CrmRabbitMQListener {
4    @RabbitHandler
5    public void callback(Map testMessage) {
6        System.out.println("消费者收到消息  : " + testMessage.toString());
7    }
8}
  1. 常量类
代码语言:javascript
复制
1package cn.xuexiluxian.open.common.constant;
2
3public class Constants {
4    public static final String RABBITMQ_DEFAULT_QUEUE = "xiaoluxian-crm-queue";
5    public static final String RABBITMQ_DEFAULT_DIRECT_EXCHANGE = "xiaoluxian-crm-direct_exchange";
6    public static final String RABBITMQ_DEFAULT_DIRECT_ROUTING = "xiaoluxian-crm-direct-routing";
7}
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2023/05/08 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 下载安装
  • 安装Erlang环境
  • 安装RabbitMQ
  • Springboot 链接 RabbitMQ
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档