Rocketmq Docker环境安装

网友投稿 621 2022-09-20

Rocketmq Docker环境安装

Rocketmq Docker环境安装

获取镜像

docker pull rocketmqinc/rocketmq:4.4.0

# 后续的name-server,broker,rocketmq-console都会使用该网络 docker network create rocketmq # 创建好网络可以使用docker inspect命令查看网络信息 docker inspect rocketmq

docker运行命令

docker run -d --name rmqnamesrv -p 9876:9876 \ --privileged=true \ --network rocketmq \ -v /home/soft/mq/data/namesrv/logs:/root/logs \ -v /home/soft/mq/data/namesrv/store:/root/store \ -e "MAX_POSSIBLE_HEAP=100000000" \ rocketmqinc/rocketmq sh mqnamesrv autoCreateTopicEnable=true

通过 docker 的 -v 参数使用 volume 功能,把你本地的目录映射到容器内的目录上。否则所有数据都默认保存在容器运行时的内存中,重启之后就又回到最初的起点。

创建broker容器

创建文件夹

mkdir /home/soft/mq/conf

在conf目录下输入命令touch broker.conf 新建文件

配置文件

vi broker.conf

brokerClusterName = DefaultCluster brokerName = broker-a brokerId = 0 deleteWhen = 04 fileReservedTime = 48 brokerRole = ASYNC_MASTER flushDiskType = ASYNC_FLUSH brokerIP1 = {本地公网 IP} #192.168.136.131

本地公网IP就是你的Linux系统IP地址,一定要设置正确,否则后面我们的RocketMq就不会启动完成。

启动容器

docker run -d --name rmqbroker -p 10911:10911 -p 10909:10909 \ --privileged=true \ --network rocketmq \ -v /home/soft/mq/data/broker/logs:/root/logs \ -v /home/soft/mq/data/broker/store:/root/store \ -v /home/soft/mq/conf/broker.conf:/opt/rocketmq/conf/broker.conf \ -e "NAMESRV_ADDR=rmqnamesrv:9876" -e "MAX_POSSIBLE_HEAP=200000000" \ rocketmqinc/rocketmq sh mqbroker autoCreateTopicEnable=true -c /opt/rocketmq/conf/broker.conf

[^]: broker.conf 的文件中的 brokerIP1 是你的 broker 注册到 Namesrv 中的 ip。如果不指定他会默认取容器中的内网 IP。除非你的应用也同时部署在网络相通的容器中,本地或容器外就无法连接 broker 服务了,进而导致类似 RemotingTooMuchRequestException 等各种异常。

docker logs -f rmqbroker

安装 rocketmq 控制台

拉取镜像

docker pull styletang/rocketmq-console-ng

启动rockermq-console容器

docker run -d \ --restart=always \ --name rmqadmin \ -e "JAVA_OPTS=-Drocketmq.namesrv.addr=10.18.60.12:9876 -Dcom.rocketmq.sendMessageWithVIPChannel=false" \ -p 9999:8080 \ -t styletang/rocketmq-console-ng

需要关闭防火墙或者开放namesrv和broker端口,如果不设置,控制台服务将无法访问namesrv服务

关闭防火墙

这一步实际上对有的同学来说是多余的,我们很多人的Linux防火墙是默认关闭的,没有必要关闭对需要的9876端口开发。

systemctl stop firewalld.service

开放指定端口

firewall-cmd --permanent --zone=public --add-port=9876/tcp firewall-cmd --permanent --zone=public --add-port=10911/tcp firewall-cmd --reload

结果

其他

欢迎有问题及时交流~以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多交流

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:Python 矩阵旋转180度(python字典)
下一篇:玩银河麒麟操作系统终端,忆国外unix主机上偶遇隔壁同胞
相关文章

 发表评论

暂时没有评论,来抢沙发吧~