hbase 是bigtable的开源java版本。是建立在hdfs之上,提供高可靠,高性能,高存储,可伸缩,实时读写nosql的数据库系统。
它是介于nosql和RDBMS之间,仅通过主键(rowkey)和主键的range来检索数据,仅支持单行事物,可通过hive支持来实现多表join等复杂操作。
主要用来存储结构化和半结构化的松散数据。
Hbase 查询数据功能简单,不仅支持join等复杂操作,不支持复杂的事物行级的事物。
Hbase中支持的数据类型:byte[]
与hadoop一样,Hbase目标主要依靠横向扩展,通过不断增加廉价的商用服务器,来增加计算和存储能力。
Hbase钟表一般有这样的特点:
大,一个表可以有上十亿行,上百万列。
面向列:面向列族的存储和权限控制,列族独立检索
稀疏:对于为空null的列,并不占用存储空间,因此,表可以设计得非常稀疏。
HBase的发展历程
HBase的原型是Google的BigTable论文,受到了该论文思想的启发,目前作为Hadoop的子项目来开发维护,用于支持结构化的数据存储。
官方网站:http://hbase.apache.org
* 2006年Google发表BigTable白皮书
* 2006年开始开发HBase
* 2008 HBase成为了 Hadoop的子项目
* 2010年HBase成为Apache顶级项目