zoukankan      html  css  js  c++  java
  • Docker部署RabbitMQ

    可以先看之前写的Docker系列的文章,对Docker有了解

    1.单机部署

    我们在Centos7虚拟机中使用Docker来安装。

    1.1.下载镜像

    方式一:在线拉取

    docker pull rabbitmq:3-management
    

    方式二:从本地加载

    在资料已经提供了镜像包:

    链接:https://pan.baidu.com/s/1bzTy6OrjFUy--pt89QNqyg
    提取码:1211

    上传到虚拟机中后,使用命令加载镜像即可:

    docker load -i mq.tar
    

    1.2.安装MQ

    执行下面的命令来运行MQ容器:

    docker run \
     -e RABBITMQ_DEFAULT_USER=itcast \
     -e RABBITMQ_DEFAULT_PASS=123321 \
     --name mq \
     --hostname mq1 \
     -p 15672:15672 \
     -p 5672:5672 \
     -d \
     rabbitmq:3-management
    

    设置了用户名,密码

    --hostname:指定容器主机名称
    --name:指定容器名称
    -p:将mq端口号映射到本地
    

    此时再浏览器中输入http://192.168.52.132:15672/就可以看到界面

    2.集群部署

    接下来,我们看看如何安装RabbitMQ的集群。

    2.1.集群分类

    在RabbitMQ的官方文档中,讲述了两种集群的配置方式:

    • 普通模式:普通模式集群不进行数据同步,每个MQ都有自己的队列、数据信息(其它元数据信息如交换机等会同步)。例如我们有2个MQ:mq1,和mq2,如果你的消息在mq1,而你连接到了mq2,那么mq2会去mq1拉取消息,然后返回给你。如果mq1宕机,消息就会丢失。
    • 镜像模式:与普通模式不同,队列会在各个mq的镜像节点之间同步,因此你连接到任何一个镜像节点,均可获取到消息。而且如果一个节点宕机,并不会导致数据丢失。不过,这种方式增加了数据同步的带宽消耗。

    我们先来看普通模式集群。

    2.2.设置网络

    首先,我们需要让3台MQ互相知道对方的存在。

    分别在3台机器中,设置 /etc/hosts文件,添加如下内容:

    192.168.150.101 mq1
    192.168.150.102 mq2
    192.168.150.103 mq3
    

    并在每台机器上测试,是否可以ping通对方:

    作者:山丘!

    -------------------------------------------

    你闻讯而来,我大喜过望,我在这等你,你又在哪呢?喜欢的话加一个“关注”呗!

    如果觉得这篇文章对你有小小的帮助的话,记得在右下角点个“推荐”哦,博主在此感谢!

  • 相关阅读:
    常见数据结构使用场景
    Java与算法之(4)
    Java与算法之(3)
    Java与算法之(2)
    Java与算法之(1)
    Maven适配多种运行环境的打包方案
    从头开始基于Maven搭建SpringMVC+Mybatis项目(4)
    从头开始基于Maven搭建SpringMVC+Mybatis项目(3)
    从头开始基于Maven搭建SpringMVC+Mybatis项目(2)
    从头开始基于Maven搭建SpringMVC+Mybatis项目(1)
  • 原文地址:https://www.cnblogs.com/mengd/p/15626949.html
Copyright © 2011-2022 走看看