# Hbase11X Reader

Hbase11X Reader 插件支持从 HBase 1.x 版本读取数据, 其实现方式为 通过 HBase 的 Java 客户端连接远程 HBase 服务,并通过 Scan 方式读取你指定 rowkey 范围内的数据。

## 配置

### 建表以及填充数据

以下演示基于下面创建的表以及数据

`shell create 'users', 'address','info' put 'users', 'lisi', 'address:country', 'china' put 'users', 'lisi', 'address:province',    'beijing' put 'users', 'lisi', 'info:age',        27 put 'users', 'lisi', 'info:birthday',   '1987-06-17' put 'users', 'lisi', 'info:company',    'baidu' put 'users', 'xiaoming', 'address:city',    'hangzhou' put 'users', 'xiaoming', 'address:country', 'china' put 'users', 'xiaoming', 'address:province',    'zhejiang' put 'users', 'xiaoming', 'info:age',        29 put 'users', 'xiaoming', 'info:birthday',   '1987-06-17' put 'users', 'xiaoming', 'info:company',    'alibaba' `

#### normal 模式

把 HBase 中的表,当成普通二维表(横表)进行读取,读取最新版本数据。如:

```shell hbase(main):017:0> scan 'users' ROW COLUMN+CELL

lisi column=address:city, timestamp=1457101972764, value=beijing lisi column=address:country, timestamp=1457102773908, value=china lisi column=address:province, timestamp=1457101972736, value=beijing lisi column=info:age, timestamp=1457101972548, value=27 lisi column=info:birthday, timestamp=1457101972604, value=1987-06-17 lisi column=info:company, timestamp=1457101972653, value=baidu xiaoming column=address:city, timestamp=1457082196082, value=hangzhou xiaoming column=address:country, timestamp=1457082195729, value=china xiaoming column=address:province, timestamp=1457082195773, value=zhejiang xiaoming column=info:age, timestamp=1457082218735, value=29 xiaoming column=info:birthday, timestamp=1457082186830, value=1987-06-17 xiaoming column=info:company, timestamp=1457082189826, value=alibaba

2 row(s) in 0.0580 seconds ```

读取后数据

rowKey | addres:city | address:country | address:province | info:age | info:birthday | info:company |
-------- | ----------- | --------------- | ---------------- | -------- | ------------- | ------------ |
lisi | beijing | china | beijing | 27 | 1987-06-17 | baidu |
xiaoming | hangzhou | china | zhejiang | 29 | 1987-06-17 | alibaba |

#### multiVersionFixedColumn 模式

把 HBase 中的表,当成竖表进行读取。读出的每条记录一定是四列形式,依次为:rowKeyfamily:qualifiertimestampvalue

读取时需要明确指定要读取的列,把每一个 cell 中的值,作为一条记录(record),若有多个版本就有多条记录(record)。如:

```shell hbase(main):018:0> scan 'users',{VERSIONS=>5} ROW COLUMN+CELL

lisi column=address:city, timestamp=1457101972764, value=beijing lisi column=address:contry, timestamp=1457102773908, value=china lisi column=address:province, timestamp=1457101972736, value=beijing lisi column=info:age, timestamp=1457101972548, value=27 lisi column=info:birthday, timestamp=1457101972604, value=1987-06-17 lisi column=info:company, timestamp=1457101972653, value=baidu xiaoming column=address:city, timestamp=1457082196082, value=hangzhou xiaoming column=address:contry, timestamp=1457082195729, value=china xiaoming column=address:province, timestamp=1457082195773, value=zhejiang xiaoming column=info:age, timestamp=1457082218735, value=29 xiaoming column=info:age, timestamp=1457082178630, value=24 xiaoming column=info:birthday, timestamp=1457082186830, value=1987-06-17 xiaoming column=info:company, timestamp=1457082189826, value=alibaba

2 row(s) in 0.0260 seconds ```

读取后数据(4 列)

rowKey | column:qualifier | timestamp | value |
-------- | ---------------- | ------------- | ---------- |
lisi | address:city | 1457101972764 | beijing |
lisi | address:contry | 1457102773908 | china |
lisi | address:province | 1457101972736 | beijing |
lisi | info:age | 1457101972548 | 27 |
lisi | info:birthday | 1457101972604 | 1987-06-17 |
lisi | info:company | 1457101972653 | beijing |
xiaoming | address:city | 1457082196082 | hangzhou |
xiaoming | address:contry | 1457082195729 | china |
xiaoming | address:province | 1457082195773 | zhejiang |
xiaoming | info:age | 1457082218735 | 29 |
xiaoming | info:age | 1457082178630 | 24 |
xiaoming | info:birthday | 1457082186830 | 1987-06-17 |
xiaoming | info:company | 1457082189826 | alibaba |

