目录

前言

一、StarRocks在贝壳的应用现状

1.1 历史的数据分析架构

1.2 OLAP选型

1.2.1  离线场景

1.2.2 实时场景

1.2.3 StarRocks 的引入

二、StarRocks 在贝壳的分析实践

2.1 指标分析

2.2 实时业务

2.3 可视化分析

三、未来规划

3.1 StarRocks集群的稳定性

3.2 StarRocks 新特性采用


    原文大佬的这篇贝壳找房数仓实践的文章整体写的很深入,这里摘抄下来用作学习和知识沉淀。

前言

   贝壳找房是国内最大的在线房产交易平台之一,利用大数据技术进行房源的挖掘和匹配,通过数据分析和挖掘,更准确地了解用户需求,并为用户提供个性化的房源推荐和交易服务
    随着数据和业务规模的增长,传统数仓的分析能力面临很大的挑战,贝壳需要引入新兴的数据湖技术来支撑业务的发展。在指标分析场景、实时业务场景采用StarRocks替换原有的Kylin、Clickhouse 等组件,业务性能上有 5-6 倍性能提升;同时,贝壳也开始推动 StarRocks 替换 Presto 的场景,进一步简化架构,实现分析层的统一,与 StarRocks 社区共建极速统一的湖仓新范式。

一、StarRocks在贝壳的应用现状

1.1 历史的数据分析架构

  早期为了支持多样化的分析能力,引入了多种OLAP引擎以支持不同的场景,其中包括:

  • Kylin、Druid:用于高QPS的指标查询、报表系统等(高并发)

  • Presto、Impala:基于Hive数据分析

  • ClickHouse :用于支撑用户分析、风控等实时业务

     随着使用规模的扩大,维护成本越来越高,在扩展引擎数量的同时,必须要考虑上下游配套产品的兼容性改造,由于每个引擎的特殊性,适配的开发成本也很高,随着引擎数量的增加和特性迭代,这方面的工作量越来越大。尽管数据开发平台已经在很大程度上屏蔽了引擎的使用细节,但随着业务的深入使用,某些场景可能需要使用引擎的高级特性支持。一些业务逻辑需要沉淀到引擎底层,增加了业务模型的开发维护成本

1.2 OLAP选型

1.2.1  离线场景

   最初使用kylin进行指标分析,Kylin是一种空间换时间的方案,并且依赖于HDFS 和HBase。此外,Kylin在维度计算方面需要较长的构建时间,查询性能受到HBase的限制,调优成本较高。

Druid的引入虽然解决了以上问题,Druid 的引入虽然解决了以上问题,但Druid本身也存在一些局限性,比如 SQL 能力较弱,不支持JOIN操作。对于数据分析产品来说,如果只能使用宽表,但宽表模型的问题较为显著,即一旦维度有所变化,其回溯的成本是很高的

1.2.2 实时场景

    ClickHouse 主要是支撑实时分析场景,但在运维成本、更新操作,高并发和Join等场景有诸多限制。

  从总体来看面临以下比较严重问题:

  • 复杂、灵活的业务模型要求
  • 高性能的查询和高稳定性
  • 多引擎的高运维成本

1.2.3 StarRocks 的引入

    带着这些问题开始调研市场上新兴的 OLAP 技术,发现 StarRocks 能够完全解决以上痛点。2021 年 StarRocks 在贝壳落地,截止 2022 年底,StarRocks 在占据了近 70% 的流量份额。生产环境共有 10 集群在使用,大规模集群 BE节点 40个,小规模集群 BE 节点数 5~10个。

   规模:

  • 存储总量80TB
  • 日均写入的数据量12TB,其中离线7TB,实时5TB
  • 日均的查询量是1400万次

二、StarRocks 在贝壳的分析实践

  引入StarRocks最要的目标是解决多引擎的问题,接下来通过 3 个场景来介绍各引擎如何统一到 StarRocks 上。

2.1 指标分析

   离线分析场景:Druid To StarRocks

   指标开发分为3个阶段:

  • 数据准备:数据开发人员准备 Hive 表和 StarRocks 表
  • 指标开发:基于元数据进行模型和指标开发
  • 模型构建:将模型转换到具体引擎的实现

   在模型构建阶段,使用 Spark任务将Hive数据同步到StarRocks 中,使用Flink同步Kafka中的数据。

   在指标分析场景中引入StarRocks,需要关注的主要问题有两个:
