SpringCloud(七)——RibbitMQ安装

本文详细介绍了如何在CentOS虚拟机上安装RabbitMQ,包括erlang的安装、rabbitMQ服务器配置、可视化界面设置,并演示了基本的账户管理和服务节点操作。适合进一步理解SpringCloud Bus中RabbitMQ的运用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

SpringCloud(七)——RibbitMQ安装

前言

本篇笔记记录RibbitMQ的安装。

安装准备

  • 准备虚拟机并提供LinuxCentOS版本:

虚拟机下载

CentOS镜像下载

如果有经济的话可以选择购买一个远程服务器来安装操作,本人使用的是阿里云服务器。

虚拟机的安装使用请自行寻找教程。

  • 下载安装包:

rabbitMQ安装包下载

RabbitMQ安装与使用

安装步骤

  • 先安装 erlang
rpm -ivh erlang-22.0.7-1.el7.x86_64.rpm
  • 安装rabbitMQ:缺少依赖包,所以使用yum安装
yum install -y rabbitmq-server-3.7.18-1.el7.noarch.rpm
  • 复制启动配置文件:
cp /usr/share/doc/rabbitmq-server-3.7.18/rabbitmq.config.example /etc/rabbitmq/rabbitmq.config
  • 修改配置文件:
vim rabbitmq.config

修改第60行,去掉注释,去掉逗号

  • 加载rabbitMQ的可视化界面插件
rabbitmq-plugins enable rabbitmq_management
  • 启动rabbitMQ:
systemctl start rabbitmq-server

RabbitMQ使用

在本篇笔记中仅会记录一些针对统一配置中心的操作,如果想系统了解RabbitMQ的所有操作,请自行寻找教程学习。

访问界面

在配置启动阶段,我们开启了可视化界面的配置,访问该界面的路径是:http://${ip}:15672/

在这里插入图片描述

软件使用
  • 账户配置:

点击工具栏中的admin,可以发现User一栏中有关于用户名和密码的配置。默认提供了一个拥有至高无上权利的账号,其用户名和密码都为 guest

如果需要自行配置对应的账户可以点击下方的addUser一栏。如下图所示:

在这里插入图片描述

  • 服务节点界面:

点击工具栏中的queue,可以看到服务节点管理的界面,日后连接到RabbitMQ的服务会作为RabbitMQ的节点显示在这里。

总结

简单说明了RabbitMQ的安装,同时介绍了接下来需要使用到的相关配置。如果是从SpringCloudBus的笔记中过来的,那么请回到笔记中,继续查看对应的SpringBus的使用。

### 集成RabbitMQSpring Cloud项目 为了在Spring Cloud项目中集成RabbitMQ,可以遵循一系列配置步骤来确保消息队列服务正常工作并与其他微服务组件协同运作。首先,在项目的依赖管理文件`pom.xml`或`build.gradle`中引入必要的依赖项[^2]。 对于Maven构建工具而言,需添加如下依赖: ```xml <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-amqp</artifactId> </dependency> ``` 接着定义连接工厂以及交换器、队列等相关资源的配置类。通过创建一个名为`RabbitConfig.java`的新Java类实现这一点,并标注为`@Configuration`以便被自动扫描加载入应用上下文中。该类内部应声明至少两个方法用于初始化DirectExchange实例和Queue对象;另外还需指定绑定关系使得生产者发送的消息能够按照路由键准确无误地投递给目标消费者处理逻辑所在之处[^3]。 最后一步是在具体业务场景下编写相应的Producer与Consumer角色代码片段完成实际的数据交互过程。例如下面展示了一个简单的异步通知机制案例——当订单状态发生变更时触发事件向特定主题广播更新信息给订阅方知晓。 #### 生产者端示例 ```java import org.springframework.amqp.rabbit.core.RabbitTemplate; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Service; @Service public class OrderStatusChangePublisher { @Autowired private RabbitTemplate rabbitTemplate; public void publish(String orderId, String status){ // 构建消息体内容 String messageBody = "{\"orderId\":\""+orderId+"\",\"status\":\""+status+"\"}"; // 发送至exchange名称为order-status-exchange下的routingKey路径上 rabbitTemplate.convertAndSend("order-status-exchange", "order.status.update",messageBody); } } ``` #### 消费者端接收示例 ```java import com.rabbitmq.client.Channel; import org.springframework.amqp.core.Message; import org.springframework.amqp.rabbit.listener.api.ChannelAwareMessageListener; import org.springframework.stereotype.Component; @Component public class StatusUpdateReceiver implements ChannelAwareMessageListener { @Override public void onMessage(Message message, Channel channel) throws Exception { try{ byte[] body=message.getBody(); System.out.println(new String(body,"UTF-8")); // 手动确认消费成功 channel.basicAck(message.getMessageProperties().getDeliveryTag(),false); }catch(Exception e){ // 处理异常情况... } } } ``` 上述操作涵盖了从环境搭建直至功能模块开发整个流程的关键要点说明[^1]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值