SparkSQL在字节跳动的应用实践和优化实战

2024-09-06 21:32

本文主要是介绍SparkSQL在字节跳动的应用实践和优化实战,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

来源:字节跳动白泉的分享
作者:大数据技术与架构整理

点击右侧关注,大数据开发领域最强公众号!

点击右侧关注,暴走大数据!



By  大数据技术与架构

场景描述: 面对大量复杂的数据分析需求,提供一套稳定、高效、便捷的企业级查询分析服务具有重大意义。本次演讲介绍了字节跳动基于SparkSQL建设大数据查询统一服务TQS(Toutiao Query Service)的一些实践以及在执行计划调优、数据读取剪枝、SQL兼容性等方面对SparkSQL引擎的一些优化。

关键词:SparkSQL优化 字节跳动

本文是根据来自字节跳动的分享整理而成。

作者来自字节跳动数据平台查询分析团队。

目标和能力

为公司内部提供 Hive 、 Spark - SQL 等 OLAP 查询引擎服务支持。
  • 提供全公司大数据查询的统一服务入口,支持丰富的API接口,覆盖Adhoc、ETL等SQL查询需求

  • 支持多引擎的智能路由、参数的动态优化

  • Spark-SQL/Hive引擎性能优化


针对SparkSQL,主要做了以下优化:
  1. 执行计划自动调优
        •基于AE的 ShuffledHashJoin调整
        •Leftjoinbuildleftmap技术
   2. 数据读取剪枝
        •Parquetlocalsort
        •BloomFilter&BitMap
        •Prewhere
   3. 一些其它优化
 

执行计划调优

  • 执行计划的自动调优:

Spark Adaptive Execution ( Intel®Software),简称SparkAE,总体思想是将sparksql生成的1个job中的所有stage单独执行,为每一个stage单独创建一个子job,子job执行完后收集该stage相关的统计信息(主要是数据量和记录数),并依据这些统计信息优化调整下游stage的执行计划。

目前SparkAE主要支持的功能:
(1)数据倾斜的调整
(2)小task的合并
(3)sortmerge-> broadcase
Spark 有3种join方式:Broadcastjoin、ShuffledHashJoin、SortMergeJoin
普通leftjoin无法build 左表

优化点:
在AE的框架下,根据shuffle数据量大小,自动调整join执行计划:SortMergeJoin调整为 ShuffledHashJoin•扩展支持left-join时将左表build成HashMap。

省去了大表join小表的情况下对shuffle数据的排序过程、join过程以HashMap完成,实现join提速。

  • SortMergeJoin调整为ShuffledHashJoin

640?wx_fmt=png

  • Leftjoin build left sidemap

1、初始化表A的一个匹配记录的映射表
目标:
对于Left-join的情况,可以对左表进行HashMapbuild。使得小左表leftjoin大右表的情况可以进行ShuffledHashJoin调整

难点:
Left-join语义:左表没有join成功的key,也需要输出

原理
在构建左表Map的时候,额外维持一个"是否已匹配"的映射表;在和右表join结束之后,把所有没有匹配到的key,用null进行join填充。
以 Aleft join B 为例:
640?wx_fmt=png

2、join过程中,匹配到的key置为1,没有匹配到的项不变(如key3)
640?wx_fmt=png

3、join结束后,没有匹配到的项,生成一个补充结果集R2
640?wx_fmt=png 640?wx_fmt=png

4.合并结果集R1和结果集R2,输出最终生成的join结果R。
640?wx_fmt=png
优化结果
  • 约95%左右的joinSQL有被调整成ShuffledHashJoin/BroadcastJoin

  • 被优化的SQL整体速度提升20%~30%

  • 整体执行时长缩短

640?wx_fmt=png

基于Parquet数据读取剪枝

以parquet格式数据为对象,在数据读取时进行适当的过滤剪枝,从而减少读取的数据量,加速查询速度
优化点:
  • LocalSort

  • BoomFilter

  • BitMap

  • Prewhere


基于Parquet数据读取剪枝:LocalSort
对parquet文件针对某个高频字段进行排序。从而实现读数据时RowGroup的过滤
目标:
  • 自动选择排序字段

  • 生成文件时自动排序

640?wx_fmt=png

Parquet文件读取原理:
(1)每个rowgroup的元信息里,都会记录自己包含的各个列的最大值和最小值
(2)读取时如何这个值不在最大值、最小值范围内,则跳过RowGroup
生成hive分区文件时,先读取metastore,获取它是否需要使用localsort,如果需要,选择它的高频列是哪个。

基于Parquet数据读取剪枝:BloomFilter&BitMap
640?wx_fmt=png
640?wx_fmt=png
640?wx_fmt=png
整体优化结果:
  • 命中索引平均性能提升 30%

  • 生成时间增加:10%

  • 空间开销增加:5%

  如何选取合适的列

640?wx_fmt=png

Local_sort &BloomFilter & BitMap 如何自动生效
640?wx_fmt=png

基于Parquet数据读取剪枝:Prewhere
基于列式存储各列分别存储、读取的特性•针对需要返回多列的SQL,先根据下推条件对RowId进行过滤、选取。再有跳过地读取其他列,从而减少无关IO和后续计算•谓词选择(简单、计算量小):in,=,<>,isnull,isnotnull
优化结果使得: 特定 SQL ( Project16 列, where条件 2 列) SQL 平均性能提升 20%

其他优化

  • Hive/SparkLoad分区Move文件优化:

