百摩网
当前位置: 首页 生活百科

kylin 部署(Kylin构建Cube过程详解)

时间:2023-06-03 作者: 小编 阅读量: 1 栏目名: 生活百科

2Cube示例以手机销售为例,表SALE记录各手机品牌在各个国家,每年的销售情况。表PHONE是手机品牌,表COUNTRY是国家列表,两表通过外键与SALE表相关联。手机品牌的个数可用于表示手机品牌列的基度。为了平衡作业,kylin增加这一步“重新分配”数据。首先,kylin获取到这中间表的行数,然后根据行数的数量,它会重新分配文件需要的数据量。

kylin 部署?1 前言在使用Kylin的时候,最重要的一步就是创建cube的模型定义,即指定度量和维度以及一些附加信息,然后对cube进行BUILD,当然我们也可以根据原始表中的某一个string字段(这个字段的格式必须是日期格式,表示日期的含义)设定分区字段,这样一个cube就可以进行多次build,每一次的build会生成一个segment,每一个segment对应着一个时间区间的cube,这些segment的时间区间是连续并且不重合的,对于拥有多个segment的cube可以执行merge,相当于将一个时间区间内部的segment合并成一个下面开始分析cube的build过程,下面我们就来聊聊关于kylin 部署?接下来我们就一起去了解一下吧!

kylin 部署

1 前言

在使用Kylin的时候,最重要的一步就是创建cube的模型定义,即指定度量和维度以及一些附加信息,然后对cube进行BUILD,当然我们也可以根据原始表中的某一个string字段(这个字段的格式必须是日期格式,表示日期的含义)设定分区字段,这样一个cube就可以进行多次build,每一次的build会生成一个segment,每一个segment对应着一个时间区间的cube,这些segment的时间区间是连续并且不重合的,对于拥有多个segment的cube可以执行merge,相当于将一个时间区间内部的segment合并成一个。下面开始分析cube的build过程。

2 Cube示例

以手机销售为例,表SALE记录各手机品牌在各个国家,每年的销售情况。表PHONE是手机品牌,表COUNTRY是国家列表,两表通过外键与SALE表相关联。这三张表就构成星型模型,其中SALE是事实表,PHONE、COUNTRY是维度表。

现在需要知道各品牌手机于2010-2012年,在中国的总销量,那么查询sql为:

SELECT b.`name`, c.`NAME`, SUM(a.count)FROM SALE AS a LEFT JOIN PHONE AS b ON a.`pId`=b.`id` LEFT JOIN COUNTRY AS c ON a.`cId`=c.`id` WHERE a.`time` >= 2010 AND a.`time` <= 2012 AND c.`NAME` = "中国"GROUP BY b.`NAME`

其中时间(time), 手机品牌(b.name,后文用phone代替),国家(c.name,后文用country代替)是维度,而销售数量(a.count)是度量。手机品牌的个数可用于表示手机品牌列的基度。各手机品牌在各年各个国家的销量可作为一个cuboid,所有的cuboid组成一个cube,如下图所示:

上图展示了有3个维度的cube,每个小立方体代表一个cuboid,其中存储的是度量列聚合后的结果,比如苹果在中国2010年的销量就是一个cuboid。

3 入口介绍

在kylin的web页面上创建完成一个cube之后可以点击action下拉框执行build或者merge操作,这两个操作都会调用cube的rebuild接口,调用的参数包括:

    cube名,用于唯一标识一个cube,在当前的kylin版本中cube名是全局唯一的,而不是每一个project下唯一的;

    本次构建的startTime和endTime,这两个时间区间标识本次构建的segment的数据源只选择这个时间范围内的数据;对于BUILD操作而言,startTime是不需要的,因为它总是会选择最后一个segment的结束时间作为当前segment的起始时间。

    buildType标识着操作的类型,可以是”BUILD”、”MERGE”和”REFRESH”。

4 构建Cube过程

