Hbase学习笔记——rowkey

案例

bash;gutter:true; Reliable and Scalable Data Ingestion at Airbnb https://www.slideshare.net/HadoopSummit/reliable-and-scalable-data-ingestion-at-airbnb-63920989</p> <p>Apache HBase at Airbnb https://www.slideshare.net/HBaseCon/apache-hbase-at-airbnb</p> <p>Airbnb软件工程师丁辰 - Airbnb的Streaming ETL https://myslide.cn/slides/3473

在Airbnb的rowkey设计案例中,使用了hash法避免了写入热点问题,其中

Hbase学习笔记——rowkey

Event_key标识了一条日志的唯一性,用于将来自Kafka的日志数据进行去重;

Shard_id是将Event_key进行hash(可以参考es的路由哈希算法Hashing.murmur3_128)之后,对Shard_num进行取余后的结果,Shard_num感觉应该是当前hbase表region server的总数,由于airbnb在hbase中存储的是实时日志数据,并开启了Hbase的TTL,所以当前hbase表中的数据总量应该是可预测的,即region server数量不会无限增加

Shard_key应该就是当前业务的region_start_keys+shard_id,比如当前业务分配的前缀为00000,同时规划了100个table regions给这个业务,即00-99,那么Shard_key的范围就是0000000-0000099

rowkey就是Shard_key.Event_key,比如0000000.air_events.canaryevent.016230-a3db-434e

Hbase学习笔记——rowkey

rowkey设计原则

1.rowkey长度原则:rowkey是一个二进制码流,可以是任意字符串,最大长度 64kb ,实际应用中一般为10-100bytes,以 byte[] 形式保存,一般设计成定长。

建议越短越好,不要超过16个字节,原因如下:

  1. 数据的持久化文件HFile中是按照KeyValue存储的,如果rowkey过长,比如超过100字节,1000w行数据,光rowkey就要占用100*1000w=10亿个字节,将近1G数据,这样会极大影响HFile的存储效率;
  2. MemStore将缓存部分数据到内存,如果rowkey字段过长,内存的有效利用率就会降低,系统不能缓存更多的数据,这样会降低检索效率。
  3. 目前操作系统都是64位系统,内存8字节对齐,控制在16个字节,8字节的整数倍利用了操作系统的最佳特性。

2.rowkey散列原则:如果rowkey按照时间戳的方式递增,不要将时间放在二进制码的前面,建议将rowkey的高位作为散列字段,由程序随机生成,低位放时间字段,这样将提高数据均衡分布在每个RegionServer,以实现负载均衡的几率。

如果没有散列字段,首字段直接是时间信息,所有的数据都会集中在一个RegionServer上,这样在数据检索的时候负载会集中在个别的RegionServer上,造成热点问题,会降低查询效率。

3.rowkey唯一原则:必须在设计上保证其唯一性,rowkey是按照字典顺序排序存储的,因此,设计rowkey的时候,要充分利用这个排序的特点,将经常读取的数据存储到一块,将最近可能会被访问的数据放到一块。

热点问题

HBase中的行是按照rowkey的字典顺序排序的,这种设计优化了scan操作,可以将相关的行以及会被一起读取的行存取在临近位置,便于scan。然而糟糕的rowkey设计是热点的源头。

热点发生在大量的client直接访问集群的一个或极少数个节点(访问可能是读,写或者其他操作)。大量访问会使热点region所在的单个机器超出自身承受能力,引起性能下降甚至region不可用,这也会影响同一个RegionServer上的其他region,由于主机无法服务其他region的请求。

设计良好的数据访问模式以使集群被充分,均衡的利用。为了避免写热点,设计rowkey使得不同行在同一个region,但是在更多数据情况下,数据应该被写入集群的多个region,而不是一个。下面是一些常见的避免热点的方法以及它们的优缺点:

1.加盐

这里所说的加盐不是密码学中的加盐,而是在rowkey的前面增加随机数,具体就是给rowkey分配一个随机前缀以使得它和之前的rowkey的开头不同。分配的前缀种类数量应该和你想使用数据分散到不同的region的数量一致。加盐之后的rowkey就会根据随机生成的前缀分散到各个region上,以避免热点。

2.哈希

哈希会使同一行永远用一个前缀加盐。哈希也可以使负载分散到整个集群,但是读却是可以预测的。使用确定的哈希可以让客户端重构完整的rowkey,可以使用get操作准确获取某一个行数据。

3.反转

第三种防止热点的方法时反转固定长度或者数字格式的rowkey。这样可以使得rowkey中经常改变的部分(最没有意义的部分)放在前面。这样可以有效的随机rowkey,但是牺牲了rowkey的有序性。

反转rowkey的例子以手机号为rowkey,可以将手机号反转后的字符串作为rowkey,这样的就避免了以手机号那样比较固定开头导致热点问题

4.时间戳反转

一个常见的数据处理问题是快速获取数据的最近版本,使用反转的时间戳作为rowkey的一部分对这个问题十分有用,可以用 Long.Max_Value – timestamp 追加到key的末尾,例如 [key][reverse_timestamp] , [key] 的最新值可以通过scan [key]获得[key]的第一条记录,因为HBase中rowkey是有序的,第一条记录是最后录入的数据。

其他一些建议:

