Docker搭建RabbitMQ集群

时间:2021-10-13 10:31:30

Docker搭建RabbitMQ集群

Docker安装

官网


RabbitMQ镜像下载及配置

此博文


集群搭建

  1. 首先,我们需要启动运行RabbitMQ

    docker run -d --hostname my-rabbit -p 5671:5671 -p 5672:5672 -p 15671:15671 -p 15672:15672 -p 25672:25672 -p 4369:4369 -v $PWD/rabbitmq-data:/var/rabbitmq/lib --name my_rabbitmq rabbitmq:latest

    参数说明:

    ​ -d:后台进程运行

    ​ --hostname:主机名称

    ​ -p:端口映射

    ​ 15672:http访问端口

    ​ 5672:AMQP访问端口

    ​ -v:文件映射

    ​ --name:容器名称

  2. 启动多个RabbitMQ

    docker run -d --hostname my-rabbit -p 5671:5671 -p 5672:5672 -p 15671:15671 -p 15672:15672 -p 25672:25672 -p 4369:4369 -v $PWD/rabbitmq-data:/var/rabbitmq/lib --name my_rabbitmq1 rabbitmq:latest
    docker run -d --hostname my-rabbit -p 5673:5672 -p 15673:15672 -v $PWD/rabbitmq-data:/var/rabbitmq/lib --name my_rabbitmq2 rabbitmq:latest

    这样我们就可以使用http://ip:15672http://ip:15673 进行访问,默认账号密码均为guest.


    搭建RabbitMQ集群

    步骤一:安装RabbitMQ;

    docker run -d --hostname my-rabbit1 --name my_rabbitmq1 -p 15672:15672 -p 5672:5672 -e RABBITMQ_ERLANG_COOKIE='rabbitcookie' rabbitmq:latest

    参数说明:

    ​ -e:设置环境变量

    docker run -d --hostname my-rabbit2 --name my_rabbitmq2 -p 5673:5672 --link my_rabbitmq1:my-rabbit1 -e RABBITMQ_ERLANG_COOKIE='rabbitcookie' rabbitmq:latest
    docker run -d --hostname my-rabbit3 --name my_rabbitmq3 -p 5674:5672 --link my_rabbitmq1:my-rabbit1 --link my_rabbitmq2:my-rabbit2 -e RABBITMQ_ERLANG_COOKIE='rabbitcookie' rabbitmq:latest

    参数说明:

    ​ --link:添加链接到另一个容器

    ***注意点:

    ​ 多个容器之间使用"--link"连接,此属性不能少;

    ​ Erlang Cookie值必须相同,也就是RABBITMQ_ERLANG_COOKIE参数的值必须相同,原因见下文.

    步骤二:加入RabbitMQ节点到集群;

    设置节点1:

    docker exec -it my_rabbitmq1 /bin/bash
    rabbitmqctl stop_app
    rabbitmqctl reset
    rabbitmqctl start_app
    exit

    设置节点2:

    docker exec -it my_rabbitmq2 /bin/bash
    rabbitmqctl stop_app
    rabbitmqctl reset
    rabbitmqctl join_cluster --ram rabbit@my-rabbit1
    rabbitmqctl start_app
    exit

    设置节点3:

    docker exec -it my_rabbitmq3 /bin/bash
    rabbitmqctl stop_app
    rabbitmqctl reset
    rabbitmqctl join_cluster --ram rabbit@my-rabbit1
    rabbitmqctl start_app
    exit

    参数说明:

    ​ --ram:表示设置为内存节点,忽略次参数默认为磁盘节点.

    设置好之后,使用 http://ip:15672 进行访问,默认账号密码是guest/guest.


    配置相同Erlang Cookie

    有些特殊的情况,比如已经运行一段时间的几个单个物理机,我们在之前没有设置过相同的Erlang Cookie值,现在我们要把单个的物理机部署成集群,实现我们需要同步Erlang的Cookie值.

    1.为什么要配置相同的Erlang Cookie?

    因为RabbitMQ使用Erlang实现的,Erlang Cookie相当于不同节点之间相互通讯的秘钥,Erlang节点通过交换Erlang Cookie获得认证.

    2.Erlang Cookie的位置

    要想知道Erlang Cookie的位置,首先要取的RabbitMQ启动日志里面的home dir路径,作为根路径.可使用:

    docker logs 容器名称

    查看.

    3.复制Erlang Cookie到其他RabbitMQ节点

    获取到第一个RabbitMQ的Erlang Cookie之后,只需要把这个文件复制到其他RabbitMQ节点即可.

    物理机和容器之间复制命令如下:

    ​ 容器复制文件到物理机:

    docker cp 容器名称:容器目录 物理机目录

    ​ 物理机复制文件到容器:

    docker cp 物理机目录 容器名称:容器目录

    设置Erlang Cookie文件权限:

    chmod 600 /var/lib/rabbitmq/.erlang.cookie

注意事项

按照以上步骤搭建完成后,每个RabbitMQ服务器均需手动开启rabbitmq_management插件,方可在浏览器中输入http://localhost:15672进入RabbitMQ管理界面,在其中可看到相关节点的信息.

如何开启插件

Docker搭建RabbitMQ集群