Kylin中Cube的Build过程,是将所有的维度组合事先计算,存储于hbase中,以空间换时间,HTable对应的RowKey,就是各种维度组合,指标存在Column中,这样,将不同维度组合查询SQL,转换成基于RowKey的范围扫描,然后对指标进行汇总计算,以实现快速分析查询。整个过程如下图所示:

主要的步骤可以按照顺序分为几个阶段:

    根据用户的cube信息计算出多个cuboid文件;

    根据cuboid文件生成htable;

    更新cube信息;

    回收临时文件。

    每一个阶段操作的输入都需要依赖于上一步的输出,所以这些操作全是顺序执行的。下面对这几个阶段的内容细分为11步具体讲解一下:

4.1 创建Hive事实表中间表(Create Intermediate Flat Hive Table)

这一步的操作会新创建一个hive外部表,然后再根据cube中定义的星状模型,查询出维度和度量的值插入到新创建的表中,这个表是一个外部表,表的数据文件(存储在HDFS)作为下一个子任务的输入。

4.2 重新分配中间表(Redistribute Flat Hive Table)

在前面步骤,hive会在HDFS文件夹中生成数据文件,一些文件非常大,一些有些小,甚至是空的。文件分布不平衡会导致随后的MR作业不平衡:一些mappers作业很快执行完毕,但其它的则非常缓慢。为了平衡作业,kylin增加这一步“重新分配”数据。首先,kylin获取到这中间表的行数,然后根据行数的数量,它会重新分配文件需要的数据量。默认情况下,kylin分配每100万行一个文件。

4.3 提取事实表不同列值 (Extract Fact Table Distinct Columns)

在这一步是根据上一步生成的hive中间表计算出每一个出现在事实表中的维度列的distinct值,并写入到文件中,它是启动一个MR任务完成的,它关联的表就是上一步创建的临时表,如果某一个维度列的distinct值比较大,那么可能导致MR任务执行过程中的OOM。

4.4 创建维度字典(Build Dimension Dictionary)

这一步是根据上一步生成的distinct column文件和维度表计算出所有维度的子典信息,并以字典树的方式压缩编码,生成维度字典,子典是为了节约存储而设计的。每一个cuboid的成员是一个key-value形式存储在hbase中,key是维度成员的组合,但是一般情况下维度是一些字符串之类的值(例如商品名),所以可以通过将每一个维度值转换成唯一整数而减少内存占用,在从hbase查找出对应的key之后再根据子典获取真正的成员值。

4.5 保存Cuboid的统计信息(Save Cuboid Statistics)

计算和统计所有的维度组合,并保存,其中,每一种维度组合,称为一个Cuboid。理论上来说,一个N维的Cube,便有2的N次方种维度组合,参考网上的一个例子,一个Cube包含time, item, location, supplier四个维度,那么组合(Cuboid)便有16种:

4.6 创建HTable

创建一个HTable的时候还需要考虑一下几个事情:

    列簇的设置。

    每一个列簇的压缩方式。

    部署coprocessor。

    HTable中每一个region的大小。

    在这一步中,列簇的设置是根据用户创建cube时候设置的,在HBase中存储的数据key是维度成员的组合,value是对应聚合函数的结果,列簇针对的是value的,一般情况下在创建cube的时候只会设置一个列簇,该列包含所有的聚合函数的结果;

    在创建HTable时默认使用LZO压缩,如果不支持LZO则不进行压缩,在后面kylin的版本中支持更多的压缩方式;

    kylin强依赖于HBase的coprocessor,所以需要在创建HTable为该表部署coprocessor,这个文件会首先上传到HBase所在的HDFS上,然后在表的元信息中关联,这一步很容易出现错误,例如coprocessor找不到了就会导致整个regionServer无法启动,所以需要特别小心;region的划分已经在上一步确定了,所以这里不存在动态扩展的情况,所以kylin创建HTable使用的接口如下:

    public void createTable(final HTableDescriptor desc , byte [][] splitKeys)

