docker-RabbitMQ实践
- RabbitMQ官网:http://www.rabbitmq.com/
- docker hub地址:https://hub.docker.com/_/rabbitmq?tab=description
运行
-
运行单个容器,脚本命令如下
#!/bin/sh docker run -it -d \ --hostname my-rabbit \ -v $PWD/data:/var/lib/rabbitmq \ -e RABBITMQ_DEFAULT_USER=admin \ -e RABBITMQ_DEFAULT_PASS=123456 \ -e RABBITMQ_ERLANG_COOKIE='rabbitcookie' \ -p 15672:15672 \ -p 5672:5672 \ --restart always \ --name rabbitmq \ rabbitmq:3.7.11-management
docker下分布式集群方式
目标
- 在192.168.25.105部署my-rabbit1,在192.168.25.169部署my-rabbit2,将其组成集群
此处的ip和名称为举例用,具体请根据自己服务器的情况定
步骤
-
在192.168.25.105下创建名为hosts文件,内容如下
192.168.25.105 my-rabbit1 192.168.25.169 my-rabbit2
这一步的作用主要是为了能将两个rabbitmq组成集群
-
通过如下shell脚本运行my-rabbit1
#!/bin/sh docker run -it -d \ --hostname my-rabbit1 \ -v /etc/localtime:/etc/localtime:ro \ -v $PWD/data:/var/lib/rabbitmq \ -v $PWD/hosts:/etc/hosts \ -e RABBITMQ_DEFAULT_USER=admin \ -e RABBITMQ_DEFAULT_PASS=123456 \ -e RABBITMQ_ERLANG_COOKIE='rabbitcookie' \ --net host \ --restart always \ --name rabbitmq1 \ rabbitmq:3.7.11-management
- 其中/etc/localtime:/etc/localtime:ro主要是解决时区问题,$PWD/hosts表示当前目录下的hosts文件(即刚刚创建的hosts文件),RABBITMQ_DEFAULT_USER为登录密码,net host 则是为了组建集群时能让其他节点加入所要采取的网络模式,hostname 和name可以自己随便取,这里就取为my-rabbit1和rabbitmq1了
-
在192.168.25.169下创建名为hosts文件,内容如下
192.168.25.105 my-rabbit1 192.168.25.169 my-rabbit2
-
通过如下shell脚本运行my-rabbit2
#!/bin/sh docker run -it -d \ --hostname my-rabbit2 \ -v /etc/localtime:/etc/localtime:ro \ -v $PWD/data:/var/lib/rabbitmq \ -v $PWD/hosts:/etc/hosts \ -e RABBITMQ_DEFAULT_USER=admin \ -e RABBITMQ_DEFAULT_PASS=123456 \ -e RABBITMQ_ERLANG_COOKIE='rabbitcookie' \ --net host \ --restart always \ --name rabbitmq2 \ rabbitmq:3.7.11-management
-
以上则运行两个rabbitmq了,但此时它们还是各自独立的,因此必须要让其中一个加入到另一个中去
-
在192.168.25.169机器中执行以下命令进入my-rabbit2
docker exec -it rabbitmq2 /bin/bash
-
进入容器内部后执行以下命令加入集群
rabbitmqctl stop_app rabbitmqctl join_cluster rabbit@my-rabbit1 rabbitmqctl start_app
-
其中第二行就是使用命令join_cluster 加入到第一个节点rabbit@my-rabbit1(格式为rabbit@自己定义的hostname,本例即为my-rabbit1)
-
此时再访问下 http://192.168.25.105:15672, http://192.168.25.169:15672, 发现页面已经会显示两个节点rabbit@my-rabbit1和rabbit@my-rabbit2了,此时在其中一个节点添加exchanges,会发现另一个节点也能查看到刚刚加的exchanges,说明集群已经成功
-
此时如果将容器rabbitmq2整个移除(不是停止)后再运行rabbitmq2,会发现不用再执行一遍加入集群的命令,原因是之前的shell脚本中已有对卷的存储
参考
RabbitMQ系列(五)使用Docker部署RabbitMQ集群 - 王磊的博客 - 博客园
https://www.cnblogs.com/vipstone/p/9362388.html
rabbitmq - Docker Hub
https://hub.docker.com/_/rabbitmq?tab=description
Messaging that just works — RabbitMQ
http://www.rabbitmq.com/
(9条消息)Docker分布式部署RabbitMQ集群 - qq_337694336 - CSDN博客
https://blog.csdn.net/qq_32488647/article/details/81941491
Docker分布式部署RabbitMQ集群 - 简书
https://www.jianshu.com/p/93cada3d264b