当前位置: 首页 > news >正文

SpringBoot中整合RabbitMQ(测试+部署上线 最完整)

一、RabbitMQ安装

由于在测试环境中,我们现在虚拟机上基于docker安装mq

docker run \-e RABBITMQ_DEFAULT_USER=quick \-e RABBITMQ_DEFAULT_PASS=123 \-v mq-plugins:/plugins \--name mq \--hostname mq \-p 15672:15672 \-p 5672:5672 \--network your-net\-d \rabbitmq:3.8-management

在docker环境上运行改指令

前两个是登录的用户名密码

network是连接的网络,如果用默认网络的话就不需要写

最后一个是版本,这个是目前测试的版本

二、启动RabbitMQ

由于目前是测试阶段,这里我使用之前学习的时候的版本。

创建新用户后重新登陆,然后创建一个单独的 Virtual Hosts (虚拟主机)来进行隔离。

三、编写Java代码\

1、引入依赖
        <!--rabbitmq--><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-amqp</artifactId></dependency>
2、配置yml
spring:rabbitmq:host: ${quick.rabbitmq.host}port: ${quick.rabbitmq.port} # 端口virtual-host: ${quick.rabbitmq.virtual-host} # 虚拟主机username: ${quick.rabbitmq.username} # 用户名password: ${quick.rabbitmq.password} # 密码
quick:rabbitmq:host: 192.168.75.101 #服务器ip地址(此处为虚拟机地址)port: 5672 # 端口virtual-host: /xxx # 虚拟主机username: xxx # 用户名password: xxx # 密码