尽量减少行键和列族的大小在HBase中,value永远和它的key一起传输的。当具体的值在系统间传输时,它的rowkey,列名,时间戳也会一起传输。如果你的rowkey和列名很大,这个时候它们将会占用大量的存储空间。

列族尽可能越短越好,最好是一个字符。

冗长的属性名虽然可读性好,但是更短的属性名存储在HBase中会更好。

转自:

HBase的rowKey设计技巧

Original: https://www.cnblogs.com/tonglin0325/p/14217501.html
Author: tonglin0325
Title: Hbase学习笔记——rowkey

原创文章受到原创版权保护。转载请注明出处:https://www.johngo689.com/14902/

转载文章受原作者版权保护。转载请注明原作者出处!

(0)

大家都在看

  • 简述神经网络的训练过程?

    简述神经网络的训练过程? 训练神经网络由以下基本步骤构成: 步骤1:神经网络的初始化(Weights Initalization):初始化权值(weights)和偏差(bias)。…

    大数据 2022年9月16日
    0152
  • Nacos

    功能相比于Eureka更加丰富 Eureka并没有停止维护,停止维护的是2.x版本(还没正式推出就已经挂掉了的版本),但是常用的是1.x版本。 功能一【注册中心】 功能类似于Eur…

    大数据 2023年3月2日
    08
  • SQL语句求交集、并集、差集

    1、A、B的交集: select * from A inner jion B on A.col = B.col 2、A、B 的对称 的差集: select * from A ful…

    大数据 2023年2月25日
    013
  • 安卓 Day 27 :数据库One

    一.基本知识点 1.采用ORMLite 它的英文全称是Object Relational Mapping,意思是对象关系映射 ORMLite 支持很多的数据库类型 在Android…

    大数据 2023年2月22日
    010
  • sqlite3_exec及其回调函数

    一)sqlite3_exec 1.头文件和函数原型 #include "sqlite3.h" int sqlite3_exec(sqlite3*, const …

    大数据 2023年2月6日
    040
  • 阿里云配置zookeeper本地连接的问题:

    1.配置yml: connect-string: 39.101.70.108:2181 保证39.101.70.108在本地命令行窗口能够ping通(购买的阿里云服务器公网IP) …

    大数据 2023年3月4日
    09
  • SpringCloud实战—第十一篇:使用Consul服务注册中心

    前言 说起来容易做起来难,一步一步都干完!!! 学习一定要自己动手搞一搞,不能只眼会。 场景大纲 我们以这样一个场景来学习、构建我们的微服务,可以看到,使用Consule做注册中心…

    大数据 2023年3月2日
    08
  • Centos安装Redis

    一、下载安装redis 1.1 新建文件夹redis,获取安装包 wget http://download.redis.io/releases/redis-5.0.5.tar.gz…

    大数据 2023年2月8日
    031
  • Docker 基础篇

    路线 Docker 概述 Docker 为什么出现 ? Docker 的历史 聊聊 Docker Docke 能干嘛? 之前的虚拟技术 容器化技术 DevOps (开发、运维) D…

    大数据 2022年9月19日
    0148
  • Dax 函数汇总(一)

    2)同比增长率VAR写法:同比增长率VAR =VAR Sales = [总销售额]VAR SalesLastYear = CALCULATE([总销售额],DATEADD(&#82…

    大数据 2023年3月6日
    06
  • RedisDesktopManager客户端可视化工具下载安装与使用

    在搭建好Redis的环境并启动后,除了使用客户端脚本连接服务端,还可以使用RedisDesktopManager客户端可视化工具。 安装 安装包下载,在公众号中回复”R…

    大数据 2023年2月9日
    028
  • Pulsar单集群搭建(centos7.x版本)

    线上集群的六台机器,组件分布为,三台机器安装zookeeper集群,另外三台分别安装bookeeper和broker集群。 每台机器上都要安装了jdk1.8版本。 (初次安装失败就…

    大数据 2023年3月3日
    09
  • [渝粤教育] 中国地质大学 战略管理 复习题 (2)

    《战略管理》模拟题单选题 1.IT行业变化快是一个典型的()A.长周期市场B.标准周期市场C.短周期市场D.不能确定 2.当购买商们具有较强的讨价还价能力时从该行业购买的产品应该属…

    大数据 2023年3月6日
    06
  • 基于 Databend 和腾讯云 COS 打造新型云数仓

    本篇文章向大家演示如何使用 Databend 基于腾讯云 COS 构建新式数仓及其计算能力。如果你也在找一个低成本、高性能、支持弹性的数仓,Databend 可以为大家提供一个基于…

    大数据 2023年2月26日
    023
  • Hbase和Hive的整合

    1、版本 hive-1.2.1 hbase-1.2.1 2、需准备 重新编译目录apache-hive-1.2.1-bin/lib下的hive-hbase-handler-1.2….

    大数据 2023年2月8日
    018
  • 交叉连接Cross Join的用法

    GPS平台、网站建设、软件开发、系统运维,找森大网络科技!https://cnsendnet.taobao.com来自森大科技官方博客http://www.cnsendblog.c…

    大数据 2023年2月17日
    012
最近整理资源【免费获取】:   👉 程序员最新必读书单  | 👏 互联网各方向面试题下载 | ✌️计算机核心资源汇总