通过调整staging目录位置,实现在Load过程中mv文件夹,替代逐个mv文件,从而减少与NameNode的交互次数
  • Spark生成文件合并

通过最后增加一个repartitionstage合并spark生成文件。
  • Vcore

对于CPU使用率低的场景,通过vcore技术使得一个yarn-core可以启动多个spark-core
  • Spark 访问hivemetastore 特定filter下推:

构造 get_partitions_by_filter实现 cast、substring等条件下推hivemetastore,从而减轻metastore返回数据量

运行期调优

在SQL执行前,通过统一的查询入口,对其进行基于代价的预估,选择合适的引擎和参数:
1.SQL分析
  • 抽取Hiveexplain逻辑,进行SQL语法正确性检查

  • 对SQL包含的算子、输入的数据量进行标注

2.自动引擎选择/自动参数优化
标注结果自动选择执行引擎:
  • 小SQL走SparkServer(省去yarn申请资源耗时)

  • 其他默认走Spark-Submit

标注结果选择不同运行参数:
  • Executor个数/内存

  • Overhead、堆外内存

调优后使得Adhoc30s以内SQL占比45%,Spark-Submit内存使用量平均减少20%。

欢迎点赞+收藏+转发朋友圈素质三连

640?wx_fmt=jpeg640?wx_fmt=jpeg

文章不错?点个【在看】吧! ?

这篇关于SparkSQL在字节跳动的应用实践和优化实战的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


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

相关文章

Spring Boot + MyBatis Plus 高效开发实战从入门到进阶优化(推荐)

《SpringBoot+MyBatisPlus高效开发实战从入门到进阶优化(推荐)》本文将详细介绍SpringBoot+MyBatisPlus的完整开发流程,并深入剖析分页查询、批量操作、动... 目录Spring Boot + MyBATis Plus 高效开发实战:从入门到进阶优化1. MyBatis

MyBatis 动态 SQL 优化之标签的实战与技巧(常见用法)

《MyBatis动态SQL优化之标签的实战与技巧(常见用法)》本文通过详细的示例和实际应用场景,介绍了如何有效利用这些标签来优化MyBatis配置,提升开发效率,确保SQL的高效执行和安全性,感... 目录动态SQL详解一、动态SQL的核心概念1.1 什么是动态SQL?1.2 动态SQL的优点1.3 动态S

Spring Boot 配置文件之类型、加载顺序与最佳实践记录

《SpringBoot配置文件之类型、加载顺序与最佳实践记录》SpringBoot的配置文件是灵活且强大的工具,通过合理的配置管理,可以让应用开发和部署更加高效,无论是简单的属性配置,还是复杂... 目录Spring Boot 配置文件详解一、Spring Boot 配置文件类型1.1 applicatio

Pandas使用SQLite3实战

《Pandas使用SQLite3实战》本文主要介绍了Pandas使用SQLite3实战,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学... 目录1 环境准备2 从 SQLite3VlfrWQzgt 读取数据到 DataFrame基础用法:读

Python如何使用__slots__实现节省内存和性能优化

《Python如何使用__slots__实现节省内存和性能优化》你有想过,一个小小的__slots__能让你的Python类内存消耗直接减半吗,没错,今天咱们要聊的就是这个让人眼前一亮的技巧,感兴趣的... 目录背景:内存吃得满满的类__slots__:你的内存管理小助手举个大概的例子:看看效果如何?1.

Python中随机休眠技术原理与应用详解

《Python中随机休眠技术原理与应用详解》在编程中,让程序暂停执行特定时间是常见需求,当需要引入不确定性时,随机休眠就成为关键技巧,下面我们就来看看Python中随机休眠技术的具体实现与应用吧... 目录引言一、实现原理与基础方法1.1 核心函数解析1.2 基础实现模板1.3 整数版实现二、典型应用场景2

一文详解SpringBoot响应压缩功能的配置与优化

《一文详解SpringBoot响应压缩功能的配置与优化》SpringBoot的响应压缩功能基于智能协商机制,需同时满足很多条件,本文主要为大家详细介绍了SpringBoot响应压缩功能的配置与优化,需... 目录一、核心工作机制1.1 自动协商触发条件1.2 压缩处理流程二、配置方案详解2.1 基础YAML

tomcat多实例部署的项目实践

《tomcat多实例部署的项目实践》Tomcat多实例是指在一台设备上运行多个Tomcat服务,这些Tomcat相互独立,本文主要介绍了tomcat多实例部署的项目实践,具有一定的参考价值,感兴趣的可... 目录1.创建项目目录,测试文China编程件2js.创建实例的安装目录3.准备实例的配置文件4.编辑实例的

Python 中的异步与同步深度解析(实践记录)

《Python中的异步与同步深度解析(实践记录)》在Python编程世界里,异步和同步的概念是理解程序执行流程和性能优化的关键,这篇文章将带你深入了解它们的差异,以及阻塞和非阻塞的特性,同时通过实际... 目录python中的异步与同步:深度解析与实践异步与同步的定义异步同步阻塞与非阻塞的概念阻塞非阻塞同步

Python Dash框架在数据可视化仪表板中的应用与实践记录

《PythonDash框架在数据可视化仪表板中的应用与实践记录》Python的PlotlyDash库提供了一种简便且强大的方式来构建和展示互动式数据仪表板,本篇文章将深入探讨如何使用Dash设计一... 目录python Dash框架在数据可视化仪表板中的应用与实践1. 什么是Plotly Dash?1.1