docker 安装 rocketMQ详解
创建一个本地文件夹 作为挂载目录的地址
mkdir /usr/local/rocketmq
安装nameserver
-
NameServer的主要功能是为整个MQ集群提供服务协调与治理,具体就是记录维护Topic、Broker的信息,及监控Broker的运行状态。
-
理解成zookeeper的效果,只是他没用zk,而是自己写了个nameserver来替代zk
-
底层由netty实现,提供了路由管理、服务注册、服务发现的功能,是一个无状态节点
-
nameserver是服务发现者,集群中各个角色(producer、broker、consumer等)都需要定时向nameserver上报自己的状态,以便互相发现彼此,超时不上报的话,nameserver会把它从列表中剔除
-
nameserver可以部署多个,当多个nameserver存在的时候,其他角色同时向他们上报信息,以保证高可用,
-
NameServer集群间互不通信,没有主备的概念
-
nameserver内存式存储,nameserver中的broker、topic等信息默认不会持久化,所以他是无状态节点
docker run -d -p 9876:9876 -v /usr/local/rocketmq/data/namesrv/logs:/root/logs -v /usr/local/rocketmq/data/namesrv/store:/root/store --name rmqnamesrv -e "MAX_POSSIBLE_HEAP=100000000" rocketmqinc/rocketmq:4.4.0 sh mqnamesrv
安装 broker 服务器
- 理解成RocketMQ本身
- broker主要用于producer和consumer发送和接收消息
- broker会定时向nameserver提交自己的信息
- 是消息中间件的消息存储、转发服务器
- 每个Broker与Name Server集群中的所有节点建立长连接,定时(每隔30s)注册Topic信息到所有Name Server。Name Server定时(每隔10s)扫描所有存活broker的连接,如果Name Server超过2分钟没有收到心跳,则Name Server断开与Broker的连接。
创建一个本地文件夹 在文件夹中 添加配置文件 配置broker服务器
mkdir /usr/local/rocketmq/conf
创建配置文件
cd /usr/local/rocketmq/conf
vim broker.conf
把以下内容拷贝到文件中(注意修改自己的ip地址)
brokerClusterName = DefaultCluster
brokerId = 0
deleteWhen = 04
fileReservedTime = 48
brokerRole = ASYNC_MASTER
flushDiskType = ASYNC_FLUSH
brokerIP1 = 192.168.58.22(自己的linux机器的ip地址)
brokerName = broker-tanhua
安装brokerServer容器, 启动broker
docker run -d -p 10911:10911 -p 10909:10909 -v /usr/local/rocketmq/data/broker/logs:/root/logs -v /usr/local/rocketmq/rocketmq/data/broker/store:/root/store -v /usr/local/rocketmq/conf/broker.conf:/opt/rocketmq-4.4.0/conf/broker.conf --name rmqbroker --link rmqnamesrv:namesrv -e "NAMESRV_ADDR=namesrv:9876" -e "MAX_POSSIBLE_HEAP=200000000" rocketmqinc/rocketmq:4.4.0 sh mqbroker -c /opt/rocketmq-4.4.0/conf/broker.conf
安装 rocketmq 控制台
注意修改ip
docker run -di --name=rocketmq-console-ng -e "JAVA_OPTS=-Drocketmq.config.namesrvAddr=192.168.58.22:9876 -Drocketmq.config.isVIPChannel=false -Duser.timezone='Asia/Shanghai'" -v /etc/localtime:/etc/localtime -p 8001:8080 -t styletang/rocketmq-console-ng