首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

【腾讯微视】百亿数据、上百维度、秒级查询的多维分析场景的实践方案

作者:teachzhang  腾讯PCG工程师 |导语  大数据多维分析是业务中非常常见的分析场景,目前也有许多落地方案,但是在遇到上百亿数据、维度个数不限、秒级返回结果这样的场景时,实现的时候还是遇到了一些挑战。本文介绍了一种参考kylin的预聚合模式实现的存储方案,支持对上百亿数据以及数百个维度的多维分析,并且能在秒级返回查询结果。该方案可以运用于多维指标拆解分析,异动归因分析业务场景。希望给其他有类似分析场景的同学提供一种参考方案,对本内容感兴趣的同学,欢迎一起交流学习。 1. 背景 周报场景:微视

02
您找到你想要的搜索结果了吗?
是的
没有找到

【转】多维数据查询OLAP及MDX语言笔记整理

为了满足业务管理和决策的报表系统(包括传统报表、数据仓库、OLAP等)也被创建出来,企业主管通过报表了解企业的总体运行状态。 但是,随着企业间竞争的加剧和市场节奏的进一步加快,企业的日常管理需要对关键业务指标的更加实时的监控和反馈。比如:制造业需要更及时的仓库调度、金融业需要更实时的风险防范、电信业需要更及时的服务指标监控。于是,越来越多的企业提出实时企业的要求,传统的ERP等信息系统和报表系统无法满足这些需求。实时业务监控解决方案旨在更好支撑客户此类需求。 http://www.tuicool.com/articl... 当今的数据处理大致可以分成两大类:联机事务处理OLTP(on-line transaction processing)、联机分析处理OLAP(On-Line Analytical Processing)。OLTP是传统的关系型数据库的主要应用,主要是基本的、日常的事务处理,例如银行交易。OLAP是数据仓库系统的主要应用,支持复杂的分析操作,侧重决策支持,并且提供直观易懂的查询结果。

00

【转】多维数据查询OLAP及MDX语言笔记整理

为了满足业务管理和决策的报表系统(包括传统报表、数据仓库、OLAP等)也被创建出来,企业主管通过报表了解企业的总体运行状态。 但是,随着企业间竞争的加剧和市场节奏的进一步加快,企业的日常管理需要对关键业务指标的更加实时的监控和反馈。比如:制造业需要更及时的仓库调度、金融业需要更实时的风险防范、电信业需要更及时的服务指标监控。于是,越来越多的企业提出实时企业的要求,传统的ERP等信息系统和报表系统无法满足这些需求。实时业务监控解决方案旨在更好支撑客户此类需求。 http://www.tuicool.com/articl... 当今的数据处理大致可以分成两大类:联机事务处理OLTP(on-line transaction processing)、联机分析处理OLAP(On-Line Analytical Processing)。OLTP是传统的关系型数据库的主要应用,主要是基本的、日常的事务处理,例如银行交易。OLAP是数据仓库系统的主要应用,支持复杂的分析操作,侧重决策支持,并且提供直观易懂的查询结果。

04

数据建模1,2,3

1.何为建模? 数据几乎总是用于两种目的:操作型记录的保存和分析型决策的制定。简单来说,操作型系统保存数据,分型型系统使用数据。前者一般仅反映数据的最新状态,按单条记录事务性来处理;其优化的核心是更快地处理事务。后者往往是反映数据一段时间的状态变化,按大批量方式处理数据;其核心是高性能、多维度处理数据。通常我们将操作型系统简称为OLTP(On-Line Transaction Processing)— 联机事务处理,将分析型系统简称为OLAP(On-Line Analytical Processing)— 联机分析处理。 针对这两种不同的数据用途,如何组织数据,更好地满足数据使用需求。这里就涉及到数据建模问题。即设计一种数据组织方式(模型),来满足不同场景。在OLTP场景中,常用的是使用实体关系模型(ER)来存储,从而在事务处理中解决数据的冗余和一致性问题。在OLAP场景中,有多种建模方式有:ER模型、星型模型和多维模型。下面分别说明下:

05

OLAP在线分析引擎介绍及应用场景

核心原理: 1. 多维数据模型: OLAP的核心是一个多维数据模型,通常体现为数据立方体(Data Cube)。数据立方体由维度(Dimensions)、层次(Levels)和度量(Measures)组成。维度代表分析的角度,如时间、地理位置或产品类型;层次则提供了维度内的粒度细化,如年、季度、月;度量是分析的具体数值,如销售额、利润等。 2. 预计算与缓存: 为了加快查询速度,OLAP引擎通常采用预计算(Precomputation)策略,通过预先计算并存储可能的查询结果(如聚合数据),减少实时计算负担。这包括使用技术如cube构建,其中汇总数据被提前计算并存储起来,以便快速响应查询。 3. MPP架构(Massively Parallel Processing): 许多现代OLAP引擎采用MPP架构,如Apache Kylin和ClickHouse,这种架构中,数据分布在多个节点上,每个节点独立处理自己的数据部分,然后汇总结果。MPP系统提供了水平扩展性,能够处理PB级别的数据集,并保持高性能。 4. 列式存储: 与传统的行式存储相比,OLAP引擎常采用列式存储,这种存储方式特别适合于数据分析场景,因为它可以显著加速涉及大量聚合操作的查询。列式存储减少了需要读取的数据量,并且可以更有效地利用CPU的向量化执行能力。 5. 向量化执行引擎: 一些OLAP引擎,如ClickHouse,采用了向量化执行引擎,这意味着它们会批量处理数据而不是逐行处理,从而提高了CPU的利用率和处理速度。SIMD(Single Instruction Multiple Data)指令集进一步优化了这种处理方式。 6. 索引与压缩: 为了提高数据访问速度,OLAP引擎使用高效的索引结构,如稀疏索引和B树,以及数据压缩技术,减少存储空间需求并加速数据检索过程。 7. 实时与近实时处理: 随着技术的发展,一些OLAP引擎如Apache Druid,专注于实时或近实时分析,能够在数据流入系统后几乎立即对其进行处理和分析,满足即时决策支持的需求。 OLAP引擎能够在大数据环境下提供快速、灵活的分析能力,支撑企业决策和业务洞察。

01

【ETL技能】白话数据仓库 ETL 搭建全过程

经过多年来企业信息化建设,大部分都拥有了自己的财务,OA,CRM 等软件。这些系统都有自己的独立数据库,记录着企业运行情况某个方面的数据。但是单独看这些系统的报表,并不一定能对企业运行情况有全面客观的了解。就像只凭身高不能判断一个人是否健康,所以体检的时候我们需要化验许多指标,做各种检测,就是为了对身体情况有更全面的了解,作出更准确的判断。 同样对一个企业,不能仅根据出勤率就判断一个人的绩效高低,因为你不知道他的工作成果情况。仅根据财务报表输入支出也体现不了各部门的收益情况,这个部门有多少工作人员,完成了哪

010
领券