天天看点

分布式存储系统HBase的架构

HBase是一个构建在HDFS上的分布式列存储系统。HBase是Apache Hadoop生态系统中的重要一员,主要用于海量结构化数据存储;

从逻辑上讲,HBase将数据按照表、行和列进行存储。两者都具有良好的容错性和扩展性,都可以扩展到成百上千个节点;

Hbase表的特点

大:一个表可以有数十亿行,上百万列;

无模式:每行都有一个可排序的主键和任意多的列,列可以根据需要动态的增加,同一张表中不同的行可以有截然不同的列;

<a href="http://s3.51cto.com/wyfs02/M00/A7/84/wKioL1nn9E-Ax551AACxiONv2KQ132.jpg-wh_651x-s_1003639223.jpg" target="_blank"></a>

<a href="http://s4.51cto.com/wyfs02/M02/08/D5/wKiom1nn9xOQP5dSAACxPSOMpsE124.jpg" target="_blank"></a>

面向列:面向列(族)的存储和权限控制,列(族)独立检索;

稀疏:对于空(null)的列,并不占用存储空间,表可以设计的非常稀疏;

数据多版本:每个单元中的数据可以有多个版本,默认情况下版本号自动分配,是单元格插入时的时间戳;

数据类型单一:Hbase中的数据都是字符串,没有类型。

Hbase数据模型

HBase是基于Google BigTable模型开发的,典型的key/value系统;

<a href="http://s1.51cto.com/wyfs02/M02/08/D5/wKiom1nn9x7SxCDLAABsawfXdIU437.jpg" target="_blank"></a>

Hbase逻辑视图

<a href="http://s5.51cto.com/wyfs02/M00/08/D5/wKiom1nn9yjjxdhMAADPhRTNvAA157.jpg" target="_blank"></a>

<a href="http://s1.51cto.com/wyfs02/M00/08/D5/wKiom1nn9zKztTEbAAChfyXuEF4612.jpg" target="_blank"></a>

HBase schema可以有多个 Table,每个表可由多个Column Family组成。HBase可以有 Dynamic Column列名称是编码在cell中的,不同的cell可以拥有不同的列。

原文发布时间为:2017-10-19

本文作者:佚名

本文来自云栖社区合作伙伴“51CTO”,了解相关信息可以关注。