4.7 用Spark引擎构建Cube(Build Cube with Spark)

在Kylin的Cube模型中,每一个cube是由多个cuboid组成的,理论上有N个普通维度的cube可以是由2的N次方个cuboid组成的,那么我们可以计算出最底层的cuboid,也就是包含全部维度的cuboid(相当于执行一个group by全部维度列的查询),然后在根据最底层的cuboid一层一层的向上计算,直到计算出最顶层的cuboid(相当于执行了一个不带group by的查询),其实这个阶段kylin的执行原理就是这个样子的,不过它需要将这些抽象成mapreduce模型,提交Spark作业执行。使用Spark,生成每一种维度组合(Cuboid)的数据。Build Base Cuboid Data;Build N-Dimension Cuboid Data : 7-Dimension;Build N-Dimension Cuboid Data : 6-Dimension;……Build N-Dimension Cuboid Data : 2-Dimension;Build Cube。

4.8 将Cuboid数据转换成HFile(Convert Cuboid Data to HFile)

创建完了HTable之后一般会通过插入接口将数据插入到表中,但是由于cuboid中的数据量巨大,频繁的插入会对Hbase的性能有非常大的影响,所以kylin采取了首先将cuboid文件转换成HTable格式的Hfile文件,然后在通过bulkLoad的方式将文件和HTable进行关联,这样可以大大降低Hbase的负载,这个过程通过一个MR任务完成。

4.9 导HFile入HBase表(Load HFile to HBase Table)

将HFile文件load到HTable中,这一步完全依赖于HBase的工具。这一步完成之后,数据已经存储到HBase中了,key的格式由cuboid编号 每一个成员在字典树的id组成,value可能保存在多个列组里,包含在原始数据中按照这几个成员进行GROUP BY计算出的度量的值。

4.10 更新Cube信息(Update Cube Info)

更新cube的状态,其中需要更新的包括cube是否可用、以及本次构建的数据统计,包括构建完成的时间,输入的record数目,输入数据的大小,保存到Hbase中数据的大小等,并将这些信息持久到元数据库中。

4.11 清理Hive中间表(Hive Cleanup)

这一步是否成功对正确性不会有任何影响,因为经过上一步之后这个segment就可以在这个cube中被查找到了,但是在整个执行过程中产生了很多的垃圾文件,其中包括:

    临时的hive表;

    因为hive表是一个外部表,存储该表的文件也需要额外删除;

    fact distinct这一步将数据写入到HDFS上为建立子典做准备,这时候也可以删除了;

    rowKey统计的时候会生成一个文件,此时可以删除;

    生成HFile时文件存储的路径和hbase真正存储的路径不同,虽然load是一个remove操作,但是上层的目录还是存在的,也需要删除。

至此整个Build过程结束。

