Kylin 入门指北

1. Background

在数仓指标中,多维度分析是一种常见的需求。当多个维度不确定具体组合时,需要我们在 hive 层使用 group by cube 或者手动优化 group by 的组合来实现。 Kylin 在离线数仓中主要解决的问题便是在超大规模数据集上的多维度分析,通过预计算并结合 HBase,能做到在亚秒级响应。Kylin 可以简单理解为对接 DWD 层事实表的多维聚合分析工具。

2. Basic

2.1 Kylin 架构

Kylin 架构

从架构图中可以看到,Kylin 除了可以对接 Hive 外,还可以对接实时数据、关系型数据库等。而亚秒级的响应速度除了预计算,还得益于底层的数据存储 HBase。

2.2 Kylin 搭建

首先下载 Kylin 并解压。需要配置三个环境变量,分别是 HADOOP_HOME, HIVE_HOME, HBASE_HOME。Kylin 启动前的依赖分别是 HADOOP(HDFS,Yarn,jobhistoryserver)、Zookeeper、HBase。全部配置好以后通过 WEB 页面访问,初始用户名为 ADMIN、密码是 KYLIN。


WEB 首页

2.3 Kylin 使用

2.3.1 创建 project

创建 project

2.3.2 获取数据源

获取数据源

2.3.3 创建 Model

选择事实表并关联维度表

选择需要统计的维度

确定度量值

指定事实表分区

2.3.4 构建 Cube

创建 cube

选择 model 并指定 cube 名称

添加维度( model 中指定的维度不一定在 Cube 中全部使用)

指定 Cube 中使用的维度

为度量值添加聚合函数

设置度量值的聚合函数

构建 Cube

选择事实表构建 Cube 的分区范围

监控 Cube 构建过程

3. Deep

3.1 维度表多个相同 Key 处理

外键重复错误
  • 错误原因
    事实表通过分区字段筛选出的数据和全量的维度表进行 join,事实表中的 key(外键)对应维度表中多个 key 的时候,导致出错。
  • 解决方案
    创建维度表的一份最新完整数据作为视图

3.2 每日自动构建 Cube

使用 Restful API 将暴露的接口通过 http 请求的方式写入脚本

3.3 Cube 构建原理

3.3.1 Cube & Cuboid

对于 N 个维度来说,组合的所有可能性共有 2^n 种。对于每一种维度的组合,将度量值做聚合计算,然后将结果保存为一个物化视图,称为 Cuboid。所有维度组合的 Cuboid 作为一个整体,称为 Cube。

3.3.2 Cube 存储结构

维度字典表

Rowkey=Cuboid_id(1表示统计该维度,0表示忽略该维度) + 维度值对应的字典表中的value

3.3.3 构建算法

  • 逐层构建
    第一层由原始数据对所有维度进行聚合,剩下所有层基于上一层聚合结果降一维进行聚合
  • 快速构建
    利用 Mapper 端计算先完成大部分聚合,再将聚合后的结果交给 Reducer,从而降低对网络瓶颈的压力。该算法的主要思想是,对 Mapper 所分配的数据块,将它计算成一个完整的小 Cube 段(包含所有 Cuboid );每个 Mapper 将计算完的 Cube 段输出给 Reducer 做合并,生成大 Cube

3.4 Cube 构建优化

3.4.1 使用聚合组

聚合组是一种 Cuboid 剪枝工具,可以使用以下三种方式进行维度剪枝

  • 强制维度
  • 层级维度:A->B 作为层级,B不会单独出现。参考省市区层级,不会单独出现区

    联合维度,AB要么同时出现要么同时不出现

3.4.2 Row Key 优化

  • 被用作查询语句中 where 过滤条件的维度放在前面,HBase 查询的时候可以提高效率


    where 过滤条件的维度放在前面
  • 基数大的维度放在基数小的维度前面


    基数大的维度放在基数小的维度前面
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 218,546评论 6 507
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 93,224评论 3 395
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 164,911评论 0 354
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,737评论 1 294
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,753评论 6 392
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,598评论 1 305
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,338评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,249评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,696评论 1 314
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,888评论 3 336
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 40,013评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,731评论 5 346
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,348评论 3 330
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,929评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 33,048评论 1 270
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,203评论 3 370
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,960评论 2 355