docker-RabbitMQ实践

docker-RabbitMQ实践

运行

  • 运行单个容器,脚本命令如下

    #!/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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值