docker容器启动rabbitmq
- 一、RabbitMQ部署
- 二、RabbitMQ的集群
-
- 2.1.集群分类
- [2.1.设置 /etc/hosts文件](#2.1.设置 /etc/hosts文件)
- endl
一、RabbitMQ部署
1.1.在线拉取mq镜像
java
# 在线拉取
docker pull rabbitmq:3-management
1.2.运行mq容器
java
docker run \
-e RABBITMQ_DEFAULT_USER=root \
-e RABBITMQ_DEFAULT_PASS=123456 \
--name mq \
-p 15672:15672 \
-p 5672:5672 \
-d \
rabbitmq:3-management
1.3.访问mq
java
http://192.168.147.133:15672/
二、RabbitMQ的集群
2.1.集群分类
在RabbitMQ的官方文档中,讲述了两种集群的配置方式:
- 普通模式:普通模式集群不进行数据同步,每个MQ都有自己的队列、数据信息(其它元数据信息如交换机等会同步)。例如我们有2个MQ:mq1,和mq2,如果你的消息在mq1,而你连接到了mq2,那么mq2会去mq1拉取消息,然后返回给你。如果mq1宕机,消息就会丢失。
- 镜像模式:与普通模式不同,队列会在各个mq的镜像节点之间同步,因此你连接到任何一个镜像节点,均可获取到消息。而且如果一个节点宕机,并不会导致数据丢失。不过,这种方式增加了数据同步的带宽消耗。
2.1.设置 /etc/hosts文件
java
docker run \
-e RABBITMQ_DEFAULT_USER=root \
-e RABBITMQ_DEFAULT_PASS=123456 \
--name mq \
--hostname mq1 \
-p 15672:15672 \
-p 5672:5672 \
-d \
rabbitmq:3-management
java
192.168.229.129 mq1
192.168.229.129 mq2
192.168.229.129 mq3