一、数据热点
hbase的表的多个region中有一个region的读写并发很高,其他的region相对来说读写少,造成热点的region

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

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

1.3反转
第三种防止热点的方法是反转固定长度或者数字格式的 rowkey。这样可以使得 rowkey中经常改变的部分(最没有意义的部分)放在前面。这样可以有效的随机 rowkey,但是牺 牲了 rowkey 的有序性。
反转 rowkey 的例子以手机号为 rowkey,可以将手机号反转后的字符串作为 rowkey,这 样的就避免了以手机号那样比较固定开头导致热点问题

1.4时间戳反转
一个常见的数据处理问题是快速获取数据的最近版本,使用反转的时间戳作为 rowkey的一部分对这个问题十分有用,可以用 Long.Max_Value - timestamp 追加到 key 的末尾

二、hbase设计

1、hbase 预分区
默认情况下,在创建 HBase 表的时候会自动创建一个 region 分区,当导入数据的时候,所有的 HBase 客户端都向这一个 region 写数据,直到这个 region 足够大了才进行切分。还有一种是可以加快批量写入速度的方法,就是通过预先创建一些空的 regions,这样当数据写入 HBase 时,会按照 region 分区情况,在集群内做数据的负载均衡。

2、列簇设计
1)具备相同的io属性的放在一个列簇里
2)经验值,列簇设计不要超过3个,最好一个

3、行键的设计
三个原则
1)唯一性

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

2) rowkey 长度原则

Rowkey 是一个二进制码流,Rowkey 的长度被很多开发者建议说设计在 10~100 个字节,不过建议是越短越好,不要超过 16 个字节。
原因如下:
1、数据的持久化文件 HFile 中是按照 KeyValue 存储的,如果 Rowkey 过长比如 100 个字节,1000 万列数据光 Rowkey 就要占用 100*1000 万=10 亿个字节,将近 1G 数据,这会极大影响 HFile 的存储效率;
2、MemStore 将缓存部分数据到内存,如果 Rowkey 字段过长内存的有效利用率会降低, 系统将无法缓存更多的数据,这会降低检索效率。因此 Rowkey 的字节长度越短越好。
3、目前操作系统是都是 64 位系统,内存 8 字节对齐。控制在 16 个字节,8 字节的整数倍利用操作系统的最佳特性。

3)rowkey 散列原则

如果 Rowkey 是按时间戳的方式递增,不要将时间放在二进制码的前面,建议将 Rowkey 的高位作为散列字段,由程序循环生成,低位放时间字段,这样将高位数据均衡分布在每个 Regionserver 实现负载均衡的几率。如果没有散列字段,首字段直接是时间信息将产生所有新数据都在一个 RegionServer 上堆积的热点现象,这样在做数据检索的时候负载将会集中在个别RegionServer,降低查询效率。


Hbase设计,数据热点问题相关推荐

  1. Hbase设计数据热点问题

    一.数据热点 hbase的表的多个region中有一个region的读写并发很高,其他的region相对来说读写少,造成热点的region 一定要避免数据热点的问题! 1.防止数据热点的有效措施 1. ...

  2. HBase的数据热点和Hbase常见避免热点问题的方法

    只要使用过,听说过HBase的人,我想对HBase的数据热点想必也不会陌生. 数据热点是如何出现的,这得从HBase的存储结构说起,对于HBase详细的存储结构可以上网搜一下,这里就不补充了. 我们只 ...

  3. 如何解决hbase中数据热点问题

    所谓数据热点, 指的是大量的数据写到hbase的某一个或者某几个region中, 导致其余的region没有数据, 其他region对应regionServer的节点承受了大量的并发请求, 此时就出现 ...

  4. 企业级数据仓库:数据仓库概述;核心技术框架,数仓理论,数据通道Hive技术框架,HBase设计,系统调度,关系模式范式,ER图,维度建模,星型/雪花/星座模式,数据采集同步,业务数据埋点,数据仓库规范

    文章目录 第一章 数据仓库概述 1.1 数据仓库简介 1.1.2 什么是数据仓库? 1.1.3 OLTP 与 OLAP 1.2 数据仓库技术架构 1.3 课程目标 第二章 核心技术框架 2.1 数据仓 ...

  5. hbase 二进制数据写入_分布式数据库HBase的架构设计详解(有彩蛋)

    原标题:分布式数据库HBase的架构设计详解(有彩蛋) 本文根据DBAplus社群第99期线上分享整理而成,文末还有好书送哦~ 讲师介绍 陈鸿威 云财经大数据CTO 曾任百度高级工程师,现主持设计开发 ...

  6. Hbase写数据,存数据,读数据的详细过程

    Client写入 -> 存入MemStore,一直到MemStore满 -> Flush成一个StoreFile,直至增长到一定阈值 -> 出发Compact合并操作 -> 多 ...

  7. Designing Data-Intensive Applications(设计数据密集应用)- O'Reilly 2017 读书笔记

    Designing Data-Intensive Applications The Big Ideas Behind Reliable, Scalable, and Maintainable Syst ...

  8. Hbase 设计与开发实战

    Hbase 概述 大数据及 NoSQL 的前世今生 传统的关系型数据库处理方式是基于全面的 ACID 保证,遵循 SQL92 的标准表设计模式(范式)和数据类型,基于 SQL 语言的 DML 数据交互 ...

  9. 设计数据密集型应用 第六章:分区

    6. 分区 我们必须跳出电脑指令序列的窠臼. 叙述定义.描述元数据.梳理关系,而不是编写过程. -- Grace Murray Hopper,未来的计算机及其管理(1962) 文章目录 6. 分区 术 ...

最新文章

  1. 程序员因中年危机从北京回老家事业单位:工资从60万爆降到6万
  2. 有没有简单优雅的方法来定义单例? [重复]
  3. C 语言编程 — GCC 工具链
  4. JavaParser生成,分析和修改Java代码
  5. java.math.BigDecimal记录
  6. hci0 没反应_哄女朋友专用表情包~你说你没女朋友?先收藏着嘛,万一有了呢?...
  7. 【小记】-007--前端SEO优化
  8. 【总结】大端、小端存储模式的那点事
  9. php客户端和服务器的值传递
  10. 计算机二级通关宝典-C语言篇
  11. abaqus2018安装教程win10_win10环境下如何安装abaqus6.12?windows10环境安装abaqus6.12的方法...
  12. 在Windows x64中加载驱动
  13. android 关闭软键盘失去焦点,Android edittext 点击其他处 失去焦点和关闭软键盘
  14. 谷歌身份验证器验证码不对怎么回事_兼容谷歌验证器,开源的动态验证码小程序了解一下...
  15. Failed to introspect annotated methods on class 异常
  16. h5调起app的方法;app调起vue中的某个方法
  17. 华为交换机S5735S如何堆叠iStack
  18. train_test_split(),随机划分训练集和测试集的函数
  19. linux系统忘记登录密码怎么办
  20. Bcftools的下载与安装

热门文章

  1. 微信小程序怎么嵌入手机版的网页?
  2. 你可能知道皮实省油 却不知道这款SUV全新升级还限量了
  3. Acwing 1077.皇宫看守
  4. Android LocalBroadcastManager 注册广播和直接registerReceiver的区别
  5. 题35.C++练习-3-3快速幂 等比数列求和
  6. DRGS 分组器源码
  7. 计算机重置网络后,win10重置网络后以太网和wlan状态都显示..._网络编辑_帮考网...
  8. 51单片机STC89C52点亮一个LED(IO口的位操作)
  9. pic单片机c语言乘除法,PIC单片机C语言编程教程(1)
  10. latex教程: 1.1-历史