docker 安装 rocketMQ详解

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

开放 9876、10909、8001端口

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值