docker安装rocketMq5x以上的版本
<div id="navCategory"><h5 class="catalogue">目录</h5><ul class="first_class_ul"><li><a href="#_label0">1.背景</a></li><li><a href="#_label1">2.拉取镜像</a></li><ul class="second_class_ul"><li><a href="#_lab2_1_0">2.1 拉取RocketMQ镜像</a></li><li><a href="#_lab2_1_1">2.2 拉取RocketMQ Dashboard镜像</a></li></ul><li><a href="#_label2">3.创建网络(如果需要多个容器互联)</a></li><ul class="second_class_ul"></ul><li><a href="#_label3">4.创建相关映射目录</a></li><ul class="second_class_ul"></ul><li><a href="#_label4">5.添加boker的配置文件</a></li><ul class="second_class_ul"></ul><li><a href="#_label5">6.启动服务</a></li><ul class="second_class_ul"></ul></ul></div><p class="maodian"><a name="_label0"></a></p><h2>1.背景</h2><p>安装RocketMQ 5.x以上的版本主要是因为新版本引入了许多性能优化、新功能以及对已有特性的增强,这些改进可以帮助提升消息队列系统的稳定性和效率。<br /><strong>1.性能提升</strong>:RocketMQ 5.x版本通常包括了对消息处理速度、吞吐量和延迟的优化,使得系统能更好地应对大规模、高并发场景。<br /><strong>2.新特性:</strong></p>
<ul><li><strong>Pop与Ack机制改进</strong>:RocketMQ 5.x对Pop(拉取消息)和Ack(确认消息)机制进行了优化,增强了消息处理的可靠性和灵活性。</li><li><strong>消息追踪与诊断</strong>:提供了更强大的消息轨迹功能,便于追踪消息流转全链路,有助于问题排查和性能分析。</li><li><strong>HTTP协议支持</strong>:5.x版本可能进一步完善了HTTP协议的支持,使得集成更加便捷,特别是在云原生和微服务架构中。</li><li><strong>定时/延时消息改进</strong>:新版本可能简化了定时消息和延时消息的管理,比如提供更灵活的创建方式,不再局限于手动使用mqadmin工具。</li></ul>
<p><strong>3.安全性与稳定性</strong>:每个大版本的迭代都会修复已知的安全漏洞,并增加新的安全特性,确保数据传输的安全性和系统的稳定性。<br /><strong>4.云原生支持</strong>:随着Kubernetes等容器编排技术的普及,RocketMQ 5.x版本可能增强了对云原生环境的支持,包括更好的Docker和K8s集成,便于在云环境中部署和管理。<br /><strong>5.易用性与兼容性</strong>:新版本通常会改进用户界面和管理工具,使得操作更为直观。同时,也会提高与其他技术和框架的兼容性,减少集成难度。<br /><strong>6.社区与生态</strong>:随着版本的更新,社区支持和第三方插件、工具也会随之跟进,使用最新版本能更好地利用这些资源。</p>
<p class="maodian"><a name="_label1"></a></p><h2>2.拉取镜像</h2>
<p class="maodian"><a name="_lab2_1_0"></a></p><h3>2.1 拉取RocketMQ镜像</h3>
<div class="jb51code"><pre class="brush:bash;">docker pull apache/rocketmq:latest
</pre></div>
<p class="maodian"><a name="_lab2_1_1"></a></p><h3>2.2 拉取RocketMQ Dashboard镜像</h3>
<div class="jb51code"><pre class="brush:bash;">docker pull apacherocketmq/rocketmq-dashboard:latest
</pre></div>
<p class="maodian"><a name="_label2"></a></p><h2>3.创建网络(如果需要多个容器互联)</h2>
<div class="jb51code"><pre class="brush:bash;">docker network create rocketmq-net
</pre></div>
<p class="maodian"><a name="_label3"></a></p><h2>4.创建相关映射目录</h2>
<div class="jb51code"><pre class="brush:bash;">mkdir -p /Users/hb24795/soft/docker/rocketMq5.0/mnt/rocketmq/namesrv/logs /Users/hb24795/soft/docker/rocketMq5.0/mnt/rocketmq/namesrv/store
mkdir -p /Users/hb24795/soft/docker/rocketMq5.0/mnt/rocketmq/broker/logs /Users/hb24795/soft/docker/rocketMq5.0/mnt/rocketmq/broker/store
mkdir -p /Users/hb24795/soft/docker/rocketMq5.0/mnt/rocketmq/broker/logs /Users/hb24795/soft/docker/rocketMq5.0/mnt/rocketmq/broker/store
</pre></div>
<p>注意你需要将/Users/hb24795/soft/这个地址修改为你自己系统的地址</p>
<p class="maodian"><a name="_label4"></a></p><h2>5.添加boker的配置文件</h2>
<p>地址:/Users/hb24795/soft/docker/rocketMq5.0/conf<br />注意:你需要将/Users/hb24795/soft/docker这个地址修改为你自己系统的地址<br />添加配置文件:broker.conf</p>
<div class="jb51code"><pre class="brush:bash;"># Licensed to the Apache Software Foundation (ASF) under one or more
# contributor license agreements.See the NOTICE file distributed with
# this work for additional information regarding copyright ownership.
# The ASF licenses this file to You under the Apache License, Version 2.0
# (the "License"); you may not use this file except in compliance with
# the License.You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
#Unless required by applicable law or agreed to in writing, software
#distributed under the License is distributed on an "AS IS" BASIS,
#WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
#See the License for the specific language governing permissions and
#limitations under the License.
# 所属集群名字
brokerClusterName=DefaultCluster
# broker 名字,注意此处不同的配置文件填写的不一样,如果在 broker-a.properties 使用: broker-a,
# 在 broker-b.properties 使用: broker-b
brokerName=broker-a
# 0 表示 Master,> 0 表示 Slave
brokerId=0
# 启动IP,如果 docker 报 com.alibaba.rocketmq.remoting.exception.RemotingConnectException: connect to <192.168.0.120:10909> failed
# 解决方式1 加上一句 producer.setVipChannelEnabled(false);,解决方式2 brokerIP1 设置宿主机IP,不要使用docker 内部IP
brokerIP1=192.168.31.169
# nameServer地址,分号分割
namesrvAddr=192.168.31.169:9876
# 在发送消息时,自动创建服务器不存在的topic,默认创建的队列数
defaultTopicQueueNums=4
# 是否允许 Broker 自动创建 Topic,建议线下开启,线上关闭 !!!这里仔细看是 false,false,false
autoCreateTopicEnable=true
# 是否允许 Broker 自动创建订阅组,建议线下开启,线上关闭
autoCreateSubscriptionGroup=true
# Broker 对外服务的监听端口
listenPort=10911
# 删除文件时间点,默认凌晨4点
deleteWhen=04
# 文件保留时间,默认48小时
fileReservedTime=120
# commitLog 每个文件的大小默认1G
mapedFileSizeCommitLog=1073741824
# ConsumeQueue 每个文件默认存 30W 条,根据业务情况调整
mapedFileSizeConsumeQueue=300000
# destroyMapedFileIntervalForcibly=120000
# redeleteHangedFileInterval=120000
# 检测物理文件磁盘空间
diskMaxUsedSpaceRatio=88
# 存储路径
# storePathRootDir=/home/ztztdata/rocketmq-all-4.1.0-incubating/store
# commitLog 存储路径
# storePathCommitLog=/home/ztztdata/rocketmq-all-4.1.0-incubating/store/commitlog
# 消费队列存储
# storePathConsumeQueue=/home/ztztdata/rocketmq-all-4.1.0-incubating/store/consumequeue
# 消息索引存储路径
# storePathIndex=/home/ztztdata/rocketmq-all-4.1.0-incubating/store/index
# checkpoint 文件存储路径
# storeCheckpoint=/home/ztztdata/rocketmq-all-4.1.0-incubating/store/checkpoint
# abort 文件存储路径
# abortFile=/home/ztztdata/rocketmq-all-4.1.0-incubating/store/abort
# 限制的消息大小
maxMessageSize=65536
# flushCommitLogLeastPages=4
# flushConsumeQueueLeastPages=2
# flushCommitLogThoroughInterval=10000
# flushConsumeQueueThoroughInterval=60000
# Broker 的角色
# - ASYNC_MASTER 异步复制Master
# - SYNC_MASTER 同步双写Master
# - SLAVE
brokerRole=ASYNC_MASTER
# 刷盘方式
# - ASYNC_FLUSH 异步刷盘
# - SYNC_FLUSH 同步刷盘
flushDiskType=ASYNC_FLUSH
# 发消息线程池数量
# sendMessageThreadPoolNums=128
# 拉消息线程池数量
# pullMessageThreadPoolNums=128
</pre></div>
<p>注意:你要将</p>
<ul><li>brokerIP1=192.168.31.169</li><li>namesrvAddr=192.168.31.169:9876</li></ul>
<p>这两个ip地址修改为你本机或公网的ip地址</p>
<p class="maodian"><a name="_label5"></a></p><h2>6.启动服务</h2>
<p><strong>1.mq</strong></p>
<div class="jb51code"><pre class="brush:bash;">docker run -d --name rmqnamesrv \
-p 9876:9876 \
--network rocketmq-net \
-v /Users/hb24795/soft/docker/rocketMq5.0/mnt/rocketmq/namesrv/logs:/root/logs \
-v /Users/hb24795/soft/docker/rocketMq5.0/mnt/rocketmq/namesrv/store:/root/store \
apache/rocketmq:latest sh mqnamesrv
</pre></div>
<p><strong>2.broker</strong></p>
<div class="jb51code"><pre class="brush:bash;">docker run -d --name rmqnamesrv \
-p 9876:9876 \
--network rocketmq-net \
-v /Users/hb24795/soft/docker/rocketMq5.0/mnt/rocketmq/namesrv/logs:/root/logs \
-v /Users/hb24795/soft/docker/rocketMq5.0/mnt/rocketmq/namesrv/store:/root/store \
apache/rocketmq:latest sh mqnamesrv
</pre></div>
<p><strong>3.dashboard</strong></p>
<div class="jb51code"><pre class="brush:bash;"> docker run -d --name rmqdashboard \
--network rocketmq-net \
-p 8080:8080 \
-e "JAVA_OPTS=-Drocketmq.namesrv.addr=192.168.31.169:9876" \
apacherocketmq/rocketmq-dashboard:latest
</pre></div>
<p>启动完成之后,可以先docker ps确保自己的服务都全部成功,在访问:ip:8080</p>
<p style="text-align:center"><img alt="" src="https://img.jbzj.com/file_images/article/202601/2026011309093685.png" /></p>
<p>出现改页面说明你配置成功</p>
<p>到此这篇关于docker安装rocketMq5x以上的版本的文章就介绍到这了,更多相关docker安装rocketMq内容请搜索琼殿技术社区以前的文章或继续浏览下面的相关文章希望大家以后多多支持琼殿技术社区!</p>
頁:
[1]