公司技术栈用到了RocketMQ,我对此块知识进行了回顾(初始RocketMQ)

前言

作为24届的校招生,不知道大伙儿们是否都已经到了工作岗位上。为了以后更方便的接触到公司的业务,我司为我们安排了将近一个月的实操。虽然不用敲代码,但是…

在这里插入图片描述

了解到我司使用到的技术栈,在空闲时间正好对RocketMQ这块技术做个回顾,希望能回想起那死去的记忆,同时希望能够帮助到正在学习这块知识的小伙伴儿们!

在这里插入图片描述

以下正文开始。

RocketMQ简介

和RabbitMQ不一样,RocketMQ是一款由阿里巴巴开发并开源的分布式消息中间件,它是基于纯Java实现的。RocketMQ的前身是MetaQ,后面成为Apache的顶级开源项目。

RocketMQ的设计架构非常简洁,并且功能也很强大。除此之外,作为四大消息中间件之一,RocketMQ它也支持分布式事务、消息过滤、流量控制等高级特性。接下来我们先具体了解一下RocketMQ的各个组件!

总体架构

RocketMQ的整体架构包含四个核心组件:Producer(消息生产者)、Consumer(消息消费者)、Broker(消息存储与分发服务)、NameServer(注册中心)。这些组件协同工作,他们共同实现消息的生产、存储、消费及高可用功能。

在这里插入图片描述

Producer(消息生产者)

Producer是消息发布的角色,它负责将消息发送到指定的Topic

Producer是通过NameServer获取Broker的路由信息,然后根据负载均衡策略选择具体的Broker集群队列进行消息投递。Producer还支持快速失败和低延迟的消息投递过程。

和RabbitMQ的消息生产者一样,Producer支持集群部署。在生产过程中,Producer会将消息发送到Broker的Master节点,Master节点负责将消息存储到CommitLog中,并且异步同步到Slave节点。

Consumer(消息消费者)

Consumer是消息消费的角色,负责从Broker拉取消息并进行处理。

Consumer支持两种消费模式:Push,推模式和Pull,拉模式,这两种消费模式的底层实现都基于Pull模式。Push模式是通过消费监听器自动拉取消息并推送给消费者,而Pull模式则需要消费者主动拉取消息。

Consumer可以配置为集群模式或广播模式。在集群模式下,消息只会被发送到消费者组中的一个消费者;在广播模式下,消息会发送给所有消费者。Consumer的集群部署同样依赖于业务需求。

Broker(存储消息和分发服务)

Broker是RocketMQ的核心模块,负责接收并存储消息,同时提供Push/Pull接口将消息发送给Consumer。

Broker采用主从集群部署,实现多副本存储和高可用。Master节点负责处理消息写入,而对于Slave节点,它是主动从Master节点拉取数据来保持数据一致性的。

Broker存储消息主要依赖于CommitLog、ConsumeQueue和Index这三个文件。CommitLog用于顺序存储消息实体,ConsumeQueue作为CommitLog的索引文件,用于快速定位消息,而Index文件支持按消息属性查找消息。(这个到后面细说!)

NameServer(注册中心)

NameServer是RocketMQ的注册中心,负责服务发现和路由。

它管理集群的Topic-Queue路由配置和Broker的实时配置信息。Producer和Consumer通过与NameServer建立长连接,定期拉取Topic路由信息。

NameServer集群部署,但是各个实例间不会相互通信,每个实例都保存完整的Broker路由信息。所以,单个NameServer节点的故障不会影响整个集群的正常运行。

简单生产消息并进行消费

首先在这之前我们需要下载并将RocketMQ安装到虚拟机中,这里我下载的是4.7.1版本的RocketMQ。在使用RocketMQ之前,我们先看看下载好的RocketMQ中都有什么文件。

切换到下载好的RocketMQ目录,使用ls命令列出文件和文件夹
之后分别切换到bin文件夹和conf配置文件夹,列出所有文件

bin目录

bin目录位于RocketMQ安装目录下的根位置,它包含了RocketMQ的启动脚本和工具脚本。这些脚本用于启动NameServer、Broker等组件,同时还执行一些管理任务,比如查看消息、发送消息等等。

在这里插入图片描述

mqnamesrv:用于启动NameServer服务的脚本。NameServer是RocketMQ的命名服务,用于维护Broker的地址信息和路由信息。(上文有提到)
mqbroker:用于启动Broker服务的脚本。Broker是RocketMQ的核心组件,负责消息的存储、转发等。(同上)
tools.sh:一个工具脚本,用于执行一些快速测试或管理任务,比如发送消息、接收消息等等。

