HBase源码分析(从Flush到HFile)

Get Started. It's Free
or sign up with your email address
HBase源码分析(从Flush到HFile) by Mind Map: HBase源码分析(从Flush到HFile)

1. writer.appendMetadata()

2. writer.close()

2.1. finishBlock()

2.2. 写索引块数据

2.3. writeIndexBlocks()

2.3.1. 如果rootChunk大于maxChunkSize,分裂成子block

2.3.2. writeRoot()

2.3.3. writeHeaderAndData()

2.4. 写meta block

2.5. 写file info

2.6. 写trailer

3. HRegion flusher.commit()

3.1. commitFile()

3.1.1. 获得HFile临时文件名

3.1.2. 重命名临时文件

3.2. updateStorefiles()

3.2.1. 把StoreFile更新至列表中

3.2.2. StoreFile列表排序

3.2.3. clearSnapshot()

4. HFileWriterV2 append(kv)

4.1. 检查key顺序

4.2. key不同时checkBlockBoundary()

4.2.1. 检查是否到达block边界(默认64K)

4.2.2. 到达边界finishBlock()

4.2.2.1. 获得data block的偏移量

4.2.2.2. writeHeaderAndData()写数据

4.2.2.2.1. ensureBlockReady

4.2.2.2.2. 写入onDiskChecksum

4.2.2.3. 写入索引dataBlockIndexWriter.addEntry()

4.2.2.3.1. add()

4.2.2.4. 缓存块doCacheOnWrite()

4.2.3. 写入索引块writeInlineBlocks

4.2.3.1. 缓存块cacheOnWrite()

4.2.3.2. 写非root索引块writeInlineBlock()

4.2.3.2.1. curInlineChunk.writeNonRoot(out)

4.2.3.2.2. 保存索引块的firstkey,用于父节点索引

4.2.3.3. writeHeaderAndData()

4.2.3.4. blockWritten()把非root索引块信息添加到root索引

4.2.3.5. 缓存块cacheOnWrite()

4.2.4. newBlock()准备写入新block

4.2.4.1. startWriting()

4.2.4.1.1. 初始化offset、block类型、buffer

4.2.4.1.2. header数据占位

4.2.4.1.3. 创建DataOutputStream

4.3. 如果不在写入创建新block

4.4. 写入key和value的长度和内容

4.5. block的firstkey后续作为index block的entry属性