17. RabbitMQ 部署指南
2022年11月8日
17. RabbitMQ 部署指南
17.1.单机部署
我们在 Centos7 虚拟机中使用 Docker 来安装。
17.1.1.下载镜像
方式一:在线拉取
docker pull rabbitmq:3-management
方式二:从本地加载
镜像包:
链接: https://pan.baidu.com/s/1nn-K9dCkdVtitEvMtpI0Dw?pwd=4jfy 提取码: 4jfy
上传到虚拟机中后,使用命令加载镜像即可:
docker load -i mq.tar
17.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
之后可以通过浏览器访问:http://192.168.202.100:15672/ 进入管理界面
账号: itcast
密码: 123321
17.2.集群部署
接下来,我们看看如何安装 RabbitMQ 的集群。
17.2.1.集群分类
在 RabbitMQ 的官方文档中,讲述了两种集群的配置方式:
- 普通模式:普通模式集群不进行数据同步,每个 MQ 都有自己的队列、数据信息(其它元数据信息如交换机等会同步)。例如我们有 2 个 MQ:mq1,和 mq2,如果你的消息在 mq1,而你连接到了 mq2,那么 mq2 会去 mq1 拉取消息,然后返回给你。如果 mq1 宕机,消息就会丢失。
- 镜像模式:与普通模式不同,队列会在各个 mq 的镜像节点之间同步,因此你连接到任何一个镜像节点,均可获取到消息。而且如果一个节点宕机,并不会导致数据丢失。不过,这种方式增加了数据同步的带宽消耗。
我们先来看普通模式集群。
17.2.2.设置网络
首先,我们需要让 3 台 MQ 互相知道对方的存在。
分别在 3 台机器中,设置 /etc/hosts 文件,设置 ip 地址:
192.168.202.101 mq1
192.168.202.102 mq2
192.168.202.103 mq3
并在每台机器上测试,是否可以 ping 通对方