一、edits 文件

一)文件组成

  1. 一个edits文件记录了一次写文件的过程,该过程被分解成多个部分进行记录;(每条记录在hdfs中有一个编号)
  2. 每一个部分为: '<RECORD>...</RECORD>' ;
  3. 每一部分包含了:'<OPCODE> ... </OPCODE>'  和 '<DATA> ... </DATA>' 两部分内容;

二)文件内容理解

  1. 文件首: <OPCODE>OP_START_LOG_SEGMENT</OPCODE>

  • <RECORD>
    <OPCODE>OP_START_LOG_SEGMENT</OPCODE> --- 表示对一次写操作记录的开始
    <DATA>
    <TXID>138</TXID> ---------- HDFS的第138号记录
    </DATA>
    </RECORD>

  2. 文件的元数据: <OPCODE>OP_ADD</OPCODE>

    # a.xml._COPYING_: 写入 'a.xml' 文件的过程中,会先将文件写到该临时文件中,最后再将该文件重命名后存放到DN;

  •   <RECORD>
    <OPCODE>OP_ADD</OPCODE> ------------- 写文件操作
    <DATA>
    <TXID>139</TXID> ---------------- HDFS的第139号记录
    <LENGTH>0</LENGTH>
    <INODEID>16416</INODEID>
    <PATH>/a.xml._COPYING_</PATH> --- 写'a.xml'文件的过程中生成临时文件'a.xml._COPYING'
    <REPLICATION>3</REPLICATION> --- 副本数
    <MTIME>1603341874966</MTIME> --- 创建时间
    <ATIME>1603341874966</ATIME> --- 修改时间
    <BLOCKSIZE>134217728</BLOCKSIZE> --- 文件块的大小:128M
    <CLIENT_NAME>DFSClient_NONMAPREDUCE_-1327338057_1</CLIENT_NAME> ---- 来源哪个客户端
    <CLIENT_MACHINE>192.168.26.101</CLIENT_MACHINE> --------------- 通过哪个机器上传的
    <OVERWRITE>true</OVERWRITE> --------------- 是否允许被覆盖
    <PERMISSION_STATUS> ---------- 权限信息
    <USERNAME>heyc</USERNAME> ---------- 所属主
    <GROUPNAME>supergroup</GROUPNAME> ---------- 所属组
    <MODE>420</MODE> ---------- 权限大小(777最大)
    </PERMISSION_STATUS>
    <RPC_CLIENTID>3299ce83-ba14-4468-8cf8-b5edb5dea153</RPC_CLIENTID> ---- 集群ID
    <RPC_CALLID>3</RPC_CALLID>
    </DATA>
    </RECORD>

  3. 定义块id:<OPCODE>OP_ALLOCATE_BLOCK_ID</OPCODE>

  •  <RECORD>
    <OPCODE>OP_ALLOCATE_BLOCK_ID</OPCODE> ---- 表示该步为记录 “定义块ID”
    <DATA>
    <TXID>140</TXID> ---- HDFS的第140号记录
    <BLOCK_ID>1073741835</BLOCK_ID> ----- 块ID
    </DATA>
    </RECORD>

  4. 为块生成一个时间戳:<OPCODE>OP_SET_GENSTAMP_V2</OPCODE>

  • <RECORD>
    <OPCODE>OP_SET_GENSTAMP_V2</OPCODE>
    <DATA>
    <TXID>141</TXID>
    <GENSTAMPV2>1012</GENSTAMPV2>
    </DATA>
    </RECORD>

  5. 添加块: <OPCODE>OP_ADD_BLOCK</OPCODE>

  •  <RECORD>
    <OPCODE>OP_ADD_BLOCK</OPCODE>
    <DATA>
    <TXID>142</TXID>
    <PATH>/a.xml._COPYING_</PATH>
    <BLOCK>
    <BLOCK_ID>1073741835</BLOCK_ID>
    <NUM_BYTES>0</NUM_BYTES>
    <GENSTAMP>1012</GENSTAMP>
    </BLOCK>
    <RPC_CLIENTID></RPC_CLIENTID>
    <RPC_CALLID>-2</RPC_CALLID>
    </DATA>
    </RECORD>

  6. 封闭文件: <OPCODE>OP_CLOSE</OPCODE>

  •   <RECORD>
    <OPCODE>OP_CLOSE</OPCODE>
    <DATA>
    <TXID>143</TXID>
    <LENGTH>0</LENGTH>
    <INODEID>0</INODEID>
    <PATH>/a.xml._COPYING_</PATH>
    <REPLICATION>3</REPLICATION>
    <MTIME>1603341875516</MTIME>
    <ATIME>1603341874966</ATIME>
    <BLOCKSIZE>134217728</BLOCKSIZE>
    <CLIENT_NAME></CLIENT_NAME>
    <CLIENT_MACHINE></CLIENT_MACHINE>
    <OVERWRITE>false</OVERWRITE>
    <BLOCK>
    <BLOCK_ID>1073741835</BLOCK_ID>
    <NUM_BYTES>313</NUM_BYTES>
    <GENSTAMP>1012</GENSTAMP>
    </BLOCK>
    <PERMISSION_STATUS>
    <USERNAME>heyc</USERNAME>
    <GROUPNAME>supergroup</GROUPNAME>
    <MODE>420</MODE>
    </PERMISSION_STATUS>
    </DATA>
    </RECORD>

  7. 重命名临时文件 'a.xml._COPYING_' 为 'a.xml': <OPCODE>OP_RENAME_OLD</OPCODE>

  • <RECORD>
    <OPCODE>OP_RENAME_OLD</OPCODE>
    <DATA>
    <TXID>144</TXID>
    <LENGTH>0</LENGTH>
    <SRC>/a.xml._COPYING_</SRC>
    <DST>/a.xml</DST>
    <TIMESTAMP>1603341875552</TIMESTAMP>
    <RPC_CLIENTID>3299ce83-ba14-4468-8cf8-b5edb5dea153</RPC_CLIENTID>
    <RPC_CALLID>8</RPC_CALLID>
    </DATA>
    </RECORD>

