本文主要描述使用Idea获取rocketMQ源码及源码的读取。

在演示搭建源码环境前,先简要描述一下RocketMQ的设计目标。

1、架构模式

  和大多数消息中间件一样,采用的是发布订阅模式,基本组件包括:消息发送者、消息服务器(消息存储)、消息消费和路由发现

2、顺序消息

  rocketMQ保证严格的顺序消息(消息到达服务器的时间)

3、消息过滤

  rocketMQ既支持在broker端的消息过滤,也支持在消费端的消息过滤

4、消息存储

  rocketMQ引入了内存机制,保证消息存储的高性能;同时将所有的topic数据存在一个文件中,保证查找消息的高效率;同时为了避免文件积累,引入了文件过期机制和存储空间报警机制。

5、消息高可用

  rocketMQ使用同步刷盘保证了异常宕机情况下数据不丢失,异步刷盘可能有少量数据丢失;单点故障情况,如果开启异步复制机制,则能保证只丢少量数据;后续会引入双写机制,以满足可靠性极高的场合。

6、消息到底低延迟

  RocketMQ在不发生消息堆积时,以长轮询模式实现准实时的消息推送模式。

7、确保消息必须被消费一次

  通过消息消费确认机制(ACK)来确保消息至少被消费一次(由于ACK信息可能会丢失等原因,所以rocket MQ无法做到准确的只被消费一次,因此有可能会有重复消费的可能)

8、回溯消息

  rocketMQ支持按时间的消息回溯(已经被消费的数据,可以重新进行消费),可以精确到毫秒

9、消息堆积

  rocketMQ使用的是磁盘存储,同时使用了内存映射机制,并且存储的物理文件为多个大小相等的逻辑文件,只要磁盘够大,就可以无限存储(实际上,如第4点所述,rocketMQ还提供了文件过期机制和存储空间报警机制,默认保留3天)

10、定时消息

  定时消息实际就是不立即消费的消息,到达一定时间后才会被消费,rocketMQ不支持任意进度的定时消息,而只zhi'chi特定的延迟级别(这是因为特定的延迟级别会有对应的队列)

11、消息重试机制

  消息如果被消费失败,则会重新投递消息

然后就是搭建阅读源码环境

1、获取源码

  VCS  -->  Checkout from Version Control  --> Git

输入git地址:https://github.com/apache/rocketmq.git ,由于我是将项目fork到我本人的gitHub目录下,所以我这里添加我自己的git地址:https://github.com/menglongdeye/rocketmq.git

gitHub  reocketMQ项目地址:https://github.com/apache/rocketmq

然后选择Maven

直接下一步

勾选JDK8,下一步

继续下一步

继续下一步

完成

编辑和下载依赖包

RocketMQ核心目录说明:

(1)acl:访问控制,包含用户、资源、权限、角色等信息。

(2)broker:broker模块(broker启动进程)

(3)client:消息客户端,包含消息生产者、消费者相关类

(4)common:公共包

(5)dev:开发者信息(非源码)

(6)distribution:部署实例文件夹(非源码)

(7)docs:存储对各个模块的说明和一些流程图片,分为中文和英文两种语音描述

(8)example:示例代码

(9)filter:消息过滤基础类

(10)logappender:日志实现相关类

(11)namesrv:namesrv相关实现类(NameSrv启动进程)

(12)openmessaging:消息开放标准

(13)remoting:远程通信模块,基于Netty

(14)srvutil:服务器工具类

(15)store:消息存储实现类相关

(16)style:checkstyle相关实现

(17)test:测试相关类

(18)tools:工具类,监控命令相关实现类

2、调试源码

启动nameSrv

配置ROCKETMQ_HOME

name 为 ROCKETMQ_HOME, value为源码保存路径(与源码目录同层级)

在 ROCKETMQ_HOME创建 conf、logs、store三个文件夹

将distribution项目中broker.conf、logback_namesrv.xml和logback_broker.xml复制到刚才创建的conf文件夹下。

修改broker.conf配置文件,新增以下配置项

# 存储路径
storePathRootDir=D:\\workSpace\\store
# commitlog存储路径
storePathCommitLog=D:\\workSpace\\store\\commitlog
# 消费队列存储路径
storePathConsumeQueue=D:\\workSpace\\store\\comsumequeue
# 消息索引存储位置
storePathIndex=D:\\workSpace\\store\\index
# checkpoint文件存储位置
storeCheckPoint=D:\\workSpace\\store\\checkpoint
# abort文件存储位置
abortFile=D:\\workSpace\\store\\abort namesrvAddr=127.0.0.1:9876

启动namesrv,当输出 The Name Server boot success. serializeType=JSON 时,说明启动成功。

3、启动broker

配置ROCKETMQ_HOME和broker配置文件

启动成功(会显示链接nameSrv的地址)

4、使用rocketmq提供的样例发送消息和消费消息

(1)发送消息

更改example\src\main\java\org\apache\rocketmq\example\quickstart\Producer.java 中 namesrv地址

启动

(2)消费消息

  启动D:\workSpace\rocketMQ\example\src\main\java\org\apache\rocketmq\example\quickstart\Consumer.java(需要配置namesrv地址)

可以看到消息消费成功。

