千家信息网

Hbase协处理器coprocessor

发表于:2025-11-13 作者:千家信息网编辑
千家信息网最后更新 2025年11月13日,对每个region进行处理,弥补了scan的时候有限的几个过滤器的不足分为两种类型observer 观察者相当于触发器Endpoint终端相当于存储过程下面的观察者实现查询之前替换掉行键为Jack的K
千家信息网最后更新 2025年11月13日Hbase协处理器coprocessor

对每个region进行处理,弥补了scan的时候有限的几个过滤器的不足


分为两种类型


  1. observer 观察者相当于触发器

  2. Endpoint终端相当于存储过程



下面的观察者实现查询之前替换掉行键为Jack的KeyValue

import java.io.IOException;import java.util.List;import org.apache.hadoop.hbase.KeyValue;import org.apache.hadoop.hbase.client.Get;import org.apache.hadoop.hbase.coprocessor.BaseRegionObserver;import org.apache.hadoop.hbase.coprocessor.ObserverContext;import org.apache.hadoop.hbase.coprocessor.RegionCoprocessorEnvironment;import org.apache.hadoop.hbase.util.Bytes;public class RegionObserverTest extends BaseRegionObserver {    private static byte[] fixed_rowkey = "Jack".getBytes();    @Override    public void postGet(ObserverContext c,            Get get, List result) throws IOException {        if (Bytes.equals(get.getRow(), fixed_rowkey)) {            KeyValue kv = new KeyValue(get.getRow(), Bytes.toBytes("time"),                    Bytes.toBytes("time"), Bytes.toBytes(System                            .currentTimeMillis()));            result.add(kv);        }    }}

加载协处理器命令

disable 'students'alter 'students' ,'coprocessor'=>'hdfs://ns1/coprocessor.jar|com.hbase.RegionObserverTest||'enable 'students'


alter 'table_name' ,METHOD=>'table_att', 'coprocessor'=>'path|class|number|args'

number表示第几个协处理器

删除第一个协处理器

alter 'table_name' ,METHOD=>'table_att_unset',NAME=>'coprocessor$1'

0