使用Docker容器部署rocketmq单机的全过程
更新时间:2022年04月03日 11:15:36 作者:执意
这篇文章主要介绍了使用Docker容器部署rocketmq单机,详细介绍了查询镜像拉取镜像的命令,对Docker部署rocketmq相关知识感兴趣的朋友一起看看吧
查询镜像
docker search rocketmq NAME DESCRIPTION STARS OFFICIAL AUTOMATED foxiswho/rocketmq rocketmq 69 rocketmqinc/rocketmq Image repository for Apache RocketMQ 54 styletang/rocketmq-console-ng rocketmq-console-ng 37 apacherocketmq/rocketmq Docker Image for Apache RocketMQ 21 apache/rocketmq
拉取镜像
docker pull foxiswho/rocketmq:server #mq-server ... docker pull foxiswho/rocketmq:broker #mq-broker ... docker pull styletang/rocketmq-console-ng #客户端 ...
创建namesrv数据存储路径
mkdir -p /var/local/docker/rocketmq/namesrv/store /var/log/docker/rocketmq/namesrv
构建namesrv容器
docker run -d \ --restart=always \ --name rmqnamesrv \ -p 9876:9876 \ -v /var/log/docker/rocketmq/namesrv:/var/log \ -v /var/local/docker/rocketmq/namesrv/store:/var/store \ -e "MAX_POSSIBLE_HEAP=100000000" \ foxiswho/rocketmq \ sh mqnamesrv
创建broker数据存储路径
mkdir -p /var/local/docker/rocketmq/broker/store /var/log/docker/rocketmq/broker
创建broker配置文件
mkdir -p /etc/docker/rocketmq/conf touch broker.conf vi broker.conf
broker.conf 内容如下:
vim /docker/rocketmq/conf/broker.conf # 所属集群名称,如果节点较多可以配置多个 brokerClusterName = DefaultCluster #broker名称,master和slave使用相同的名称,表明他们的主从关系 brokerName = broker-a #0表示Master,大于0表示不同的slave brokerId = 0 #表示几点做消息删除动作,默认是凌晨4点 deleteWhen = 04 #在磁盘上保留消息的时长,单位是小时 fileReservedTime = 48 #有三个值:SYNC_MASTER,ASYNC_MASTER,SLAVE;同步和异步表示Master和Slave之间同步数据的机制; brokerRole = ASYNC_MASTER #刷盘策略,取值为:ASYNC_FLUSH,SYNC_FLUSH表示同步刷盘和异步刷盘;SYNC_FLUSH消息写入磁盘后才返回成功状态,ASYNC_FLUSH不需要; flushDiskType = ASYNC_FLUSH # 设置broker节点所在服务器的ip地址 brokerIP1 = 192.168.1.1 # 注意:改成你的IP地址
构建broker容器
docker run -d \ --restart=always \ --name rmqbroker \ --link rmqnamesrv:namesrv \ -p 10911:10911 \ -p 10909:10909 \ -v /var/local/docker/rocketmq/broker/store:/var/store \ -v /var/log/docker/rocketmq/broker:/var/logs \ -v /etc/docker/rocketmq/conf/broker.conf:/etc/rocketmq/conf/broker.conf \ -e "NAMESRV_ADDR=namesrv:9876" \ -e "MAX_POSSIBLE_HEAP=200000000" \ foxiswho/rocketmq:broker \ sh mqbroker -c /etc/rocketmq/conf/broker.conf
构建rocketmq-console-ng
docker run -d \ --name rmqconsole \ -p 8180:8080 \ --restart=always \ --link rmqserver:namesrv \ -e "JAVA_OPTS=-Drocketmq.namesrv.addr=namesrv:9876 -Dcom.rocketmq.sendMessageWithVIPChannel=false" \ -t styletang/rocketmq-console-ng
到此这篇关于使用Docker容器部署rocketmq单机的文章就介绍到这了,更多相关Docker部署rocketmq内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
Docker 本地导入镜像/保存镜像/载入镜像/删除镜像的方法
这篇文章主要介绍了Docker 本地导入镜像/保存镜像/载入镜像/删除镜像的方法,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧2018-12-12docker环境中websocket 通过nginx代理不通解决方案
这篇文章主要介绍了docker环境中websocket 通过nginx代理不通解决方案,下面是一些可能会导致 WebSocket 代理失败的问题以及相应的解决方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下2023-05-05
最新评论