rabbitmq构建普通集群docker-compose方式

2024-08-28 09:18

本文主要是介绍rabbitmq构建普通集群docker-compose方式,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1.rabbitmq相关操作命令官方文档:rabbitmq操作命令
2.下载延迟插件:延迟插件下载
下载成功后,上传至安装目录,在此我新建个目录专门作为rabbitmq的安装目录
在这里插入图片描述

3.编写Dockerfile构建新镜像,把延迟插件加进去,或者不用编写Dockerfile直接启动,然后把延迟插件复制进去

以下为编写Dockerfile方式:

Dockerfile文件如下

FROM rabbitmq:3.8.10-rc.5-management-alpine
COPY  rabbitmq_delayed_message_exchange-3.8.0.ez   /plugins
RUN rabbitmq-plugins enable --offline rabbitmq_management rabbitmq_mqtt rabbitmq_federation_management rabbitmq_stomp rabbitmq_delayed_message_exchange rabbitmq_web_stomp rabbitmq_tracing

docker-compose.yml文件如下:

version: '3.9'
services:#服务名称rabbitmq:#构建镜像build: .#镜像名称image: rabbitmq:s1.0#容器名称container_name: rabbitmq#总是重启后启动restart: alwayshostname: rabbitmq01#端口映射ports:- 5672:5672- 15672:15672- 4369:4369- 25672:25672- 61613:61613#挂载volumes:- /data/rabbitmq/data:/var/lib/rabbitmq- /etc/hosts:/etc/hosts- /etc/localtime:/etc/localtimeprivileged: true#环境变量environment:- RABBITMQ_DEFAULT_USER=admin- RABBITMQ_DEFAULT_PASS=qikecheng- RABBITMQ_ERLANG_COOKIE=BGDMHWCMAFHHPOBZEYMG- RABBITMQ_NODENAME=slave01

4.以上文件编写完成,接下来开始启动单个rabbitmq

#启动并构建镜像
docker-compose up --build -d
#如果已构建过可直接使用
docker-compose up -d
#up命令会创建新的容器,down命令会删除已创建的容器
docker-compose down
#以上两个命令容器会受到影响,如果容器已构建成功,正常的停止启动应该使用以下两个命令
#停止
docker-compose stop
#启动
docker-compose start
#更多命令可查看官网或使用帮助命令
docker-compose --help
#查看启动状态
docker-compose ps

5.启动成功查看延时插件是否添加成功
在这里插入图片描述
如果不成功,则可直接进入到容器中再次运行插件启动命令

#查看容器
docker ps
#进入容器
docker exec -it 镜像id /bin/bash
#启用插件
rabbitmq-plugins enable --offline rabbitmq_management rabbitmq_mqtt rabbitmq_federation_management rabbitmq_stomp rabbitmq_delayed_message_exchange

不使用Dockerfile构建方式:
1.直接docker-compose启动rabbitmq,然后再将插件添加到容器中,再运行插件启用命令即可

docker-compose.yml

version: '3.9'
services:#服务名称rabbitmq:#镜像名称image: rabbitmq:3.8.10-rc.5-management-alpine#容器名称container_name: rabbitmq#总是重启后启动restart: alwayshostname: rabbitmq01#端口映射ports:- 5672:5672- 15672:15672- 4369:4369- 25672:25672- 61613:61613#挂载volumes:- /data/rabbitmq/data:/var/lib/rabbitmq- /etc/hosts:/etc/hosts- /etc/localtime:/etc/localtimeprivileged: true#环境变量environment:- RABBITMQ_DEFAULT_USER=admin- RABBITMQ_DEFAULT_PASS=qikecheng- RABBITMQ_ERLANG_COOKIE=BGDMHWCMAFHHPOBZEYMG- RABBITMQ_NODENAME=slave01

2.启动并添加延时插件

#启动并创建容器
docker-compose up -d
#关闭并删除容器,一般不要使用
docker-compose down
#查看启动的容器
docker ps
#将延时插件复制到rabbitmq插件目录中
docker cp rabbitmq_delayed_message_exchange-3.8.0.ez 0f12b4db0d68:/opt/rabbitmq/plugins/
#进入容器
docker exec -it 0f12b4db0d68 /bin/bash
#启用插件
rabbitmq-plugins enable --offline rabbitmq_stomp rabbitmq_delayed_message_exchange
#退出容器
exit

3.重新启动容器,延时插件才会生效

#停止
docker-compose stop
#启动
docker-compose start

4.访问控制台即可查看到容器插件已经添加成功
在这里插入图片描述

构建rabbimq集群:
1.构建前环境准备,我这里构建的集群是分布于三台独立虚拟机的,不是在一台上构建,在同一台上勾建相对简单。
2.配置三台hosts映射,hosts中必须包含刚刚构建yml中指定的虚拟hostname名称
我的三台机器配置如下:
在这里插入图片描述

3.保证三台机.erlang.cookie相同,我这里是在yml中进行了指定,但是新版本已不推荐此方式,如果不在yml中指定,则复制一台机的到另外两台机上,保持一致就行,.erlang.cookie的目录在&HOME目录下,docker-compose方式是存放在映射的目录下,如下图
在这里插入图片描述
4.随便选一台作为集群主机,将其它node节点加入到该集群主机中即可构建成普通集群了