(1)建表:

  •  离线场景:数据来源于Hive,可以进行数据内容探测,根据数据量自动计算分桶数(StarRocks自动分桶策略),根据实践经验,慢查询sql中有很大一部分是模型问题导致(模型表选择、分区分桶选择等),智能化建表模式能更好的适配业务。
  • 实时场景:虽然可以预估数据规模来生成表模型,但是业务的增长和发展是难以预估的,因此,对事实表通过添加定期巡检任务进行周期性的检测,根据历史数据规模评估表的分区和分桶是否合理,定时向用户反馈,协助用户进行模型优化。

(2)数据导入:

  • 临时分区:采用临时分区来解决导入期间无法查询的问题
  • 预聚合:Spark任务将Hive数据同步到StarRocks的过程中,先在spark阶段对数据进行部分计算,以降低导入过程中BE节点的资源消耗,由于大量的导入通常发生在晚上0点至凌晨6点之间,并伴随着离线导入的高峰期,提前进行聚合可以减轻compaction的压力。

  • 高基数的字符列精确去重:需要兼容之前的字符精确去重场景( Kylin、 Druid)使用 Hive 的全局字典来实现去重列编码。去重计数列使用bitmap类型,查询性能提高约3到4倍,在高QPS场景下,集群吞吐能力提升明显。

2.2 实时业务

  实时分析场景:ClickHouse To StarRocks

 ClickHouse不支持直接的update操作,因此需要通过使用视图和 argMax() 函数计算最新数据以达到实时更新的目的。对一个复杂的模型而言,需要为每一张表都创建对应的视图,最终要多张表和视图才能实现,如图 7 所示:

   ClickHouse 涉及到本地表、分布式表和视图等不同层级的结构,最顶层的视图view相当于用户指标建模时所用的表,从开发角度来看相当复杂:

  • 开发门槛较高:数据开发人员需要对 ClickHouse 有较高的掌握程度

  • 维护迭代成本高:对于频繁迭代的业务来说,模型的修改和数据验证过程会变得比较复杂

  • 底表数据量大:底层表存储了所有变更记录,在频繁变更的场景,低表的数据量会变得很大

  • 并发场景下Scan高:底层每次执行都需要扫描大量数据,导致集群的I/O压力较高,读写互相影响

  • Join性能有限:在复杂场景下,多张表的关联查询性能不及预期

  StarRocks 原生支持update、高性能的Join,高QPS这些特性可以解决以上所有痛点;针对目前ClickHouse中存量的模型,可以通过以下方式平滑迁移到StarRocks:

  • 模型:使用 Duplicate 模型对应 ClickHouse 中的MergeTree模型,StarRocks 中与 argMax() 函数对应的有 row_number()
  • 查询:查询层通过查询服务直接转换到StarRocks语法结构

  下图是迁移后查询性能对比结果,平均响应时间大幅下降。通过相同集群规模的并发压测,QPS提升了5倍以上

2.3 可视化分析

   ad-hoc场景:Presto To StarRocks

   贝壳内部的BI 产品ODIN分析平台提供了基于Hive的分析能力,底层通过Presto引擎查询,用户通过PrestoSql进行建模分析,模型和引擎耦合性非常紧密,无法轻易转换成到其他引擎的查询。    StarRocks支持了 Hive 外表的功能,相比Presto有 3 倍以上的性能提升,使得 StarRocks 在贝壳有能力统一 OLAP 场景。目前已开始将分流到 StarRocks 做测试验证,后续随着 StarRocks Trino/Presto 兼容能力的进一步提升,会继续提升 StarRocks 的流量占比,实现 StarRocks 在分析层的完全统一。

三、未来规划

   贝壳找房引入 StarRocks已经有两年时间了,从实践结果来看,StarRocks能满足90% 以上的需求场景。引入StarRocks对贝壳整个分析链路的建设起到了关键性作用,达到了极速统一的目标,并且带来了显著的性能收益,极大提升了OLAP分析场景的能力和效率。以下是未来的发展规划:

3.1 StarRocks集群的稳定性

   对大规模集群的运维,需要从以下几个方面加强稳定性建设:

  • 细化监控维度,增加重要指标的监控告警
  • 集群上下游链路的阻断控制能力:阻断能力在稳定性保障中非常重要,监控的目的是更好地发现问题,一旦发现问题,就需要有效的手段来控制降级,比如查询降级,危险SQL拦截,写入限制等。
  • 多集群数据源的故障恢复自动化:对于一个核心业务,已经建立了双链路保障策略,出现问题时能够自动切换,不需要人工干预。

