当前位置: 首页 > news >正文

RocketMQ系列开篇

RocketMQ系列开篇

今天开始学习RocketMQ相关系列源码。我会带着自己的目的去学习源码。所以不会像一般的技术博客一样,写一个完整的流程,介绍每一步干了啥。而是提出一个问题,然后去看代码里面是怎么实现的。说明一下,本次系列我选的是roketMQ的5.0.0版本,不同版本肯定代码都是有不同出入的,但是思想是一样的,大家可以借鉴。下面开始正题。

首先clone源码。然后就是本地运行了。

模块介绍

首先先介绍一下主要的模块

nameserv.其实就是一个注册中心。接收broker的注册,保存broker的路由地址,以供消费者和生产者查询。

broker。就是保存数据的地方。

comsumer和producter就不用说了,生产者和消费者。

只要有个简单的认识就可以了,后续我们会对每个模块进行解析。

本地运行

这里就只跑一个最简单的例子。

启动 nameserv

首先启动nameserv。找到nameserv这个模块下面的NamesrvStartup这个类,启动后会发现报错说没有roketmq_Home。所以在启动类里面加上环境变量。

ROCKETMQ_HOME=D:/project/ideaPorject/myProject/rocketmq/distribution

启动broker

找到broker模块下面的BrokerStartup,加上和上面同样的ROCKETMQ_HOME的环境变量,然后启动

启动comsumer和producer

在example模块下面有个quickstart目录,里面有消费者和生产者。他们的group不一样,我们先改成一样。然后先启动comsumer,再启动producer。就会发现控制台有消费和打印出来了。

至此,我们的项目就启动完成了。

http://www.lryc.cn/news/34609.html

相关文章:

  • logback无法删除太久远的日志文件?logback删除日志文件源码分析
  • 【MyBatis-Plus】基于@Version注解的乐观锁实现
  • ubuntu20.04搭建detectron2环境
  • Navicate远程连接Linux上docker安装的MySQL容器
  • 基于Jetson NX的模型部署
  • 【PaddlePaddle onnx】PaddlePaddle导出ONNX及模型可视化教程
  • 虹科案例 | 如何可持续的对变压器进行温度监控?
  • Go之入门(特性、变量、常量、数据类型)
  • 第九届省赛——8等腰三角形(找规律)
  • 【产品设计】ToB 增删改查显算传
  • MySQL(二)视图、锁、存储过程、触发器、锁以及常用工具
  • CorelDRAW Graphics Suite2023更新内容介绍
  • 2021牛客OI赛前集训营-提高组(第三场) T1变幻
  • 你还在使用if-else写代码吗,今天带你领略下策略模式的魅力!
  • Leetcode. 21 合并两个有序列表
  • 使用 Wall 教你搭建 照片墙 和 视频墙
  • 0103 MySQL06
  • 【UE4 RTS游戏】04-摄像机运动_鼠标移动到视口边缘时移动Pawn
  • 147597-66-8,p-SCN-Bn-NOTA,NOTA-P-苯-NCS新型双功能螯合剂
  • JDK解压安装及idea开发工具配置
  • 使用Ubuntu中的Docker部署Remix
  • 【MySQL】P9 多表查询(3) - 子查询
  • SpringMVC中的拦截器不生效的问题解决以及衍生出的WebMvcConfigurationSupport继承问题思考
  • 【量化交易笔记】3.实现数据库保存数据
  • [数据结构]:15-堆排序(顺序表指针实现形式)(C语言实现)
  • 蓝桥 卷“兔”来袭编程竞赛专场-02破解曾公亮密码 题解
  • CSS定位
  • python sympy库
  • 达梦数据库统计信息的导出导入
  • 信息系统基本知识(六)