### 配置样例

配置一个从 HBase 抽取数据到本地的作业,分别为标准模式和多版本模式

=== "job/hbase11x2stream_normal.json"

`json --8<-- "jobs/hbase11xreader_normal.json" `

=== "job/hbase11x2srtream_version.json"

`json --8<-- "jobs/hbase11xreader_version.json" `

## 参数说明

配置项 | 是否必须 | 默认值 | 描述 |
:------------ | :------: | ------ | -------------------------------------------------------------------------------------------- |
hbaseConfig | 是 | 无 | 连接 HBase 集群需要的配置信息, hbase.zookeeper.quorum 为必填项,其他 client 的配置为可选项 |
mode | 是 | 无 | 读取 HBase 的模式,可填写 normalmultiVersionFixedColumn |
table | 是 | 无 | 要读取的 hbase 表名(大小写敏感) |
encoding | 否 | UTF-8 | 编码方式,UTF-8 或是 GBK,用于对二进制存储的 HBase byte[] 转为 String 时的编码 |
column | 是 | 无 | 要读取的 hbase 字段,normal 模式与 multiVersionFixedColumn 模式下必填项, 详细说明见下文 |
maxVersion | 是 | 无 | 指定在多版本模式下读取的版本数,-1 表示读取所有版本, multiVersionFixedColumn 模式下必填 |
range | 否 | 无 | 指定读取的`rowkey` 范围, 详见下文 |
scanCacheSize | 否 | 256 | HBase client 每次从服务器端读取的行数 |
scanBatchSize | 否 | 100 | HBase client 每次从服务器端读取的列数 |

### column

描述:要读取的 hbase 字段,normal 模式与 multiVersionFixedColumn 模式下必填项。

### normal 模式

name 指定读取的 hbase 列,除了 rowkey 外,必须为 列族:列名 的格式,type 指定源数据的类型,format`指定日期类型的格式, `value 指定当前类型为常量,不从 hbase 读取数据,而是根据 value 值自动生成对应的列。配置格式如下:

```json {

"column": [
{

"name": "rowkey", "type": "string"

}, {

"value": "test", "type": "string"

}

]

}

normal 模式下,对于用户指定 Column 信息,type 必须填写,name/value 必须选择其一。

### multiVersionFixedColumn 模式

name 指定读取的 hbase 列,除了 rowkey 外,必须为 列族:列名 的格式,type 指定源数据的类型,`format`指定日期类型的格式 。 multiVersionFixedColumn 模式下不支持常量列。配置格式如下:

```json {

"column": [
{

"name": "rowkey", "type": "string"

}, {

"name": "info: age", "type": "string"

}

]

}

#### range

指定读取的 rowkey 范围

  • startRowkey:指定开始 rowkey

  • endRowkey 指定结束 rowkey

  • isBinaryRowkey:指定配置的 startRowkey`和 `endRowkey 转换为`byte[]`时的方式,默认值为 false,若为 true,则调用`Bytes.toBytesBinary(rowkey)`方法进行转换;若为 false:则调用`Bytes.toBytes(rowkey)`

配置格式如下:

```json {

"range": {

"startRowkey": "aaa", "endRowkey": "ccc", "isBinaryRowkey": false

}

}

## 类型转换

下面列出支持的读取 HBase 数据类型,HbaseReader 针对 HBase 类型转换列表:

Addax 内部类型 | HBase 数据类型 |
-------------- | -------------------- |
Long | int, short ,long |
Double | float, double |
String | string, binarystring |
Date | date |
Boolean | boolean |

请注意:

除上述罗列字段类型外,其他类型均不支持

## 限制

  1. 目前不支持动态列的读取。考虑网络传输流量(支持动态列,需要先将 hbase 所有列的数据读取出来,再按规则进行过滤),现支持的两种读取模式中需要用户明确指定要读取的列。

  2. 关于同步作业的切分:目前的切分方式是根据用户 hbase 表数据的 region 分布进行切分。即:在用户填写的 [startrowkey,endrowkey] 范围内,一个 region 会切分成一个 task,单个 region 不进行切分。

  3. multiVersionFixedColumn 模式下不支持增加常量列