zoukankan      html  css  js  c++  java
  • Hbase表设计

    HBase与RDBMS的区别: Hbase的cell具有版本描述(versioned),行是有序的,列(Qualifier)在所属列簇(column families)存在是,由客户端添加。

    1. Hbase中没有Joins的概念。如果要join,在设计的时候,要考虑用大表的思维解决。
    2. Row Keys设计: 主键,在region里按字母顺序排列(Byte数组)。写入的时候要分散,避免造成数据只保存在几个结点上,如order表 可以把order id 做reverse 操作用于row key。

                       注:多个条件查询,可以选择组合rowkey。

                              读取数据时候,只能按rowkey或者scan全表

             3.列簇CF设计:尽量CF的数量1-2个。设计hbase shema的时候。要尽量只有一个column family

             Flush: MemStore 中的数据达到一定的阈值,被Flush成HDFS中的HFile文件。

             Compaction: 可以把多个HFile的”交错无序状态“,变成单个Hfile的”有序状态“,降低读取时延。

                

               引:http://baijiahao.baidu.com/s?id=1596690073555129451&wfr=spider&for=pc

               案例:

                      1. 学生表,课程表,多对多。

                        RDBMS:

                        

                        Hbase:

                       

                     2. person  身份证表  1:1

                        RDBMS

                      

                      Hbase:

                      

                   3. 订单: roder表和order detail       1:N

                     RDBMS

                     

  • 相关阅读:
    备忘录 | ‘神器’在手,新世界大门我有
    1001种玩法 | HotswapAgent:支持无限次重定义运行时类与资源
    面面观 | CentOS install etcd 测试
    控制台、终端、虚拟终端和伪终端
    KMP算法,BoyerMoore算法
    qemu kvm 虚拟化
    web端log4net输出错误日志到mysql
    JQuery调用WCF服务,部署在iis
    首篇
    微信支付接口
  • 原文地址:https://www.cnblogs.com/Jesse-Li/p/8967682.html
Copyright © 2011-2022 走看看