RocketMq基础

转载:https://blog.csdn.net/SmallCat0912/article/details/128535930

可视化平台镜像

bash 复制代码
# 拉取镜像
docker pull rocketmqinc/rocketmq:4.3.2

# 修改镜像名字
docker tag 【镜像id】 rocketmq:4.3.2

可视化平台镜像:

bash 复制代码
# 拉取镜像
docker pull styletang/rocketmq-console-ng:1.0.0

# 修改镜像名字
docker tag 【镜像id】 rocketmq-console:1.0.0

挂载目录:

1、创建nameserver挂载目录

bash 复制代码
mkdir -p /docker/rocketmq/data/namesrv/logs /docker/rocketmq/data/namesrv/store 

2、创建broker目录

bash 复制代码
mkdir -p /docker/rocketmq/data/broker/logs /docker/rocketmq/data/broker/store

3、创建broker配置文件目录

bash 复制代码
mkdir -p /docker/rocketmq/data/conf

4、创建配置文件

bash 复制代码
vim broker.conf
bash 复制代码
# 所属集群名称,如果节点较多可以配置多个
brokerClusterName = DefaultCluster
#broker名称,master和slave使用相同的名称,表明他们的主从关系
brokerName = broker-a
#0表示Master,大于0表示不同的slave
brokerId = 0
#表示几点做消息删除动作,默认是凌晨4点
deleteWhen = 04
#在磁盘上保留消息的时长,单位是小时
fileReservedTime = 1
#有三个值:SYNC_MASTER,ASYNC_MASTER,SLAVE;同步和异步表示Master和Slave之间同步数据的机制;
brokerRole = ASYNC_MASTER
#刷盘策略,取值为:ASYNC_FLUSH,SYNC_FLUSH表示同步刷盘和异步刷盘;SYNC_FLUSH消息写入磁盘后才返回成功状态,ASYNC_FLUSH不需要;
flushDiskType = ASYNC_FLUSH
# 设置broker节点所在服务器的ip地址,也就是centosOS7的服务ip
brokerIP1 = 127.0.0.1
# 磁盘使用达到80%之后,生产者再写入消息会报错 CODE: 14 DESC: service not available now, maybe disk full
diskMaxUsedSpaceRatio=80
#自己服务器的ip
namesrvAddr= 127.0.0.1:9876
#自动创建topic
autoCreateTopicEnable=true

启动nameserver

bash 复制代码
docker run -d --restart=always --name rocketmq_nameserver -p 9876:9876 -v /docker/rocketmq/data/namesrv/logs:/root/logs -v /docker/rocketmq/data/namesrv/store:/root/store -e "MAX_POSSIBLE_HEAP=100000000" rocketmq:4.3.2 sh mqnamesrv

启动broker

bash 复制代码
docker run -d --restart=always --name rocketmq_broker --link rocketmq_nameserver:namesrv -p 10911:10911 -p 10909:10909 -v /docker/rocketmq/data/broker/logs:/root/logs -v /docker/rocketmq/data/broker/store:/root/store -v /docker/rocketmq/data/conf/broker.conf:/opt/rocketmq-4.3.2/conf/broker.conf -e "NAMESRV_ADDR=namesrv:9876" -e "MAX_POSSIBLE_HEAP=200000000" rocketmq:4.3.2 sh mqbroker -c /opt/rocketmq-4.3.2/conf/broker.conf

启动可视化平台

bash 复制代码
docker run -d --restart=always --name rocketmq_console -e "JAVA_OPTS=-Drocketmq.namesrv.addr=127.0.0.1:9876 -Dcom.rocketmq.sendMessageWithVIPChannel=false" -p 8080:8080 rocketmq-console:1.0.0

记得开启端口号:10909,10911,9876(活生生卡了我两个半小时)

相关推荐
编程彩机1 小时前
互联网大厂Java面试:从分布式架构到大数据场景解析
java·大数据·微服务·spark·kafka·分布式事务·分布式架构
小酒窝.1 小时前
【多线程】多线程打印1~100
java·多线程
君爱学习1 小时前
基于SpringBoot的选课调查系统
java
APIshop1 小时前
Java 实战:调用 item_search_tmall 按关键词搜索天猫商品
java·开发语言·数据库
血小板要健康2 小时前
Java基础常见面试题复习合集1
java·开发语言·经验分享·笔记·面试·学习方法
淼淼7632 小时前
安装jdk1.8
java·开发语言
毕设源码-朱学姐2 小时前
【开题答辩全过程】以 高校食堂餐饮管理系统的设计与实现为例,包含答辩的问题和答案
java
过期动态2 小时前
Java开发中的@EnableWebMvc注解和WebMvcConfigurer接口
java·开发语言·spring boot·spring·tomcat·maven·idea
摇滚侠2 小时前
IDEA 定义返回值快捷键
java·ide·intellij-idea
毕设源码-郭学长2 小时前
【开题答辩全过程】以 高校考勤管理系统为例,包含答辩的问题和答案
java·eclipse