Hbase入门——客户端(Java,Shell,Thrift,Rest...

本文详细介绍了Hbase的四种主要客户端:原生Java客户端、Hbase Shell、Thrift客户端和REST客户端的用法。内容包括配置连接、创建表、增删改查数据等操作,并提供了示例代码。对于非Java程序员,还介绍了通过Thrift和REST接口使用Python和Java访问Hbase的方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Hbase的客户端有原生java客户端,Hbase Shell,Thrift,Rest,Mapreduce,WebUI等等。

下面是这几种客户端的常见用法。

一、原生Java客户端

原生java客户端是hbase最主要,最高效的客户端。

涵盖了增删改查等API,还实现了创建,删除,修改表等DDL操作。

配置java连接hbase

Java连接HBase需要两个类:

  • HBaseConfiguration
  • ConnectionFactory

首先,配置一个hbase连接:

比如zookeeper的地址端口hbase.zookeeper.quorumhbase.zookeeper.property.clientPort

更通用的做法是编写hbase-site.xml文件,实现配置文件的加载:

hbase-site.xml示例:

<configuration><property><name>hbase.master</name><value>hdfs://host1:60000</value></property><property><name>hbase.zookeeper.quorum</name><value>host1,host2,host3</value></property><property><name>hbase.zookeeper.property.clientPort</name><value>2181</value></property></configuration>

随后我们加载配置文件,创建连接:

config.addResource(new Path(System.getenv("HBASE_CONF_DIR"), "hbase-site.xml")); Connection connection = ConnectionFactory.createConnection(config);创建表

要创建表我们需要首先创建一个Admin对象

Admin admin = connection.getAdmin(); //使用连接对象获取Admin对象TableName tableName = TableName.valueOf("test");//定义表名HTableDescriptor htd = new HTableDescriptor(tableName);//定义表对象HColumnDescriptor hcd = new HColumnDescriptor("data");//定义列族对象htd.addFamily(hcd); //添加admin.createTable(htd);//创建表HBase2.X创建表

HBase2.X 的版本中创建表使用了新的 API

TableName tableName = TableName.valueOf("test");//定义表名//TableDescriptor对象通过TableDescriptorBuilder构建;TableDescriptorBuilder tableDescriptor = TableDescriptorBuilder.newBuilder(tableName);ColumnFamilyDescriptor family = ColumnFamilyDescriptorBuilder.newBuilder(Bytes.toBytes("data")).build();//构建列族对象tableDescriptor.setColumnFamily(family);//设置列族admin.createTable(tableDescriptor.build());//创建表添加数据Table table = connection.getTable(tableName);//获取Table对象try {    byte[] row = Bytes.toBytes("row1"); //定义行    Put put = new Put(row);             //创建Put对象    byte[] columnFamily = Bytes.toBytes("data");    //列    byte[] qualifier = Bytes.toBytes(String.valueOf(1)); //列族修饰词    byte[] value= Bytes.toBytes("张三丰");    //值    put.addColumn(columnFamily, qualifier, value);    table.put(put);     //向表中添加数据finally {    //使用完了要释放资源    table.close();}获取指定行数据//获取数据Get get = newGet(Bytes.toBytes("row1"));   //定义get对象Result result = table.get(get);         //通过table对象获取数据System.out.println("Result: " + result);//很多时候我们只需要获取“值” 这里表示获取 data:1 列族的值byte[] valueBytes = result.getValue(Bytes.toBytes("data"), Bytes.toBytes("1")); //获取到的是字节数组//将字节转成字符串String valueStr = new String(valueBytes,"utf-8");System.out.println("value:" + valueStr);扫描表中的数据Scan scan = new Scan();ResultScanner scanner = table.getScanner(scan);try {    for (Result scannerResult: scanner) {        System.out.println("Scan: " + scannerResult);         byte[] row = scannerResult.getRow();         System.out.println("rowName:" + new String(row,"utf-8"));    }} finally {    scanner.close();}删除表TableName tableName = TableName.valueOf("test");admin.disableTable(tableName);  //禁用表admin.deleteTable(tableName);   //删除表

Hbase Java API表DDL完整示例:

packa

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值