二、fsimage 文件

1)文件组成

  1. fsimage 由多个 '<INodeDirectorySection> ... </INodeDirectorySection>'
  2. 每个 '<INodeDirectorySection> ... </INodeDirectorySection>' 中有多个 '<inode> ... </inode>'

2)文件内容理解

  • <inode>
    <id>16417</id>
    <type>FILE</type> ------ 文件类型:常规文件(如果是文件夹则为 'DIRECTORY')
    <name>b.xml</name>    ----- 文件名
    <replication>3</replication> --- 副本数
    <mtime>1603342078483</mtime> --- 创建时间
    <atime>1603342078253</atime> --- 修改时间
    <perferredBlockSize>134217728</perferredBlockSize> --- 块大小
    <permission>heyc:supergroup:rw-r--r--</permission> --- 权限
    <blocks> ---- 被切成了几个块
    <block> --- 一个快
    <id>1073741836</id> ----- 块的id
    <genstamp>1013</genstamp> --- 块的时间戳
    <numBytes>313</numBytes> --- 块中存放的数据的大小(该文件只有一个块,该大小即为文件大小)
    </block>
    </blocks>
    </inode>

数仓:解读 NameNode 的 edits 和 fsimage 文件内容的更多相关文章

  1. HDFS源码分析之FSImage文件内容(一)总体格式

    FSImage文件是HDFS中名字节点NameNode上文件/目录元数据在特定某一时刻的持久化存储文件.它的作用不言而喻,在HA出现之前,NameNode因为各种原因宕机后,若要恢复或在其他机器上重启 ...

  2. 数仓面试高频考点--解决hive小文件过多问题

    本文首发于公众号:五分钟学大数据 小文件产生原因 hive 中的小文件肯定是向 hive 表中导入数据时产生,所以先看下向 hive 中导入数据的几种方式 直接向表中插入数据 insert into ...

  3. hadoop源代码解读namenode高可靠:HA;web方式查看namenode下信息;dfs/data决定datanode存储位置

    点击browserFilesystem,和命令查看结果一样 当我们查看hadoop源代码时,我们看到hdfs下的hdfs-default.xml文件信息 我们查找${hadoop.tmp.dir}这是 ...

  4. Hadoop-2.4.1学习之edits和fsimage查看器

    在hadoop中edits和fsimage是两个至关关键的文件.当中edits负责保存自最新检查点后命名空间的变化.起着日志的作用,而fsimage则保存了最新的检查点信息.这个两个文件里的内容使用普 ...

  5. HAWQ取代传统数仓实践(十三)——事实表技术之周期快照

    一.周期快照简介 周期快照事实表中的每行汇总了发生在某一标准周期,如一天.一周或一月的多个度量.其粒度是周期性的时间段,而不是单个事务.周期快照事实表通常包含许多数据的总计,因为任何与事实表时间范围一 ...

  6. 技术专家说 | 如何基于 Spark 和 Z-Order 实现企业级离线数仓降本提效?

    [点击了解更多大数据知识] 市场的变幻,政策的完善,技术的革新--种种因素让我们面对太多的挑战,这仍需我们不断探索.克服. 今年,网易数帆将持续推出新栏目「金融专家说」「技术专家说」「产品专家说」等, ...

  7. 数仓1.4 |业务数仓搭建| 拉链表| Presto

    电商业务及数据结构 SKU库存量,剩余多少SPU商品聚集的最小单位,,,这类商品的抽象,提取公共的内容 订单表:周期性状态变化(order_info) id 订单编号 total_amount 订单金 ...

  8. 数仓1.1 分层| ODS& DWD层

    数仓分层 ODS:Operation Data Store原始数据 DWD(数据清洗/DWI) data warehouse detail数据明细详情,去除空值,脏数据,超过极限范围的明细解析具体表 ...

  9. 在HUE中将文本格式的数据导入hive数仓中

    今天有一个需求需要将一份文档形式的hft与fdd的城市关系关系的数据导入到hive数仓中,之前没有在hue中进行这项操作(上家都是通过xshell登录堡垒机直接连服务器进行操作的),特此记录一下. - ...

