栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 前沿技术 > 大数据 > 大数据系统

hbase

hbase

相关资料

官网 https://hbase.apache.org/ hbase安装

拉取镜像

docker pull harisekhon/hbase
启动
docker run -d -h docker-hbase -p 2181:2181 -p 8080:8080 -p 8085:8085 -p 9090:9090 -p 9000:9000 -p 9095:9095 -p 16000:16000 -p 16010:16010 -p 16201:16201 -p 16301:16301 -p 16020:16020 --name hbase harisekhon/hbase
修改host(window)
127.0.0.1 docker-hbase
hbase数据模型

表(Table)
Hbase 会将数据组织进一张张的表里面,一个 Hbase 表由多行组成。

行(Row)
Hbase 中的一行包含一个行键和一个或多个与其相关的值的列。在存储行时,行按字母顺序排序。出于这个原因,行键的设计非常重要。目标是以相关行相互靠近的方式存储数据。常用的行键模式是网站域。如果你的行键是域名,则你可能应该将它们存储在相反的位置(org.apache.www,org.apache.mail,org.apache.jira)。这样,表中的所有 Apache 域都彼此靠近,而不是根据子域的第一个字母分布。

列(Column)
Hbase 中的列由一个列族和一个列限定符组成,它们由:(冒号)字符分隔。

列族(Column Family)
出于性能原因,列族在物理上共同存在一组列和它们的值。在 Hbase 中每个列族都有一组存储属性,例如其值是否应缓存在内存中,数据如何压缩或其行编码是如何编码的等等。表中的每一行都有相同的列族,但给定的行可能不会在给定的列族中存储任何内容。

列族一旦确定后,就不能轻易修改,因为它会影响到 Hbase 真实的物理存储结构,但是列族中的列标识(Column Qualifier)以及其对应的值可以动态增删。

列限定符(Column Qualifier)
列限定符被添加到列族中,以提供给定数据段的索引。鉴于列族的content,列限定符可能是content:html,而另一个可能是content:pdf。虽然列族在创建表时是固定的,但列限定符是可变的,并且在行之间可能差别很大。

单元格(Cell)
单元格是行、列族和列限定符的组合,并且包含值和时间戳,它表示值的版本。

时间戳(Timestamp)
时间戳与每个值一起编写,并且是给定版本的值的标识符。默认情况下,时间戳表示写入数据时 RegionServer 上的时间,但可以在将数据放入单元格时指定不同的时间戳值。

示例

row1 column=personal:name, timestamp=1418051555, value=raju
row1 column=personal:city, timestamp=1418275907, value=Hyderabad
row1 column=professional:designation, timestamp=14180555,value=manager
row1 column=professional:salary, timestamp=1418035791555,value=50000

数据类型

shell脚本操作
脚本示例说明
hbase shell进入命令行
create ‘’,’
create ‘test’,‘course’创建表
get ’’,’row1’
get ‘emp’, ‘1’获取单行数据
put ‘table name’,’row ’,‘Column family:column name’,’new value’put ‘emp’,‘row1’,‘personal:city’,‘Delhi’写数据
scan ‘’
scan ‘emp’扫描
delete ‘’, ‘’, ‘’, ‘
delete ‘emp’, ‘1’, ‘personal data:city’,1417521848375删除数据
deleteall ‘’, ‘
deleteall ‘emp’,‘1’删除所有数据
java连接

    下载hadoop本地开发环境
    https://github.com/steveloughran/winutils

    配置HADOOP_HOME环境变量
    配置完成后需要重启电脑,如果不想重启加入如下代码

    System.setProperty("hadoop.home.dir", "D:\Program Files\hadoop-2.7.1");
    

    java包引入

     
     	org.apache.hbase
        hbase-client
        1.3.1
    
    
        org.apache.hbase
        hbase-server
        1.3.1
    
    

    使用示例

    Configuration conf = HbaseConfiguration.create();
    //设置zk集群地址,这里需要修改windows下的hosts文件
    //conf.set("hbase.zookeeper.quorum", "master:2181,slave1:2181,slave2:2181");
    conf.set("hbase.master", "127.0.0.1:16000");
    //建立连接
    Connection conn = ConnectionFactory.createConnection(conf);
    
    Table htable = conn.getTable(TableName.valueOf("test"));
    //创建put对象
    //创建rowkey
    Put put = new Put(Bytes.toBytes("row2"));
    put.addColumn(Bytes.toBytes("cf"), Bytes.toBytes("a"), Bytes.toBytes("value"));
    //添加put到表对象
    htable.put(put);
    
转载请注明:文章转载自 www.mshxw.com
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号