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

相关文章

java中4种API参数传递方式统一说明

《java中4种API参数传递方式统一说明》在Java中,我们可以使用不同的方式来传递参数给方法或函数,:本文主要介绍java中4种API参数传递方式的相关资料,文中通过代码介绍的非常详细,需要的... 目录1. 概述2. 参数传递方式分类2.1 Query Parameters(查询参数)2.2 Path

MybatisPlus中几种条件构造器运用方式

《MybatisPlus中几种条件构造器运用方式》QueryWrapper是Mybatis-Plus提供的一个用于构建SQL查询条件的工具类,提供了各种方法如eq、ne、gt、ge、lt、le、lik... 目录版本介绍QueryWrapperLambdaQueryWrapperUpdateWrapperL

idea设置快捷键风格方式

《idea设置快捷键风格方式》在IntelliJIDEA中设置快捷键风格,打开IDEA,进入设置页面,选择Keymap,从Keymaps下拉列表中选择或复制想要的快捷键风格,点击Apply和OK即可使... 目录idea设www.chinasem.cn置快捷键风格按照以下步骤进行总结idea设置快捷键pyth

Linux镜像文件制作方式

《Linux镜像文件制作方式》本文介绍了Linux镜像文件制作的过程,包括确定磁盘空间布局、制作空白镜像文件、分区与格式化、复制引导分区和其他分区... 目录1.确定磁盘空间布局2.制作空白镜像文件3.分区与格式化1) 分区2) 格式化4.复制引导分区5.复制其它分区1) 挂载2) 复制bootfs分区3)

SpringBoot返回文件让前端下载的几种方式

《SpringBoot返回文件让前端下载的几种方式》文章介绍了开发中文件下载的两种常见解决方案,并详细描述了通过后端进行下载的原理和步骤,包括一次性读取到内存和分块写入响应输出流两种方法,此外,还提供... 目录01 背景02 一次性读取到内存,通过响应输出流输出到前端02 将文件流通过循环写入到响应输出流

java敏感词过滤的实现方式

《java敏感词过滤的实现方式》文章描述了如何搭建敏感词过滤系统来防御用户生成内容中的违规、广告或恶意言论,包括引入依赖、定义敏感词类、非敏感词类、替换词类和工具类等步骤,并指出资源文件应放在src/... 目录1.引入依赖2.定义自定义敏感词类3.定义自定义非敏感类4.定义自定义替换词类5.最后定义工具类

python项目环境切换的几种实现方式

《python项目环境切换的几种实现方式》本文主要介绍了python项目环境切换的几种实现方式,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一... 目录1. 如何在不同python项目中,安装不同的依赖2. 如何切换到不同项目的工作空间3.创建项目

python项目打包成docker容器镜像的两种方法实现

《python项目打包成docker容器镜像的两种方法实现》本文介绍两种将Python项目打包为Docker镜像的方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要... 目录简单版:(一次成功,后续下载对应的软件依赖)第一步:肯定是构建dockerfile,如下:第二步

SpringBoot的内嵌和外置tomcat的实现方式

《SpringBoot的内嵌和外置tomcat的实现方式》本文主要介绍了在SpringBoot中定制和修改Servlet容器的配置,包括内嵌式和外置式Servlet容器的配置方法,文中通过示例代码介绍... 目录1.内嵌如何定制和修改Servlet容器的相关配置注册Servlet三大组件Servlet注册详

Python + Streamlit项目部署方案超详细教程(非Docker版)

《Python+Streamlit项目部署方案超详细教程(非Docker版)》Streamlit是一款强大的Python框架,专为机器学习及数据可视化打造,:本文主要介绍Python+St... 目录一、针对 Alibaba Cloud linux/Centos 系统的完整部署方案1. 服务器基础配置(阿里