Tachyon源码结构分析(三)

2024-06-20 17:58
文章标签 分析 源码 结构 tachyon

本文主要是介绍Tachyon源码结构分析(三),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

发布人:南京大学PASA大数据实验室


前言

在上一篇《Tachyon源码结构分析(二)》中,我们具体分析了Common模块和Client模块的源码结构,本篇接着上一篇内容介绍Master模块的源码结构分析。
 
版本选择
Tachyon目前刚刚发布了新版本0.6.1,最新的开发版仍为0.7.0-SNAPSHOT。本篇我们仍然选择Tachyon-0.6.0版本保持与前两篇同步。

官方链接:Tachyon-0.6.0


Master模块

Master模块是Tachyon的核心模块,负责管理和协调Worker与Client的正常工作。Master保存了Tachyon系统的元数据信息、文件结构、日志和镜像以及所有Worker的状态信息,同时向Client提供了关于元数据的处理操作,包括创建文件、创建表格、删除文件等。Master还提供了基于重计算的丢失文件恢复机制来容错,提供了基于Zookeeper的竞争机制来保证Master节点的健壮性,提供了心跳机制来保证Tachyon系统的可靠性。总的来说,重计算、Zookeeper以及日志和镜像机制都是为了巩固Tachyon的容错性能,我们在后续章节会针对这些核心的机制进行详细的分析。

Master模块的源码包含三个部分,分别为tachyon.mastertachyon.retrytachyon.web。这样划分的原因是tachyon.retrytachyon.web目前都是以tachyon.master包为核心的。tachyon.master包主要实现了Master的核心机制(重计算、心跳、日志和镜像等);tachyon.retry目前为tachyon.master包中MasterClient的连接操作所使用,实现了连接失败后的退避策略;tachyon.web目前都是使用tachyon.master来收集web显示的数据信息。下面按每个包来介绍Master模块具体是如何实现的。


  • tachyon.master包

    tachyon.master包是Master模块的核心,实现了Master的主要功能。该包定义了文件节点的基本结构,实现了日志和镜像机制以及心跳机制,同时定义了依赖关系的具体内容,进一步实现了重计算机制。我们现在来介绍tachyon.master的源码结构。

    从图1可以看出,tachyon.master的源码结构是错综复杂的,各个类之间的关系联系比较紧密。从图中可以看出,JsonObjectImageElementEditLogOperation的基类,抽象出日志和镜像中数据的基本存储单元。ImageElementImageElementType和参数组成,描述了元数据的静态结构(Version、 CheckpointInodeFile、 InodeFolderRawTableDependency);EditLogOperationEditLogOperationType和参数组成,描述了元数据的动态操作(ADD_BLOCKADD_CHECKPOINTCREATE_FILECOMPLETE_FILESET_PINNEDRENAMEDELETE、CREATE_RAW_TABLEUPDATE_RAW_TABLE_METADATACREATE_DEPENDENCY)。ImageElementImage中的元素,EditLogOperationEditLog中的元素,ImageEditLog一起构成JournalImageWriterRawTablesInodeDependencyMasterInfo的基类,定义了写入镜像的基本接口,也就是说InodeDependencyRawTablesMasterInfo都可以将元数据写入到镜像文件。InodeFileInodeFolder继承于Inode,分别为文件和文件夹的索引节点。文件夹的索引节点保存了子文件夹或者子文件的索引节点Id,用于构成文件的树状结构。TachyonMaster是Master节点的入口函数,调用TachyonMastermain函数开启Master的web和数据服务。从图中我们还可以看出MasterInfo是Master节点的核心,它和InodeMasterWorkerInfoRawTablesDependency、RecomputeCommandBlockInfoCounters等都直接相关,向Master服务模块提供大量的数据信息。


     图1. tachyon.master源码结构

     

  • tachyon.retry包

    我们知道当连接网络放生冲突以后,立即重连会导致依然连接冲突的概率很大。该包的功能就是定义一系列退避策略,当连接发生冲突时,退避若干个时间单位以后重新连接,使得冲突的概率最小化。目前该包只定义了一种可用的退避策略,即二进制退避策略,当第i次连接失败以后,连接被延迟0到之间随机的时间单位之后,规避依然冲突的风险。

    该包包含四个类,分别为package-infoRetryPolicySleepingRetryExponentialBackoffRetry。其中RetryPolicy定义了退避策略的接口;SleepingRetry是实现了RetryPolicy接口的抽象类;ExponentialBackoffRetry继承了RetryPolicy


  • tachyon.web包

    Tachyon作为一个分布式内存文件系统,需要向用户提供友好的交互界面使得用户能够随时把握Tachyon当前状态和当前的文件结构。tachyon.web的作用就是为Tachyon网页显示提供必要的数据信息,保证Tachyon状态能够被实时监督。而Master作为主控制节点,它收集了所有文件的元数据信息以及所有从节点的当前状态信息,所以tachyon.web基本都是从Master节点获取实时数据,因而我们把tachyon.web划分为Master模块。(在接下来的版本中,每个Worker节点也开启了web服务,每个Worker节点从本地获取web信息,所以web也可以归为Common模块)

