热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

RocketMq消息持久化

一、为什么要持久化:防止消息丢失。二、rmq消息持久化方式:在rmq中采用CommitLog和ConsumeQueue2个文件结合来持久化消息。其

一、为什么要持久化:

防止消息丢失。


二、rmq消息持久化方式 :

在rmq中采用 CommitLog和ConsumeQueue 2个文件结合来持久化消息。其中CommitLog是用来存放消息实体的,文件位置在store/commitLog目录下,一个broker共用同一个commitlog目录下所有文件。consumeQueue是消息的索引文件,用来指示消息在commitLog中的具体位置,文件位置在store/consumeQueue目录下,在consumeQueue目录下,会根据topic和topic包含的queueId创建二级目录,然后在该目录下创建consumeQueue索引文件。

commitLog目录结构:

commitLog文件以文件起始字节数命名,图片中第二个文件的起始字节数为1073741824=2^30=1G,说明commitLog每个文件大小为1G,把文件大小控制在1G,和java NIO中MappperedByteBuffer文件内存映射限制有关系。

commitLog文件持久化协议:

其中存放bodyLength为4个字节,可以计算出我们可以发送的最大消息体为2^23/2^20=4M

consumeQueue目录结构:

consumeQueue文件通过topic和queueId目录来加快索引速度,每个文件可以存放30W个消息索引,每个索引大小20Byte,那么每个索引文件大小为30 0000 * 20 Byte / 2^ 20 = 5.7M。

consumeQueue文件持久化协议:

consumeQueue文件中数据是以块存储的,每个块固定20Byte,其中offset为消息在CommitLog文件中的偏移量占8个Byte,size为消息体的大小占4个Byte,tagCode为消息体中tag的哈希值占8个Byte。


三、根据索引文件后去消息:

1、当我们拿到索引文件的一个数据块后,先取出前面八个字节 offset(消息在commitLog中起始地址。

2、计算消息所在的commitLog文件,offset / 1G (commitLog文件大小)获取到commitLog文件的序号。

3、通过序号获取对应的commitLog文件,计算相对起始位置,pos = offset - commitLog.formOffset (commitLog的起始字节数)。

4、通过起始位置和size获取对应的消息。


四、持久化和索引分开的目的:

1、设计初衷,顺序写入,随机读取。

2、顺序写入提升写入速度。


五、架构图:

 


推荐阅读
  • 用FileStream,是没办法下载指定文件的,不管你怎么写,都是浪费力气,最后下载的是整个html页面,包括背景,按钮,查询框,图片,虽然还是xsl格式。而且关闭文档,会弹出是否保存当前修改,如果保 ... [详细]
  • MATLAB人体行为检测与识别
    人体行为检测与识别摘要人体行为检测与识别是当前研究的重点,具有很高的研究价值和广阔的应用前景。主要应用在型人机交互、运动分析、智能监控和虚拟现实也称灵境技术ÿ ... [详细]
  • Proc是一个虚拟文件系统,在Linux系统中它被挂载于proc目录之上。Proc有多个功能,这其中包括用户可以通过它访问内核信息或用于排错,这其中一个非常有用的功能,也是Linu ... [详细]
  • 现在要针对我们需求引入检测模型,只检测人物,然后是图像能侧立,这样人物在里面占比更多,也更清晰,也不需要检测人占比小的情况,如下是针对这个需求,用的yolov3-tiny模型训练后 ... [详细]
  • 一、缓冲流缓冲流也叫高效流,是对四个基本的FileXxx流的增强,所以也是4个流,按照数据类型分为:字节缓冲流ÿ ... [详细]
  • 用python如何自定义一个包含一个参数的函数,函数从一累加到参数的值,返回累加?defcursum(n):res0foriinrange(1,n+1):res+1returnre ... [详细]
  • 10 软件源_WinQTLCartographer软件之QTL分析
    集思慧远又一QTL软件分析来啦!今天小编要跟大家分享的是WinQTLCart。WinQTLCart是北卡罗来纳州立大学发布的一款在windows下运行的QTL软件&# ... [详细]
  • 起源本文主要介绍开源项目Aria的使用。Aria项目源于15年工作中遇到的一个文件下载管理的需求,当时被下载折磨的痛不欲生,从那时起便萌生了编写一个简单 ... [详细]
  • 本文目录一览:1、北大青鸟java培训:Java集合框架的知识总结? ... [详细]
  • Android使用系统相机拍照和读取相册照片1.拍照(对于7.0以上的版本,不在允许直接访问uri)`若不指定输出路径intent.putExtra(MediaStore.EXTR ... [详细]
  • 深入分析PE可执行文件是如何进行加壳和数据混淆的
    在本文,我们将以一个可执行文件的压缩过程为例,详细讲解我在过去的两天之中时如何对它进行加壳的。就像是 ... [详细]
  • 如何使网页自适应电脑屏幕分辨率?
    在1024*768或者800*600的分辨率下可以自动调整成适用于该客户端分辨率的大小。  第一种方法:做一个网页解决问题(长了点)  如果只是因为浏览者改变了浏览器的设置,或者因为浏览器不兼容,使自 ... [详细]
  • 怎样用PHP生成html文件
    php教程|php手册html,fp,fclose,buffer,PHPphp教程-php手册html文件源码下载,ubuntu加载模块驱动,jdk和tomcat安装和配置,爬虫是 ... [详细]
  • 蜂鸟E203学习笔记(四)——取指
    1.1取值概述1.1.1如何快速取指首先要保证存储器的读延时足够小,通常使用指令紧耦合存储器(ITCM)和指令缓存器(I ... [详细]
  • nginxproxy缓存简介转自:https:mp.weixin.qq.comsDRTWuwiB6gdrRVEP6UWBAgnginx将用户已经访问过的内容保留在ng ... [详细]
author-avatar
阿芙2011
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有