深入理解RocketMQ(一)---阅读源码准备的更多相关文章

  1. 阅读源码(III)

    往期系列: <由阅读源码想到> <由阅读源码想到 | 下篇> Medium上有一篇文章Why You Don't Deserve That Dream Developer Jo ...

  2. 阅读源码(IV)

    往期系列: <由阅读源码想到> <由阅读源码想到 | 下篇> <阅读源码(III)> Eric S.Raymond的写于2014年的<How to learn ...

  3. How Tomcat works — 一、怎样阅读源码

    在编程的道路上,通过阅读优秀的代码来提升自己是很好的办法.一直想阅读一些开源项目,可是没有合适的机会开始.最近做项目的时候用到了shiro,需要做集群的session共享,经过查找发现tomcat的s ...

  4. Java工程师阅读源码的一些见解

    一.为何阅读源码 就是说,通过阅读源码能给你带来什么好处. 学习如何从需求-设计-实现,开阔你的思维,提升你的架构设计能力: 帮助更好地理解原理和架构设计: 帮助更快地定位线上问题BUG 可以根据自己 ...

  5. 阅读源码,从ArrayList开始

    前言 为啥要阅读源码?一句话,为了写出更好的程序. 一方面,只有了解了代码的执行过程,我们才能更好的使用别人提供的工具和框架,写出高效的程序.另一方面,一些经典的代码背后蕴藏的思想和技巧很值得学习,通 ...

  6. 从SpringBoot启动,阅读源码设计

    目录 一.背景说明 二.SpringBoot工程 三.应用上下文 四.资源加载 五.应用环境 六.Bean对象 七.Tomcat服务 八.事件模型 九.配置加载 十.数据库集成 十一.参考源码 服务启 ...

  7. 【转】使用 vim + ctags + cscope + taglist 阅读源码

    原文网址:http://my.oschina.net/u/554995/blog/59927 最近,准备跟学长一起往 linux kernel 的门里瞧瞧里面的世界,虽然我们知道门就在那,但我们还得找 ...

  8. Spring源码解析——如何阅读源码(转)

    最近没什么实质性的工作,正好有点时间,就想学学别人的代码.也看过一点源码,算是有了点阅读的经验,于是下定决心看下spring这种大型的项目的源码,学学它的设计思想. 手码不易,转载请注明:xingoo ...

  9. Spring源码解析——如何阅读源码

    最近没什么实质性的工作,正好有点时间,就想学学别人的代码.也看过一点源码,算是有了点阅读的经验,于是下定决心看下spring这种大型的项目的源码,学学它的设计思想. 手码不易,转载请注明:xingoo ...

随机推荐

  1. Spring boot Sample 005之spring-boot-profile

    一.环境 1.1.Idea 2020.1 1.2.JDK 1.8 二.目的 通过yaml文件配置spring boot 属性文件 三.步骤 3.1.点击File -> New Project - ...

  2. (二)用less+gulp+requireJs 搭建项目(gulp)

    gulp是自动化构建工具,基于node,需要安装node,如果你不了解node也没关系,先跟着来一遍再去了解node也不迟~ 首先去node官网下载安装包 1.新建项目文件夹 在目录下shift+右键 ...

  3. (Java实现) 洛谷 P1553 数字反转(升级版)

    题目描述 给定一个数,请将该数各个位上数字反转得到一个新数. 这次与NOIp2011普及组第一题不同的是:这个数可以是小数,分数,百分数,整数.整数反转是将所有数位对调:小数反转是把整数部分的数反转, ...

  4. Java实现k个数乘(cheng)(自然数的k乘积问题)

    k个数乘(cheng) 题目描述 桐桐想把一个自然数N分解成K个大于l的自然数相乘的形式,要求这K个数按从小到大排列,而且除了第K个数之外,前面(K-l)个数是N分解出来的最小自然数.例如:N=24, ...

  5. Java实现 LeetCode 304 二维区域和检索 - 矩阵不可变

    304. 二维区域和检索 - 矩阵不可变 给定一个二维矩阵,计算其子矩形范围内元素的总和,该子矩阵的左上角为 (row1, col1) ,右下角为 (row2, col2). Range Sum Qu ...

  6. SQL server怎么查找某个时间段(多个时间段)的第一个值 或 最后一个值(这里举例查找每小时的第一个值)(Convert详细方法)

    我们就举例查找每小时第一次测量的PM2.5的值吧 如下图,我们可以看出,时间非常乱,毫无规律 select min(时间) from a2 group by CONVERT(nvarchar(13), ...

  7. Java实现第九届蓝桥杯乘积为零

    乘积为零 如下的10行数据,每行有10个整数,请你求出它们的乘积的末尾有多少个零? 5650 4542 3554 473 946 4114 3871 9073 90 4329 2758 7949 61 ...

  8. Linux系统调用和ANSI C文件操作的区别

    一.在Linux下对文件操作有两种方式:Linux系统调用和ANSI C文件操作. 1.Linux系统调用调用常用于I/O文件操作,系统调用常用的函数有open.close.read.write.ls ...

  9. 面试官:说说Redis的Hash底层 我:......(来自阅文的面试题)

    redis源码分析系列文章 [Redis源码系列]在Liunx安装和常见API 为什么要从Redis源码分析 String底层实现——动态字符串SDS Redis的双向链表一文全知道 前言 hello ...

  10. PAT1040 Longest Symmetric String (25分) 中心扩展法+动态规划

    题目 Given a string, you are supposed to output the length of the longest symmetric sub-string. For ex ...