Hbase 源码分析6 -- Regionserver上的 Get 全流程
来源:互联网 发布:javascript的date对象 编辑:程序博客网 时间:2024/05/01 05:11
当regionserver收到来自客户端的Get请求时,调用接口
public Result get(byte[] regionName, Get get)
{
...
HRegion region = getRegion(regionName);
return region.get(get, getLockFromId(get.getLockId()));
...
}
我们看HRegion.get接口,其首先会做family检测,保证Get中的family与Table的相符,然后通过RegionScanner.next来返回result
而Scanner是Hbase读流程中的主要类,先做一个大概描述:
从Scanner的scan范围来分有RegionScanner,StoreScanner,MemstoreScanner,HFileScanner;根据名称很好理解他们的作用,而他们之间的关系:RegionScanner由一个或多个StoreScanner组成,StoreScanner由MemstoreScanner和HFileScanner组成;
再看RegionScanner类的构造形成过程:
List<KeyValueScanner> scanners = new ArrayList<KeyValueScanner>();
for (Map.Entry<byte[], NavigableSet<byte[]>> entry :
scan.getFamilyMap().entrySet())
{
Store store = stores.get(entry.getKey());
scanners.add(store.getScanner(scan, entry.getValue()));
}
this.storeHeap = new KeyValueHeap(scanners, comparator);
这段代码为RegionScanner类内部属性storeHeap初始化,其内容就是Region下面所有StoreScanner的和;storeHeap是一个KeyValueHeap,从字面可以理解result就是从中获取的
接着看store.getScanner(scan, entry.getValue())即StoreScanner类的构造形成过程:
StoreFileScanner的内部属性包括HFileScanner和Hfile.Reader,在添加前会根据timestamp,columns,bloomfilter过滤掉一部分
Scanner构造完毕以后,当最上层的RegionScanner.next时,首先会先从MemStoreScanner中获取,如果没有或者版本数不足,则再从HfileScanner中获取,而从HfileScanner获取时,先查看是否在blockcache中,如果MISS则再从底层的HDFS中获取block,并根据设置决定是否将Block cache到LruBlockCache中
public Result get(byte[] regionName, Get get)
{
...
HRegion region = getRegion(regionName);
return region.get(get, getLockFromId(get.getLockId()));
...
}
我们看HRegion.get接口,其首先会做family检测,保证Get中的family与Table的相符,然后通过RegionScanner.next来返回result
而Scanner是Hbase读流程中的主要类,先做一个大概描述:
从Scanner的scan范围来分有RegionScanner,StoreScanner,MemstoreScanner,HFileScanner;根据名称很好理解他们的作用,而他们之间的关系:RegionScanner由一个或多个StoreScanner组成,StoreScanner由MemstoreScanner和HFileScanner组成;
再看RegionScanner类的构造形成过程:
List<KeyValueScanner> scanners = new ArrayList<KeyValueScanner>();
for (Map.Entry<byte[], NavigableSet<byte[]>> entry :
scan.getFamilyMap().entrySet())
{
Store store = stores.get(entry.getKey());
scanners.add(store.getScanner(scan, entry.getValue()));
}
this.storeHeap = new KeyValueHeap(scanners, comparator);
这段代码为RegionScanner类内部属性storeHeap初始化,其内容就是Region下面所有StoreScanner的和;storeHeap是一个KeyValueHeap,从字面可以理解result就是从中获取的
接着看store.getScanner(scan, entry.getValue())即StoreScanner类的构造形成过程:
一般情况下StoreScanner中添加了HFileScanner和MemStoreScanner;
StoreFileScanner的内部属性包括HFileScanner和Hfile.Reader,在添加前会根据timestamp,columns,bloomfilter过滤掉一部分
Scanner构造完毕以后,当最上层的RegionScanner.next时,首先会先从MemStoreScanner中获取,如果没有或者版本数不足,则再从HfileScanner中获取,而从HfileScanner获取时,先查看是否在blockcache中,如果MISS则再从底层的HDFS中获取block,并根据设置决定是否将Block cache到LruBlockCache中
- Hbase 源码分析6 -- Regionserver上的 Get 全流程
- Hbase 源码分析之 Regionserver上的 Get 全流程
- Hbase 源码分析之 Regionserver下的 Get 全流程
- HBase源码分析之regionserver写入流程分析
- HBase源码分析之regionserver读取流程分析
- Hbase-0.98.6源码分析--RegionServer宕机处理
- HBase 0.1.0 Get流程源码分析
- HBase源码分析之org.apache.hadoop.hbase.regionserver包
- Hbase源码@RegionServer启动
- Hbase 源码分析4 - Get 流程及rpc原理
- Hbase 源码分析四 - Get 流程及rpc原理
- HBase源码分析之HRegionServer上compact流程分析
- HBase的put流程源码分析
- HBase的put流程源码分析
- 启动hbase的regionserver
- hbase的regionserver宕机
- HBase源码分析之Region上Spilt流程
- HBase深入分析之RegionServer
- ora-27125解决方法unable to create shared memory segment
- linux一些简单的操作命令
- C# 窗口句柄有关的常见问题
- Windows 内核版本
- 关于while与do...while...
- Hbase 源码分析6 -- Regionserver上的 Get 全流程
- 算法学习【16】—— 1119. Factstone Benchmark
- 字符串处理
- C# OpenCV 初体验
- MySQL查看表结构SQL语句
- asp.net 判断字符串是否有汉字
- IOS开发之手势——UIGestureRecognizer 共存
- 注册登录过程点滴(一):初始的想法--分享是王道
- Excel 2007 自定义 设置 快捷键 合并单元格 字体颜色 ==