conf目录

conf目录同样位于RocketMQ安装目录下的根位置,它包含了RocketMQ的配置文件。这些配置文件用于定义RocketMQ的运行参数和行为。

在这里插入图片描述

broker.conf:Broker的配置文件,包含Broker的各种运行参数,比如NameServer的地址、Broker的名称、IP地址、端口号、存储路径等等。这个文件是Broker启动时必须指定的配置文件之一。
logback_namesrv.xml 和logback_broker.xml:这两个文件是Logback的配置文件,分别用于配置NameServer和Broker的日志记录行为。它们允许用户自定义日志的级别、格式、输出位置等等。

conf目录下还包含其他的配置文件或目录,这些文件或目录可以用于不同的场景或者配置不同的组件。举个栗子,RocketMQ支持集群部署,所以在conf目录下会有用于配置集群的目录或文件,比如2m-2s-async、2m-2s-sync这些目录,这些目录内包含了用于配置不同集群模式的Broker配置文件。(这点后面细嗦)

NameServer,启动

在启动RocketMQ之前,我们需要修改bin目录下的runserver.sh⽂件。因为RocketMQ默认设置的JVM内存为4G,但是虚拟机⼀般没有4G内存,所以我们需要将大小调整为512mb或者256mb。

切换到bin目录 cd bin
修改runserver.sh文件 vim runserver.sh
找到需要修改的地方作如下修改

JAVA_OPT="${JAVA_OPT} -server -Xms512m -Xmx512m -Xmn256m -XX:MetaspaceSize=128m -XX:MaxMetaspaceSize=320m"

因为在启动RocketMQ服务之前需要先启动NameServer,所以我们在bin⽬录内使⽤静默⽅式启动。

nohup ./mqnamesrv &  

这里对上诉命令做一个解释:

nohup 命令可以忽略所有的挂断信号,使命令持续运行。它通常与 & 一起使用,以在后台运行命令。而且nohup 命令会输出重定向到一个名为 nohup.out 的文件中,除非你在命令中指定了其他输出文件。
./mqnamesrv:这部分代表要运行的程序或脚本。./mqnamesrv 是RocketMQ NameServer的启动脚本。. 表示当前目录,/ 是路径分隔符,所以 ./mqnamesrv 指的是当前目录下名为 mqnamesrv 的脚本或可执行文件
&:这个符号用于将命令置于后台执行。在命令的末尾添加 &,我们就可以让输入的命令在后台执行,这样我们就可以在同一个终端中继续执行其他命令了。

输入这个命令后,使用jps查看进程可以看到NameServer已经启动了。

在这里插入图片描述

Broker,启动

在启动Broker之前,我们同样需要修改Broker的jvm参数配置,将默认8G内存修改为512m或者256m。修改 bin/runbroker.sh ⽂件。

步骤同上!!!

JAVA_OPT="${JAVA_OPT} -server -Xms512m -Xmx512m -Xmn256m"

同时,我们可以在 conf目录下的broker.conf ⽂件中加⼊以下配置,开启⾃动创建Topic功能。

autoCreateTopicEnable=true

然后同上,以静默⽅式启动broker:

nohup ./mqbroker -n localhost:9876 &

其中,localhost也可以改为你的具体IP地址。执行命令后:

看到这里,你可能看到了这个输入文件,我们可以查看这个输出文件cat nohup.out,出现下图代表启动成功。

在这里插入图片描述

发送和接收消息

在发送/接收消息之前,我们需要告诉客户端nameserver的位置。配置环境变量NAMESRV_ADDR :

export NAMESRV_ADDR=localhost:9876

上文介绍到了RocketMQ自带的tools.sh工具,这里可以用上了。我们使用bin/tools.sh⼯具验证消息的发送,默认会发1000条消息:

./tools.sh org.apache.rocketmq.example.quickstart.Producer

在这里插入图片描述
然后使用bin/tools.sh⼯具验证消息的接收:

./tools.sh org.apache.rocketmq.example.quickstart.Consumer

在这里插入图片描述
最后关闭服务器(关闭Broker和nameserver)

./mqshutdown broker
./mqshutdown namesrv

文章小结

这篇文章主要介绍Producer、Consumer、Broker和NameServer四个核心组件,和简单的生产者生产消息到消费者对消息进行消费,后续会继续分享关于RocketMQ集群相关的知识点。

本篇文章到这里就结束了,感谢各位小伙伴们的支持!

在这里插入图片描述

  • 20
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 6
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

小威要向诸佬学习呀

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值