首页 > 其他分享 >公司技术栈用到了RocketMQ,我对此块知识进行了回顾(初始RocketMQ)

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

时间:2024-07-27 14:53:33浏览次数:17  
标签:RocketMQ bin 用到 Broker 消息 NameServer 目录 初始

前言

作为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集群相关的知识点。

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

在这里插入图片描述

标签:RocketMQ,bin,用到,Broker,消息,NameServer,目录,初始
From: https://blog.csdn.net/qq_53847859/article/details/140530589

相关文章

  • Spring中使用到的设计模式及其源码分析
    前言众所周知,Spring框架是一个强大而灵活的开发框架。这不,上次的面试刚问到这些,没防住!!!因此下来总结一下。这篇文章主要介绍Spring中使用到的设计模式,自己做个面试复盘,同时希望能帮助到其他小伙伴儿们。工厂模式相信大家面试题都背过,Spring通过工厂模式来创建和管理Bean......
  • Java初学-8.3-代码块(实例初始化块/普通代码块和静态初始化块/静态代码块)
    代码块又称初始化块,属于类中的成员,即类的一部分。类似于方法,将逻辑语句封装在方法体中,用{}包围起来。与方法不同的是,代码块没有方法名,没有返回值,没有参数,只有方法体,而且不能通过对象或类显式调用,而是在加载类时或创建对象时隐式调用。 代码块可以用访问修饰符修饰,也可以写st......
  • 如何注释用文字初始化的“OrderedDict”的类型?
    假设我有以下内容:fromcollectionsimportOrderedDictfromdataclassesimportdataclass@dataclassclassHelloWorld:x:OrderedDict[str,int]a=OrderedDict([("a",0),("c",2),("b",1)])HelloWorld(a)<---#typeerro......
  • window系统使用经验:新买的window11初始化时最好要选择用Microsoft账户激活,而不要用loc
    Windows系统初始化时有两种类型的账户可以选择,一种时Microsoft账户,一种时local账户,Microsoft账户需要联网初始化,而local账户则和传统的初始化方式一致,即账号信息保存在本地而不和云端的Microsoft服务器上的信息同步。即使是使用local账户激活后也可以在进入系统后通过关联Micro......
  • vs2022 QT Opencv用到的一些代码
     MyFirstQT.cpp#include"MyFirstQT.h"#include"ui_MyFirstQT.h"#include<QFileDialog>#include<QMessageBox>#include<QPixmap>#include<opencv2/opencv.hpp>#include<QDebug>#include<opencv2/imgp......
  • vue 创建项目及初始化开发环境
    创建项目打开cmd命令工具、进入需要创建前端项目的文件目录中、执行创建Vue项目命令npmcreatevue执行过程中,会提示你命名新项目、以及是否会开启一些诸如Typescript和测试支持之类的可选功能、这里统一敲击回车键选择No即可、当你看到命令行提示done,标识你已经创建好......
  • 华为交换机新版系统初始化ssh
    <Huawei>load-moduleweakea<Huawei>install-moduleweakea_V200R021C10SPC600.mod<Huawei>sys[Huawei]undosshserverpublickey[Huawei]undosshservercipher[Huawei]undosshserverhmac[Huawei]undosshserverkey-exchange[Huawei]undosshs......
  • C++自学笔记18(成员初始化列表和初始化对象)
    成员列表初始化创建变量,并将其初始化是创建函数的必要部分。#include<iostream>#include<string>classEntity{private:std::stringm_name;public:Entity(){m_name="nothing"}Entity(conststd::string&name){......
  • 高速上用到的视频上云网关现在市场上真的太卷了
      先看一个需求: 这个是最近的一个招标项目上对视频网关的需求,我看了以后,真的有点不知道该怎么说。两个问题:第一个问题,目前都在执行新标准了,部标目前是128K推送到标准了,这个招标文件中还是32K,看来设计公司这个项目时,还是去年上半年的时候,但这个标发出来前,难道不应该......
  • SpringBoot集成RocketMQ
    RocketMQ的延迟消息概述举例说明延迟:PDD的拼单,大家在pdd拼单购买商品时,下单后,会有一个拼单倒计时,如果在倒计时结束的时候,还未拼单成功,那么系统就会取消到这个订单。技术实现:只需在消息生产者代码中添加一句:message.setDelayTimeLevel(3);//设置延迟的等级,即消费者接收到......