3.2 StarRocks 新特性采用

   当前我们比较关注 StarRocks 新特性主要是物化视图、Trino 语法兼容和 LakeHouse 架构。

  • 物化视图在OLAP场景下对查询的性能提升非常大,目前社区在物化视图的多表,异步,自动更新等方面已经有了很丰富的功能支持,如何将这些功能结合业务场景,自动探测查询模式生成对应的物化视图将是未来的重点工作。
  • 从 StarRocks 3.0 版本开始,StarRocks 支持Trino方言,这一点对存量的 Presto模型迁移来说,降低了迁移和使用成本,同时有不错的查询性能提升。

  • LakeHouse架构是StarRocks3.0 的新架构模式,相比2.0版本的资源隔离能力,全新的存算分离架构支持硬资源隔离,这个特性使得现在的多个小规模集群模式可以统一成大规模集群,进一步降低资源和维护成本;弹性计算能力可以满足不同业务的使用场景。此外,StarRocks也支持了Apache Hudi、Apache Iceberg 和 Delta Lake 主流数据湖,统一湖仓查询场景不再是问题。

参考文章:

性能全面飙升!StarRocks 在贝壳找房的极速统一实践

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.pswp.cn/news/711542.shtml
繁体地址,请注明出处:http://hk.pswp.cn/news/711542.shtml
英文地址,请注明出处:http://en.pswp.cn/news/711542.shtml

如若内容造成侵权/违法违规/事实不符,请联系英文站点网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

PMP考试培训费用多少钱?

PMP考试的相关费用包括报名费用、培训费用和证书续证费用三个部分。 一、PMP考试报名费用: 首次报考费用为3900元,如果未通过考试可以在英文报名有效期内进行补考报名,补考费用为2500元。 付费方式是在项目管理学会官方网站上提交报考资料…

企业数字化转型的第一步:由被动多云向主动多云转变

随着经济环境、市场形势、技术发展、用户需求等诸多因素的变化,数字化转型为企业进一步提升效率和竞争力、提供更加丰富的个性化产品和服务、进行业务场景创新、探寻新的增长机会和运营模式提供了崭新的途径。越来越多的企业意识到,数字化转型已不是企业…

第1篇 Linux Docker安装rabbitmq

Docker安装RabbitMq 1、搜索rabbitmq镜像 docker search rabbitmq2、下载rabbitmq镜像 docker pull rabbitmq3、运行rabbitmq服务 docker run -d --name rabbitmq --restart always -p 15672:15672 -p 5672:5672 rabbitmq4、访问rabbitmq http://192.168.1.x:15672 5、rab…

亚信安慧AntDB:打破数据孤岛,实现实时处理

AntDB数据库以其独特的创新能力在分布式数据库领域引领潮流。其中,融合统一与实时处理是其两大核心创新能力,为其赢得广泛关注与赞誉。融合统一意味着AntDB能够将多种不同类型的数据库融合为一体,实现数据的统一管理与处理,极大地…

电视盒子什么品牌好?资深数码粉强推口碑电视盒子推荐

我对各类数码产品是非常熟悉的,尤其是电视盒子,用过超十五款了,涵盖了各个主流品牌,最近看到很多朋友在讨论不知道电视盒子什么品牌好,我这次要来分享的就是口碑最好的五款电视盒子推荐给各位不懂如何选电视盒子的新手…

AI、AIGC、AGI、ChatGPT它们的区别?

今天咱们聊点热门话题,来点科普时间——AI、AIGC、AGI和ChatGPT到底是啥?这几个词听起来好像挺神秘的,但其实它们就在我们生活中。让我们一起探索这些术语的奥秘! AI(人工智能):先说说AI&#…

数仓技术选型特点

高性能:用全并行的MPP架构数据库,业务数据被分散存储在多个节点上,数据分析任务被推送到数据所在位置就近执行,并行地完成大规模的数据处理工作,实现对数据处理的快速响应。 易扩展:Shared-Nothing开放架构…

电梯物联网之梯控相机方案-防止电瓶车进电梯

梯控现状 随着电梯产品在智能化建筑的日益普及,对于电梯的智能化管理 安全性需求 的要求越来越迫切。尤其今年来随着电瓶车的大量普及,发起多起楼道、轿厢电瓶车着火恶性事件, 造成了极大的社会 负面影响。控制电瓶车进入单元门,楼道以及电梯…

