微前端架构如何改变企业的开发模式与效率提升
621
2022-09-20
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小时内删除侵权内容。
发表评论
暂时没有评论,来抢沙发吧~