/spring-data-hbase

spring-data-hadoop 中的 hbase 代码部分提取,支持 hbase 2.x API

Primary LanguageJavaApache License 2.0Apache-2.0

Spring-Data-Hbase

spring-data-hadoop 项目 HBaseTemplate API 提取,支持 HBase 2.x API


项目说明

由于 spring-data-hadoop 目前已经停止更新(2019-04-05),最后一个版本不支持 Hbase-Client-2.x 的 API,此项目基于 spring-hadoop 代码,提取 spring-data-hbase 部分的代码,更新相关代码以支持 HBase 2.x。

该项目引入的主要组件依赖版本如下:

  • spring-boot:2.1.8.RELEASE

  • hbase-client:2.0.0

实际使用可以根据实际版本修改 pom 并重新打包;


HBase 连接配置

spring-data-hbase 已经集成了 spring-boot 的 auto configuration 功能,自动读取 yml 或者 properties 中以 spring.data.hbase.config 为前缀的配置项,作为 hbase 的连接配置项,以下是一个示例的 yml 配置文件:

spring.data.hbase.config:
    hbase.zookeeper.quorum: hbase
    hbase.zookeeper.property.clientPort: 2181
    hbase.zookeeper.parent: /hbase
    hbase.rootdir: hdfs://namenode:9000/hbase

HBaseTemplate 使用说明

HBaseTemplate 的使用和原生 HBaseTemplate API 完全一致,所有的测试代码位于 /src/test 目录下,以下作简要说明:

示例用的 HBase 初始化语句

create 'city', 'f0'

映射用的 DTO 实体

public class CityDTO {
    private String rowkey;
    private String name;
    private String province;
    private String code;
    .......
 }

HBase Put 操作

/**
 * 新增/更新数据
 */
@Test
public void testPut() {
hbaseTemplate.execute("city", (TableCallback<Object>) table -> {
    String rowkey = "key122";
    Put put = new Put(Bytes.toBytes(rowkey));
    put.addColumn(Bytes.toBytes("f0"), Bytes.toBytes("name"), Bytes.toBytes("guangzhou"));
    put.addColumn(Bytes.toBytes("f0"), Bytes.toBytes("province"), Bytes.toBytes("guangdong"));
    put.addColumn(Bytes.toBytes("f0"), Bytes.toBytes("code"), Bytes.toBytes("G-11"));
    table.put(put);
    return rowkey;
});
}

/**
 * 删除数据
 */
@Test
public void testDelete() {
hbaseTemplate.execute("city", (TableCallback<Object>) table -> {
    String rowkey = "key122";
    Delete delete = new Delete(Bytes.toBytes(rowkey));
    table.delete(delete);
    return rowkey;
});
}

HBase Get/Scan 操作

/**
 * get 操作
 */
@Test
public void testGet() {
String rowkey = "key122";
CityDTO results = hbaseTemplate.get("city", rowkey, (result, rowNum) -> {
    CityDTO dto = new CityDTO.CityDTOBuilder()
            .rowkey(new String(result.getRow()))
            .name(new String(result.getValue(Bytes.toBytes("f0"), Bytes.toBytes("name"))))
            .province(new String(result.getValue(Bytes.toBytes("f0"), Bytes.toBytes("province"))))
            .code(new String(result.getValue(Bytes.toBytes("f0"), Bytes.toBytes("code"))))
            .build();
    return dto;
});
System.out.println(results);
}

/**
 * scan 操作
 */
@Test
public void testScanFilter() {
Scan scan = new Scan().withStartRow(Bytes.toBytes("key100")).withStopRow(Bytes.toBytes("key300"));
scan.addFamily(Bytes.toBytes("f0"));
scan.setFilter(new SingleColumnValueFilter(
        Bytes.toBytes("f0"),
        Bytes.toBytes("code"),
        CompareOperator.EQUAL,
        Bytes.toBytes("G-11")));

List<CityDTO> results = hbaseTemplate.find("city", scan, (result, rowNum) -> {
    CityDTO dto = new CityDTO.CityDTOBuilder()
            .rowkey(new String(result.getRow()))
            .name(new String(result.getValue(Bytes.toBytes("f0"), Bytes.toBytes("name"))))
            .province(new String(result.getValue(Bytes.toBytes("f0"), Bytes.toBytes("province"))))
            .code(new String(result.getValue(Bytes.toBytes("f0"), Bytes.toBytes("code"))))
            .build();
    return dto;
});
results.forEach(System.out::println);
}