Vue官网“食用指南”

把Vue官网当做一个工具来用,有问题,先来官网查一查。 官网中常用的板块 官网:https://cn.vuejs.org/上手后,最常用的模块是【快速上手】【API】。所以务必要知道这两个模块在哪里,怎么使用。![image.png](https://img…

/proc/cpuinfo文件内容详解

/proc/cpuinfo 文件包含了有关系统 CPU 的信息,每一行代表一个属性及其对应的值。以下是一些常见的属性及其含义: 1. processor:表示 CPU 的物理编号,通常从 0 开始递增。 2. vendor_id:CPU 厂商的名称,如…

蓝桥杯 砝码称重 dp/dfs

题目链接&#xff1a; https://www.lanqiao.cn/problems/1447/learning/?subject_code1&group_code4&match_num12&match_flow1&origincup 思想&#xff1a;dfs暴力枚举过一半的分 代码&#xff1a; #include<bits/stdc.h> using namespace std;#def…

快速开发一个鸿蒙的页面

文章目录 前言常用组件快速开启简单的鸿蒙页面总结 一、前言 鸿蒙要想快速上手&#xff0c;那么就需要对基础的组件使用比较熟悉&#xff0c;这里就罗列开发中常见的基础组件的使用。 只要是写android的&#xff0c;对于这些组件的使用还是能很快上手的&#xff0c;只要多多…

01-prometheus监控系统-安装部署prometheus

一、准备环境 主机名ip配置prometheus-server3110.0.0.311核1g-20GBprometheus-server3210.0.0.311核1g-20GBprometheus-server3310.0.0.311核1g-20GB 二、下载/上传软件包 1&#xff0c;软件包地址 这里给大家准备了百度云盘的安装包&#xff1b; 链接&#xff1a;https:/…

FRM模型十二:极值理论

目录 极值理论介绍GEVPOT 代码实现 极值理论介绍 在风险管理中&#xff0c;将事件分为高频高损、高频低损、低频高损、低频低损。其中低频高损是一种非常棘手的损失事件&#xff0c;常出现在市场大跌、金融体系崩溃、金融危机以及自然灾害等事件中。 由于很难给极端事件一个准…

Spring 学习记录

Spring 学习记录 1. Spring和SpringFrameWork1.1 广义的Spring2.1 狭义的Spring2.3 SpringFrameWork / Spring框架图 2. Spring IOC容器(即上图中的Core Container)2.1 相关概念 (IOC DI 容器 组件)2.2 Spring IOC容器的作用2.3 Spring IOC容器接口和具体实现类 3. Spring IOC …

flask 数据库迁移报错 Error: No such command ‘db‘.

初学FLASK&#xff0c;使用pycharm的terminal 启动&#xff0c;实现数据库迁移 文件结构 项目启动文件不在一级目录pycharm>terminal启动 由于自己初入 python flask 很多东西并不懂&#xff0c;只能依葫芦画瓢&#xff0c;使用如下命令,输入完第一行命令执行没有任何错误…

素数合集(C语言版)

目录 判断素数函数 题目 素数个数 素数求和 最大的素数

微信小程序 ---- 慕尚花坊 购物车

购物车 01. 购物车-封装购物车接口 API 思路分析&#xff1a; 为了方便后续进行购物车模块的开发&#xff0c;我们在这一节将购物车所有的接口封装成接口 API 函数 落地代码&#xff1a; import http from ../utils/http/*** description 获取购物车列表数据* returns Pro…

Vue ElementUI 修改消息提示框样式—messageBox 的大小

在窄屏模式下&#xff08;移动端或pda&#xff09;&#xff0c;提示框的宽度太宽&#xff0c;会出现显示不完全的问题。 应当如何修改 ElementUI 的样式呢&#xff1f; open() {this.$confirm(window.vm.$i18n.t("tips.conLogOut"),window.vm.$i18n.t("tips.tip…

11-Linux部署集群准备

Linux部署集群准备 介绍 在前面&#xff0c;我们所学习安装的软件&#xff0c;都是以单机模式运行的。 后续&#xff0c;我们将要学习大数据相关的软件部署&#xff0c;所以后续我们所安装的软件服务&#xff0c;大多数都是以集群化&#xff08;多台服务器共同工作&#xff…