首页
Web开发
Windows程序
编程语言
数据库
移动开发
系统相关
微信
其他好文
会员
首页
>
其他好文
> 详细
<HBase><读写>
时间:
2017-05-30 15:57:21
阅读:
186
评论:
0
收藏:
0
[点我收藏+]
标签:
key
hbase
合并
新版本
定位
存储
root
ems
三次
Overview
HBase中的一个big table,首先会按行划分成一些
region
(这些
region之间是有序的
,由startkey保证),每个region分配到不同的节点进行存储。因此,region是HBase分布式和负载均衡的最小单元。
对每个节点而言,它会对分配到的region是按列族进行存储的。也即,
region被分为多个store(对应多个列族)。而store内部,又有一个memStore和多个storeFiles组成
。
数据首先更新到memStore,memStore会内排序,而storeFile是由memStore flush到磁盘的,所以
每个storeFile内部都是有序的
。但是,本质上HBase进行的都是append操作(删除并不是真正的删除,而是打上delete的tag),所以是
无法保证storeFiles之间有序的
。
storeFiles之间无序,那么当storeFiles个数过多时,必然造成效率下降,因此会对storeFiles做merge操作。也即当 StoreFile 文件数量超过设定值时,会
触发合并操作
,合并成一个大文件。
同样的,
当region的大小达到阈值时,会被切分开
,生成一个新的region,HMaster会对其进行管理,分配到合适的 regionserver。region的变化后,系统还需要
对hbase:meta 表进行维护
。
HBase:meta
在Hbase的老版本中,是包含-root-和.meta.表的,每次索引数据都要进行三次定位。在新版本中改成了只有HBase:meta表,它存在于Zookeeper中。
当我们在HBase中查找某rowkey时,首先要定位其所在的RegionServer,这就需要通过HBase:meta表来实现了。
HBase:meta表本质上也是一张HBase表。
HBase Read
以上,查找某rowkey时:
通过Zookeeper中的HBase:meta表定位其所在region(RegionServer);【因为region之间是有序的,因此可以根据startKey来定位】
在RegionServer中查找:首先是BlockCache,然后是MemStore,再然后是StoreFiles(StoreFiles之间虽是无序的,但每个StoreFile内部是有序的)。
<HBase><读写>
标签:
key
hbase
合并
新版本
定位
存储
root
ems
三次
原文地址:http://www.cnblogs.com/wttttt/p/6920029.html
踩
(
0
)
赞
(
0
)
举报
评论
一句话评论(
0
)
登录后才能评论!
分享档案
更多>
2021年07月29日 (22)
2021年07月28日 (40)
2021年07月27日 (32)
2021年07月26日 (79)
2021年07月23日 (29)
2021年07月22日 (30)
2021年07月21日 (42)
2021年07月20日 (16)
2021年07月19日 (90)
2021年07月16日 (35)
周排行
更多
分布式事务
2021-07-29
OpenStack云平台命令行登录账户
2021-07-29
getLastRowNum()与getLastCellNum()/getPhysicalNumberOfRows()与getPhysicalNumberOfCells()
2021-07-29
【K8s概念】CSI 卷克隆
2021-07-29
vue3.0使用ant-design-vue进行按需加载原来这么简单
2021-07-29
stack栈
2021-07-29
抽奖动画 - 大转盘抽奖
2021-07-29
PPT写作技巧
2021-07-29
003-核心技术-IO模型-NIO-基于NIO群聊示例
2021-07-29
Bootstrap组件2
2021-07-29
友情链接
兰亭集智
国之画
百度统计
站长统计
阿里云
chrome插件
新版天听网
关于我们
-
联系我们
-
留言反馈
© 2014
mamicode.com
版权所有 联系我们:gaon5@hotmail.com
迷上了代码!