这篇关于Tachyon源码结构分析(三)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1078853

相关文章

Linux中的more 和 less区别对比分析

《Linux中的more和less区别对比分析》在Linux/Unix系统中,more和less都是用于分页查看文本文件的命令,但less是more的增强版,功能更强大,:本文主要介绍Linu... 目录1. 基础功能对比2. 常用操作对比less 的操作3. 实际使用示例4. 为什么推荐 less?5.

spring-gateway filters添加自定义过滤器实现流程分析(可插拔)

《spring-gatewayfilters添加自定义过滤器实现流程分析(可插拔)》:本文主要介绍spring-gatewayfilters添加自定义过滤器实现流程分析(可插拔),本文通过实例图... 目录需求背景需求拆解设计流程及作用域逻辑处理代码逻辑需求背景公司要求,通过公司网络代理访问的请求需要做请

Java集成Onlyoffice的示例代码及场景分析

《Java集成Onlyoffice的示例代码及场景分析》:本文主要介绍Java集成Onlyoffice的示例代码及场景分析,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要... 需求场景:实现文档的在线编辑,团队协作总结:两个接口 + 前端页面 + 配置项接口1:一个接口,将o

IDEA下"File is read-only"可能原因分析及"找不到或无法加载主类"的问题

《IDEA下Fileisread-only可能原因分析及找不到或无法加载主类的问题》:本文主要介绍IDEA下Fileisread-only可能原因分析及找不到或无法加载主类的问题,具有很好的参... 目录1.File is read-only”可能原因2.“找不到或无法加载主类”问题的解决总结1.File

8种快速易用的Python Matplotlib数据可视化方法汇总(附源码)

《8种快速易用的PythonMatplotlib数据可视化方法汇总(附源码)》你是否曾经面对一堆复杂的数据,却不知道如何让它们变得直观易懂?别慌,Python的Matplotlib库是你数据可视化的... 目录引言1. 折线图(Line Plot)——趋势分析2. 柱状图(Bar Chart)——对比分析3

Dubbo之SPI机制的实现原理和优势分析

《Dubbo之SPI机制的实现原理和优势分析》:本文主要介绍Dubbo之SPI机制的实现原理和优势,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Dubbo中SPI机制的实现原理和优势JDK 中的 SPI 机制解析Dubbo 中的 SPI 机制解析总结Dubbo中

C#继承之里氏替换原则分析

《C#继承之里氏替换原则分析》:本文主要介绍C#继承之里氏替换原则,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录C#里氏替换原则一.概念二.语法表现三.类型检查与转换总结C#里氏替换原则一.概念里氏替换原则是面向对象设计的基本原则之一:核心思想:所有引py

Python+PyQt5实现文件夹结构映射工具

《Python+PyQt5实现文件夹结构映射工具》在日常工作中,我们经常需要对文件夹结构进行复制和备份,本文将带来一款基于PyQt5开发的文件夹结构映射工具,感兴趣的小伙伴可以跟随小编一起学习一下... 目录概述功能亮点展示效果软件使用步骤代码解析1. 主窗口设计(FolderCopyApp)2. 拖拽路径

基于Go语言实现Base62编码的三种方式以及对比分析

《基于Go语言实现Base62编码的三种方式以及对比分析》Base62编码是一种在字符编码中使用62个字符的编码方式,在计算机科学中,,Go语言是一种静态类型、编译型语言,它由Google开发并开源,... 目录一、标准库现状与解决方案1. 标准库对比表2. 解决方案完整实现代码(含边界处理)二、关键实现细

PostgreSQL 序列(Sequence) 与 Oracle 序列对比差异分析

《PostgreSQL序列(Sequence)与Oracle序列对比差异分析》PostgreSQL和Oracle都提供了序列(Sequence)功能,但在实现细节和使用方式上存在一些重要差异,... 目录PostgreSQL 序列(Sequence) 与 oracle 序列对比一 基本语法对比1.1 创建序