随机推荐

  1. Linux下文件的三种时间标记:访问时间、修改时间、状态改动时间 (转载)

    在windows下,一个文件有:创建时间.修改时间.访问时间. 而在Linux下,一个文件也有三种时间,分别是:访问时间.修改时间.状态改动时间. 两者有此不同,在Linux下没有创建时间的概念,也就 ...

  2. Oracle创建表、删除表、修改表、字段增删改 语句总结

    创建表: create table 表名 ( 字段名1 字段类型 默认值 是否为空 , 字段名2 字段类型 默认值 是否为空, 字段名3 字段类型 默认值 是否为空, ...... ); 创建一个us ...

  3. Screenshot 库和Collections 库

    一.screenShot 是 robot framework的标准类库,用于截取当前窗口,需要手动加载. 示例: 运行结果: 二.Collections 库 Collections 库同样为 Robo ...

  4. Maven settings配置阿里镜像

    一般只用配置三个地方 maven仓库路径 镜像 默认JDK版本 <?xml version="1.0" encoding="UTF-8"?> < ...

  5. git删除未被追踪的文件

    # 先看看会删掉哪些文件,防止重要文件被误删 git clean -n # 删除 untracked files git clean -f # 连 untracked 的目录也一起删掉 git cle ...

  6. 3D 穿梭效果?使用 CSS 轻松搞定

    背景 周末在家习惯性登陆 Apex,准备玩几盘.在登陆加速器的过程中,发现加速器到期了. 我一直用的腾讯网游加速器,然而点击充值按钮,提示最近客户端升级改造,暂不支持充值(这个操作把我震惊了~).只能 ...

  7. Linux ns 5. IPC Namespace 详解

    文章目录 1. 简介 2. 源码分析 2.1 copy_ipcs() 2.2 ipcget() 2.3 ipc_check_perms() 2.4 相关系统调用 参考文档: 1. 简介 进程间通讯的机 ...

  8. pycharm 在flask断点不停止

    For me disabling Gevent compatible option in Preferences > Build, Execution, Deployment has helpe ...

  9. 快速搭建 kvm web 管理工具 WebVirtMgr

    作者:SRE运维博客 博客地址: https://www.cnsre.cn/ 文章地址:https://www.cnsre.cn/posts/211117937177/ 相关话题:https://ww ...

  10. 线性规划之单纯形算法矩阵描述与python实现

    声明 本文为本人原创,转载请注明出处.本文仅发表在博客园,作者LightningStar. 问题描述 所有的线性规划问题都可以归约到标准型的问题,规约过程比较简单且已经超出本文范围,不再描述,可以参考 ...