- 1、本文档共17页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
交互式实时管理系统
第三章 交互式实时管理系统
3.1 概述
数据查询是数据库等系统的核心功能,从关系数据库开始,对查询进行优化,减少查询
的响应时间就是数据库厂商和研究人员说关注的核心问题。针对关系数据库的查询优化已经
有了很多比较成熟的技术,但是随着大数据时代的到来,数据查询这一看似简单的功能又面
临着很多新的挑战。主要原因在于:1、数据量的增大使得传统的查询优化技术很难发挥功
效;2 、用户对查询需求更加关注查询的响应时间。而有些查询类型根本就不可能通过传统
的方法来减少查询时间,譬如ad-hoc 查询。
针对上述变化,目前学术界和产业界的研究点主要集中于如何在大数据的背景下,实现
交互式的实时查询系统。这种系统主要关注两个方面,一个是交互性,还有一个就是实时。
交互性体现在用户查询过程中系统的及时反馈,只有系统的及时反馈,才能确保用户根据反
馈的结果进行下一步的查询与分析。因此实现一个交互式的实时查询系统,关键问题还是如
何实现数据的实时查询,尤其是大数据环境下的实时查询。
交互式实时查询系统在很多领域都有着广泛的应用,譬如用户去网上购买商品,常常会
根据某些属性的组合来检索合适的商品,如果系统反馈的时间过长,用户很可能失去耐心,
不再购买。这类的查询在电子商务,电信,金融等诸多领域都有着非常广泛的应用。
实现交互式的实时查询系统大体上有两种思路:一种思路是在分布式的环境下通过增加
硬件资源(CPU、内存等)来减少数据查询的时间;在这种思路的指导下,Google 开发出
了Dremel 系统,主要用于Web 数据的分析与查询。受到Dremel 的启发,很多企业开始研
发类似的产品,目前比较具有代表性的就是Cloudera 公司的Impala 系统。在Dremel 之外,
Google 还开发了PowerDrill 系统,该系统和Dremel 的应用场景不同,但是都能在极短的时
间内对海量的数据进行查询和分析。另一种思路则在数据精度和查询时间的延迟上进行了权
衡,以牺牲一定的数据精度来换取查询时间上的大幅度减少。这类系统的典型代表有 UCB
的AMP 实验室开发的BlinkDB 等。
下面会对Dremel,Powerdrill,Impala 和BlinkDB 这四个系统逐一进行分析,主要针对
其系统架构、特性和性能指标等展开介绍。同时也尽可能的尝试将同类型的系统进行初步的
对比分析。
3.2 Dremel 系统介绍
3.2.1 整体介绍
Dremel [1]是 Google 的“交互式”数据分析系统。可以组建成规模上千的集群,处理PB
级别的数据。MapReduce 处理一个数据,需要分钟级的时间。作为MapReduce 的发起人,
Google 开发了Dremel 将处理时间缩短到秒级,作为MapReduce 的有力补充。Dremel 作为
Google BigQuery 的report 引擎,获得了很大的成功。最近Apache 计划推出Dremel 的开源
实现Drill,将Dremel 的技术又推到了浪尖上。
3.2.2 系统架构
简单起见,我们只讨论在只读系统中执行query 的核心思路。很多Dremel 查询其实是
一次性的聚合,因此我们以这种类型的查询作为重点。
Dremel 使用一个多层级服务树来执行查询(如图3. 1)。
13
图3. 1 多层级服务树
一个根节点服务器接收到来的查询,从表中读取元数据,将查询路由到下一层。叶子服
务器负责与存储层通讯,或者直接在本地磁盘访问数据。
一个简单的聚合查询如下:
SELECT A, COUNT(B) FROM T GROUP BY A
当根节点服务器收到上述查询时,它确定出所有tablet (可以把一个column-stripe 理解
成一个table ,称之为T ,table 被分布式存储和查询时可认为T 进行了水平拆分,tablet 就相
当于一个分区),重写查询。各个节点返回的子查询结果(根节点是第0 层,下一层就是第
1 层,依次类推): 查询分发器。Dremel 是一个多用户系统,也就是说,多个查询通常会被
同时执行。一个查询分发器会基于table 的分区和负载均衡对query 进行调度。它还能帮助
实
您可能关注的文档
- 输电线路行波测距数据的正弦拟合自动筛选方法-电力系统保护与控制.pdf
- 发达的通信技术信息科学什么是信息科学.pdf
- 循环理论与图书馆动态经营-图书资讯学刊.pdf
- facebook实时分析-oracle.pdf
- 广东珠江三角洲清洁空气行动计划-广东环保厅.doc
- 液晶电视面板快速测试方法和实例.pdf
- psppro169-e--yhxb2017-2017mdi-宇航学报.pdf
- 建设项目环境影响评价报告表-石湫镇.doc
- partialeiv模型的非负最小二乘方差分量估计-测绘学报.pdf
- 利用平面虚拟点光源的素描图像绘制-计算机学报.pdf
- 场地脚手架工程施工方案(3篇).docx
- 2024年浙江省丽水市松阳县玉岩镇招聘社区工作者真题及参考答案详解一套.docx
- 2024年河南省郑州市惠济区古荥镇招聘社区工作者真题及答案详解一套.docx
- 2024年浙江省杭州市淳安县文昌镇招聘社区工作者真题及完整答案详解1套.docx
- 2024年浙江省台州市三门县小雄镇招聘社区工作者真题带答案详解.docx
- 2024年浙江省宁波市余姚市河姆渡镇招聘社区工作者真题及完整答案详解1套.docx
- 2024年浙江省丽水市景宁畲族自治县雁溪乡招聘社区工作者真题及答案详解一套.docx
- 2024年浙江省杭州市临安市板桥乡招聘社区工作者真题及答案详解一套.docx
- 2024年湖北省宜昌市点军区土城乡招聘社区工作者真题及答案详解一套.docx
- 2024年浙江省台州市路桥区桐屿街道招聘社区工作者真题附答案详解.docx
文档评论(0)