#查看启动的容器
docker ps
#将延时插件复制到rabbitmq插件目录中
docker cp rabbitmq_delayed_message_exchange-3.8.0.ez 0f12b4db0d68:/opt/rabbitmq/plugins/
#进入容器
docker exec -it 0f12b4db0d68 /bin/bash
#停止el虚拟机
rabbitmqctl stop_app
rabbitmqctl reset
#加入集群
rabbitmqctl join_cluster master01@rabbitmq00
#再次启动
rabbitmqctl start_app
#要加入的节点执行以上操作即可加入集群

master01@rabbitmq00名称必须要与主节点一致,不然找不到,会报错,大多错误原因由此引起
在这里插入图片描述

5.加入完成,进行如任意主机页面查看,即可看到构建成功的集群
在这里插入图片描述

6.将slave01@rabbitmq01节点移除集群

rabbitmqctl forget_cluster_node slave01@rabbitmq01

7.至此普通集群已构建完成,如果想设置为镜像队列,可做如下策略设置
设置镜像队列命令:“rabbitmqctl set_policy 名称 匹配模式(正则) 镜像定义”

#设置惊醒队列
rabbitmqctl set_policy ha-all "^" '{"ha-mode":"all"}'
#查看集群状态
rabbitmqctl status

控制台查看是否成功,也可控制台设置
在这里插入图片描述
创建的测试queue
在这里插入图片描述
在这里插入图片描述

这篇关于rabbitmq构建普通集群docker-compose方式的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1114354

相关文章

Mybatis官方生成器的使用方式

《Mybatis官方生成器的使用方式》本文详细介绍了MyBatisGenerator(MBG)的使用方法,通过实际代码示例展示了如何配置Maven插件来自动化生成MyBatis项目所需的实体类、Map... 目录1. MyBATis Generator 简介2. MyBatis Generator 的功能3

Python数据处理之导入导出Excel数据方式

《Python数据处理之导入导出Excel数据方式》Python是Excel数据处理的绝佳工具,通过Pandas和Openpyxl等库可以实现数据的导入、导出和自动化处理,从基础的数据读取和清洗到复杂... 目录python导入导出Excel数据开启数据之旅:为什么Python是Excel数据处理的最佳拍档

SpringBoot项目启动后自动加载系统配置的多种实现方式

《SpringBoot项目启动后自动加载系统配置的多种实现方式》:本文主要介绍SpringBoot项目启动后自动加载系统配置的多种实现方式,并通过代码示例讲解的非常详细,对大家的学习或工作有一定的... 目录1. 使用 CommandLineRunner实现方式:2. 使用 ApplicationRunne

VUE动态绑定class类的三种常用方式及适用场景详解

《VUE动态绑定class类的三种常用方式及适用场景详解》文章介绍了在实际开发中动态绑定class的三种常见情况及其解决方案,包括根据不同的返回值渲染不同的class样式、给模块添加基础样式以及根据设... 目录前言1.动态选择class样式(对象添加:情景一)2.动态添加一个class样式(字符串添加:情

MYSQL行列转置方式

《MYSQL行列转置方式》本文介绍了如何使用MySQL和Navicat进行列转行操作,首先,创建了一个名为`grade`的表,并插入多条数据,然后,通过修改查询SQL语句,使用`CASE`和`IF`函... 目录mysql行列转置开始列转行之前的准备下面开始步入正题总结MYSQL行列转置环境准备:mysq

Linux(Centos7)安装Mysql/Redis/MinIO方式

《Linux(Centos7)安装Mysql/Redis/MinIO方式》文章总结:介绍了如何安装MySQL和Redis,以及如何配置它们为开机自启,还详细讲解了如何安装MinIO,包括配置Syste... 目录安装mysql安装Redis安装MinIO总结安装Mysql安装Redis搜索Red

Java文件上传的多种实现方式

《Java文件上传的多种实现方式》文章主要介绍了文件上传接收接口的使用方法,包括获取文件信息、创建文件夹、保存文件到本地的两种方法,以及如何使用Postman进行接口调用... 目录Java文件上传的多方式1.文件上传接收文件接口2.接口主要内容部分3.postman接口调用总结Java文件上传的多方式1

SSID究竟是什么? WiFi网络名称及工作方式解析

《SSID究竟是什么?WiFi网络名称及工作方式解析》SID可以看作是无线网络的名称,类似于有线网络中的网络名称或者路由器的名称,在无线网络中,设备通过SSID来识别和连接到特定的无线网络... 当提到 Wi-Fi 网络时,就避不开「SSID」这个术语。简单来说,SSID 就是 Wi-Fi 网络的名称。比如

多模块的springboot项目发布指定模块的脚本方式

《多模块的springboot项目发布指定模块的脚本方式》该文章主要介绍了如何在多模块的SpringBoot项目中发布指定模块的脚本,作者原先的脚本会清理并编译所有模块,导致发布时间过长,通过简化脚本... 目录多模块的springboot项目发布指定模块的脚本1、不计成本地全部发布2、指定模块发布总结多模

MySQL中my.ini文件的基础配置和优化配置方式

《MySQL中my.ini文件的基础配置和优化配置方式》文章讨论了数据库异步同步的优化思路,包括三个主要方面:幂等性、时序和延迟,作者还分享了MySQL配置文件的优化经验,并鼓励读者提供支持... 目录mysql my.ini文件的配置和优化配置优化思路MySQL配置文件优化总结MySQL my.ini文件