3、配置消息转换器
/*** 配置消息转换器*/
@Configuration
@ConditionalOnClass(RabbitTemplate.class) //有RabbitTemplate依赖才会生效,否则不生效
public class MqConfig {@Beanpublic MessageConverter messageConverter(){//使用json序列化发送消息return new Jackson2JsonMessageConverter();}
}
4、编写接收方接收消息

/*** 接收消息*/
@Component
@RequiredArgsConstructor
public class StoreListener {private final IStoreService storeService;@RabbitListener(bindings = @QueueBinding(value = @Queue(name = "store.addFavorite.success.queue", durable = "true"), // 队列 起名规则(服务名+业务名+成功+队列),durable持久化exchange = @Exchange(name = "addFavorite.direct"), // 交换机名称,交换机默认类型就行direct,所以不用配置directkey = "addFavorite.success" // 绑定的key))public void listenAddFavoriteCountsSuccess(Long storeId){storeService.updateStoreFavoriteUsersCountAdd1(storeId);}}

虽然代码里面也已经解释了,但是下面也再解释一下:

value:是队列信息。起名规则(服务名+业务名+成功+队列),durable表示持久化
exchange:是交换机名称。起名规则是(业务名+direct),和发送方一致
key:绑定的key。起名规则是(业务名+success),表示成功的key,和发送方一致

起名规则是个人而定

5、编写发送方发送消息

@Transactional@Overridepublic void add(Long storeId) {Favorite favorite = Favorite.builder().storeId(storeId).userId(BaseContext.getCurrentId()).build();Favorite one = Db.getOne(favorite);if (one!=null){throw new FavoriteException(MessageConstant.COLLECTION_BE_REPEAT);}// 更新收藏表favoriteMapper.insert(favorite);// 更新商品表,收藏数+1//storeService.updateStoreFavoriteUsersCountAdd1(storeId);// 发送消息 (交换机+绑定的key和发送的消息)try {rabbitTemplate.convertAndSend("addFavorite.direct","addFavorite.success",storeId);} catch (Exception e) {log.error("发送添加收藏消息失败,店铺id:{}",storeService,e);}}

虽然代码里面也已经解释了,但是下面也再解释一下:

"addFavorite.direct":是交换机名称,和接收方一致
"addFavorite.success":是绑定的key,和接收方一致
storeId:是发送的信息

6、小程序验证

点击收藏。

在RabbitMQ的界面中队列也有一条消息出现,说明mq实现异步通讯成功。

该案例是收藏商品后完成收藏表插入语句后,还要去商品表更新商品表,更新该商品的被收藏数加一,但是如果同步通讯的话,响应会有延迟,可能会对性能造成一定影响,但是通过异步通讯,不需要实时响应,就会对性能有一定的优化。

三、宝塔中安装RabbitMQ

1、下载erlang

RabbitMQ服务端是由并发式语言Erlang编写的,所以安装RabbitMQ的之前需要安装Erlang,保证所需要的环境。

安装之前注意版本兼容问题:Erlang Version Requirements | RabbitMQ

安装erlang地址:https://www.erlang-solutions.com/downloads/#

(1)查看rabbitmq的版本

先去宝塔查看rabbitmq的版本:

(2)查找erlang兼容版本

然后去找到版本兼容的erlang版本:Erlang Version Requirements | RabbitMQ

(3)安装RPM包

去下载:https://www.erlang-solutions.com/downloads/#

 

下载后拿到rpm文件:

注意:这里没有下载的版本,下载需要与自己的版本一致,如果发现启动不了RabbitMQ,请看后面的启动RabbitMQ。

注意!注意!注意!

2、前往宝塔面板

进入tmp目录,将之前的rpm包放进去。

3、安装RabbitMQ

在软件商店中安装RabbitMQ

出现问题:

看到报错日志,我又去下载报错日志里面的版本。

再次去:https://www.erlang-solutions.com/downloads/#

我是centos7,所以下载该版本。那边有点不人性化,我尝试了几次才下载到自己的版本。

将之前的哪个rmp文件删掉,再将刚刚下载的rpm文件重命名再次放入tmp目录中

上面我重命名错了,只记得修改后面,下面是再次修改后的结果。

卸载rabbitmq,然后再重新安装一次。

还是出现报错:

出现了这个报错,很莫名其妙,然后我就去用docker安装,有解决办法的可以评论一下。

在其他教程到这一步已经可以了,可以参考下面两篇博客:

宝塔面板安装RabbitMQ(已解决)_宝塔安装rabbitmq-CSDN博客

宝塔安装rabbitMQ实战-CSDN博客

四、docker中安装rabbitmq

1、安装docker
2、配置docker镜像加速
# 创建目录
mkdir -p /etc/docker# 复制内容,注意把其中的镜像加速地址改成你自己的
tee /etc/docker/daemon.json <<-'EOF'
{"registry-mirrors": ["http://hub-mirror.c.163.com","https://mirrors.tuna.tsinghua.edu.cn","http://mirrors.sohu.com","https://ustc-edu-cn.mirror.aliyuncs.com","https://ccr.ccs.tencentyun.com","https://docker.m.daocloud.io","https://docker.awsl9527.cn"]
}
EOF# 重新加载配置
systemctl daemon-reload# 重启Docker
systemctl restart docker
3、拉取RabbitMQ镜像
docker pull rabbitmq

4、运行RabbitMQ
docker run \-e RABBITMQ_DEFAULT_USER=quick \-e RABBITMQ_DEFAULT_PASS=quick \-v mq-plugins:/plugins \--name mq \--hostname mq \-p 15672:15672 \-p 5672:5672 \-d \rabbitmq

5、查看镜像和容器
docker images
docker ps

到这里已经是成功在docker中装好mq容器了

但是在我访问http://主机ip:15672的时候却无法访问,即使我开放了服务器的安全组。后来猜到应该是客户端服务可能是没开启,在之前宝塔软件里面好像有看过这个东西。

6、开放客户端服务

在mq容器中打开终端

列出所有可用的插件:

rabbitmq-plugins list

找到rabbitmq_management:

开启rabbitmq_management:

rabbitmq-plugins enable rabbitmq_management

然后再访问客户端,成功访问:

7、登录RabbitMQ客户端

这里显示有些特性标志未开启,我们可以去开启那些标志。

参考博客:Docker RabbitMQ安装_all stable feature flags must be enabled after com-CSDN博客

8、创建虚拟主机

创建一个单独的虚拟主机来进行隔离,这里可以参考前面在虚拟机上的操作。

五、部署项目验证

参考我之前的博客:记录部署项目《庆自提》完整流程-CSDN博客

修改yml配置文件,修改下面的消息:

  rabbitmq:host: ${quick.rabbitmq.host}port: ${quick.rabbitmq.port} # 端口virtual-host: ${quick.rabbitmq.virtual-host} # 虚拟主机username: ${quick.rabbitmq.username} # 用户名password: ${quick.rabbitmq.password} # 密码

在已经上线的小程序测试~~

目前只有一个人收藏,现在去测试一下。

收藏成功,去看一下数据库,查看是否更新。

去查看mq客户端:

成功更新,说明使用RabbitMQ实现异步通讯成功。

在配置mq过程中遇到许许多多的bug和问题,改了很久很久,如果里面有哪些不足的欢迎指正和建议!!!

http://www.lryc.cn/news/421699.html

相关文章:

  • 算法板子:线性DP——算出三角形中的最大路径值、求最长上升子序列、求最长公共子序列
  • 【C++】值传递
  • 工业三防平板助力MES系统打造工厂移动式生产管理
  • keepalived+nginx实现的简单高可用故障转移
  • openai api使用
  • 带你走进haproxy的世界
  • STM32--中断使用(超详细!)
  • 【深度学习实践】基于深度学习的图像去雾算法-ChaIR-实践
  • 《乳腺密度高的女性中,使用AI辅助的乳腺X线筛查与补充筛查超声的比较研究》| 文献速递-基于深度学习的乳房、前列腺疾病诊断系统
  • crm 销售管理系统有哪些?国内外排名前十盘点
  • package-lock.json 要提交到git吗?
  • 算法学习day32
  • 知识与智慧
  • 使用FFmpeg实现摄像头RTMP实时推流
  • 使用 LabVIEW 编程更改 IMAQ/IMAQdx 接口的相机文件
  • [后端代码审计] PHP 基础学习
  • 【OpenCV C++20 学习笔记】直方图计算-split, calcHist, normalize
  • js入门经典学习小结
  • nps内网穿透之——腾讯云服务器和linux虚拟机
  • 大数据知识点
  • 【计算机毕设项目】2025级计算机专业项目推荐 (前后端Web项目)
  • 【MySQL】2.MySQL实际操作
  • Winform画圆以及无边框窗体的移动
  • 如何高效记录并整理编程学习笔记?
  • docker的安装和常用命令
  • haproxy 7000字配图超详细教程 从小白到入门
  • 使用 LangChain 掌握检索增强生成 (RAG) 的终极指南:5、将自然语言问题转换为结构化查询
  • 浅析JavaScript 堆内存及其通过 Chrome DevTools 捕获堆快照的方法
  • C++学习笔记----2、使用C++进行优雅编程(五)----命名
  • Element UI顶部导航栏与左侧导航栏联动实现~