# 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 ```
读取后数据
#### multiVersionFixedColumn 模式
把 HBase 中的表,当成竖表进行读取。读出的每条记录一定是四列形式,依次为:rowKey,family:qualifier,timestamp,value。
读取时需要明确指定要读取的列,把每一个 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 列)
### 配置样例
配置一个从 HBase 抽取数据到本地的作业,分别为标准模式和多版本模式
=== "job/hbase11x2stream_normal.json"
`json --8<-- "jobs/hbase11xreader_normal.json" `
=== "job/hbase11x2srtream_version.json"
`json --8<-- "jobs/hbase11xreader_version.json" `
## 参数说明
### column
描述:要读取的 hbase 字段,normal 模式与 multiVersionFixedColumn 模式下必填项。
### normal 模式
name 指定读取的 hbase 列,除了 rowkey 外,必须为 列族:列名 的格式,type 指定源数据的类型,format`指定日期类型的格式, `value 指定当前类型为常量,不从 hbase 读取数据,而是根据 value 值自动生成对应的列。配置格式如下:
- "column": [
- {
"name": "rowkey", "type": "string"
}, {
"value": "test", "type": "string"
}
]
}
normal 模式下,对于用户指定 Column 信息,type 必须填写,name/value 必须选择其一。
### multiVersionFixedColumn 模式
name 指定读取的 hbase 列,除了 rowkey 外,必须为 列族:列名 的格式,type 指定源数据的类型,`format`指定日期类型的格式 。 multiVersionFixedColumn 模式下不支持常量列。配置格式如下:
- "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)`
配置格式如下:
- "range": {
"startRowkey": "aaa", "endRowkey": "ccc", "isBinaryRowkey": false
}
}
## 类型转换
下面列出支持的读取 HBase 数据类型,HbaseReader 针对 HBase 类型转换列表:
请注意:
除上述罗列字段类型外,其他类型均不支持
## 限制
目前不支持动态列的读取。考虑网络传输流量(支持动态列,需要先将 hbase 所有列的数据读取出来,再按规则进行过滤),现支持的两种读取模式中需要用户明确指定要读取的列。
关于同步作业的切分:目前的切分方式是根据用户 hbase 表数据的 region 分布进行切分。即:在用户填写的 [startrowkey,endrowkey] 范围内,一个 region 会切分成一个 task,单个 region 不进行切分。
multiVersionFixedColumn 模式下不支持增加常量列