订阅关注微信公众号《大数据技术进阶》,及时获取更多大数据架构和应用相关技术文章!

    推荐阅读
  • 最甜馒头做法(最甜馒头怎么做)

    最甜馒头做法食材:面粉250克、酵母2克、水130克、糖15克面粉称好后,加糖和酵母,用筷子搅几下使之均匀。水称好后,分三次左右倒入面粉中,用一双筷边倒边搅拌。最后的面团成品。放在20度的室温下发酵1.5-2小时。发酵后面团会成倍增加,用手或筷子按下去不会反弹。贴板上洒些干面粉,然后面团揉成长条,用刀切成块。冷水下锅,二次发酵20分钟。烧开后小火3分钟,再转大火12分钟,共15分钟。

  • php外贸网站价格(这个丑陋网站做了7个月)

    更过分的是,整个右边栏都是AdSense广告不说,还因为宽度设置不对,留了一大块难看的空白。我把它托管在HostGator主机上,每年主机费用是60美元,一个月5美元。网站的流量主要来自Google,有几个关键词在google上排到了第一位,这些关键词每个月的搜索量总共超过了100K。这个网站的收入全部来自GoogleAdsense和Amazon联盟。最近的两个月的平均收入超过了1000美元。

  • 属牛人几月份几时出生最好(三大农历月份出生属牛人)

    生于农历九月的生肖属牛人,他们通常有着超乎常人的胆识和智慧,以及十分充沛的精力,所以他们能在事业上做出一番非凡的大成就,在农历九月生的生肖属牛人,是集智谋与权利于一身的成大事之能人。

  • 魔兽世界9.0前夕必拿橙装(你的橙装毕业了吗)

    虽说“神器”已然不在,但“橙装”还是要有的,要不玩啥?而就在这几天,小编的“橙装”毕业了。我很早的时候就从它那里获得了一个橙,也是唯一的一件橙装!不过,有一点颇令人奇怪,我从没有在副本、地下城中获得过任何“橙装”,只是看过别人得到过!好啦,今天的魔兽世界就介绍到这里,我们下期不见不散!

  • 刷脚垫小窍门(怎样刷洗脚踏垫干净)

    泡过的脚踏垫用刷子刷一刷,放在卫生间的地面上刷,再沾水反复刷2~3次。在脚踏垫上放洗涤剂或洗衣粉,用刷子均匀地刷一刷,污渍深的位置,可以局部加洗涤剂或洗衣粉,再次刷洗。将刷好的脚踏垫再次放入盆中,用刷子刷洗洗涤剂,此时可以用刷子刷一点肥皂,刷垫,这样可以帮助消除泡沫。待水稍空不滴水时,将洗好的脚踏垫放在有阳光的地方晾晒即可。

  • 杜鹃阮经天吻戏(纽约纽约开机阮经天苗侨伟杜鹃情仇)

    《纽约纽约》北美开机仪式华谊兄弟出品,由新锐导演罗冬执导,关锦鹏监制的电影《纽约纽约》日前在纽约正式开机。陈赫随后穿上性感内裤,在镜子前摆出各种贱贱的pose,一展雄风;之后又去找室友张鲁一借套套。最后,陈赫帅气地出现在Angelababy家门口,面对出乎意料的美貌女神,依旧不卑不亢。而准备充分的陈赫此次约会进展如何,神器是否都物尽其用,最终还需要去影院一探究竟。

  • 王者荣耀的隐身状态会被发现吗(王者荣耀隐身别人知不知道)

    王者荣耀的隐身状态会被发现吗?每周一凌晨五点刷新使用次数。关于王者荣耀隐身功能什么时候全服开放,玩家看到的更新公告显示的是一批一批开通,就和之前荣耀战区一样,部分服务器先开,剩下的服务器逐步开放,直到全服,但是究竟什么时间才能全部开放,公告上并没有写。

  • 北京大学心理学研究生分析(北京大学心理学考研专硕学姐)

    确定考研以及考研专业是我在大三上学期决定了的,但是知道大三下学期差不多去年4月初才最终确定了考北大的应用心理。从10月中旬到考试前,我大概完成了5-6轮的专业课背诵,尤其是后期用莫扎特手册背诵时,以题目为单位背诵起来十分方便。然后说一下冲刺阶段复习用到的莫扎特手册、临门一题和院校真题及模拟题。

  • 重庆城口县旅游攻略(重庆城口县十大景点有哪些)

    保护区总面积136017公顷,属于森林生态系统类型自然保护区。主要保护对象是亚热带森林生态系统及其生物多样性,不同自然地带的典型自然景观,典型森林野生动植物资源。全长101.6公里,车程2小时38分钟。全长61.1公里,车程1小时20分钟。下午自驾至巴山湖国家湿地公园,游玩巴山湖国家湿地公园。漂流长度6公里,落差达130多米。

  • 畜牧学概论心得(畜牧学概论复习资料)

    12.品系:指一些具有突出特点,并能将这些优点相对稳定地遗传给后代的种畜群。