Hbase协处理器coprocessor

简介: 对每个region进行处理,弥补了scan的时候有限的几个过滤器的不足分为两种类型observer 观察者相当于触发器Endpoint终端相当于存储过程下面的观察者实现查询之前替换掉行键为Jack的KeyValueimport java.io.IOException;import java.util.List;import org.apache.hadoop.hba

对每个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<RegionCoprocessorEnvironment> c,
            Get get, List<KeyValue> 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'

本文出自 “点滴积累” 博客,请务必保留此出处http://tianxingzhe.blog.51cto.com/3390077/1699113

相关实践学习
lindorm多模间数据无缝流转
展现了Lindorm多模融合能力——用kafka API写入,无缝流转在各引擎内进行数据存储和计算的实验。
云数据库HBase版使用教程
&nbsp; 相关的阿里云产品:云数据库 HBase 版 面向大数据领域的一站式NoSQL服务,100%兼容开源HBase并深度扩展,支持海量数据下的实时存储、高并发吞吐、轻SQL分析、全文检索、时序时空查询等能力,是风控、推荐、广告、物联网、车联网、Feeds流、数据大屏等场景首选数据库,是为淘宝、支付宝、菜鸟等众多阿里核心业务提供关键支撑的数据库。 了解产品详情:&nbsp;https://cn.aliyun.com/product/hbase &nbsp; ------------------------------------------------------------------------- 阿里云数据库体验:数据库上云实战 开发者云会免费提供一台带自建MySQL的源数据库&nbsp;ECS 实例和一台目标数据库&nbsp;RDS实例。跟着指引,您可以一步步实现将ECS自建数据库迁移到目标数据库RDS。 点击下方链接,领取免费ECS&amp;RDS资源,30分钟完成数据库上云实战!https://developer.aliyun.com/adc/scenario/51eefbd1894e42f6bb9acacadd3f9121?spm=a2c6h.13788135.J_3257954370.9.4ba85f24utseFl
目录
相关文章
|
存储 大数据 Java
HBase中Coprocessor的介绍以及实际业务场景中的使用
本文主要带大家了解Coprocessor的原理。首先从四个角度出发讲解了什么是Coprocessor,Coprocessor适合哪些使用场景。并详细分析了两种类型Coprocessor,分别介绍了Observer和Endpoint的实现及其区别。
3206 0
|
搜索推荐 Java 分布式数据库
|
分布式计算 Java Hadoop
|
存储 大数据 分布式数据库
直播:HBase中Coprocessor的介绍以及实际业务场景中的使用
HBase生态+Spark社区大群直播:讲解hbase coprocessor的原理以及使用场景;coprocessor整个流程实战,包括开发,加载,运行以及管理;结合1,2分析coprocessor在rsgroup中的具体使用。
2611 0
|
存储 分布式数据库 索引
技术篇-HBase Coprocessor 的实现与应用
本次分享的内容主要分为以下五点: Coprocessor 简介 Endpoint 服务端实现 Endpoint 客户端实现 Observer 实现二级索引 Coprocessor 应用场景 1.
3522 0
|
存储 分布式计算 分布式数据库
|
分布式数据库 Hbase 设计模式