当前位置: 首页 > wzjs >正文

网站建设模板研究小红书搜索优化

网站建设模板研究,小红书搜索优化,人民日报今日新闻,推动品牌建设的网站引言:本文将全面且深入地解析Blaze RangePartitioning算子的Native实现过程。相较于原生Spark,RangePartitioning的Native实现在执行时间上达到了30%的显著下降,同时在资源开销方面节省了高达76%。这一改进大幅降低了运行成本,展现…

引言:本文将全面且深入地解析Blaze RangePartitioning算子的Native实现过程。相较于原生Spark,RangePartitioning的Native实现在执行时间上达到了30%的显著下降,同时在资源开销方面节省了高达76%。这一改进大幅降低了运行成本,展现了Native实现带来的巨大优势。

一、算子描述

RangePartitioning是shuffle partitioning的一种分区类型。它通过根据数据的值范围将数据划分成多个分区。每个分区包含特定范围内的值,通常用于处理有序的数据集,能够根据数据值进行动态划分。

RangePartitioning 的基本思想是:先对数据采样找到划分标志bounds,根据bounds将数据划分成多个近似大小的区间,然后将数据按所属区间写入对应partition,用于order by 全排序场景。

二、实现方案

RangePartitioning 实现主要包含采样和partition划分两个部分。

步骤一:首先需要获取每个partition对应的区间划分范围bounds,所以会先对全量数据进行采样,算出 partitionNum - 1 个区间分割点bounds。具体流程如下:

1、在driver端基于InternalRow进行数据采样:

  • 通过spark.sql.execution.rangeExchange.sampleSizePerPartition参数控制每个分区平均采样数量,设置一个稍微过采样一点的采样数sampleSizePerPartition。

  • 对每个分区采用蓄水池采样(Reservoir Sampling)算法进行采样。

  • 对采样结果评估,记录采样不均衡的分区重新采样(某个分区数据量过多,按照sampleSizePerPartition均值采样会出现样本数少于实际应采样数量,即采样不均衡的情况)。

  • 计算每个样本的权重weight,通过sumWeights/numReducer = step找到每个边界的步长,类似于直方图划分边界找出numReducer-1个分割点bounds。

2、由于采样数据量可能不足导致bounds较少,需要重新设置partitionNum=bounds.len + 1。因此会出现RangePartitioning的实际partition num与设置数量不同的情况。

3、定义rangepartition的序列化方式,主要包括三个参数:SortExpr、numPartitions、Bounds。进而转成native 算子进行后续处理。

图片

步骤二:在native端需要再计算一次全量数据,将数据按分割点bounds写入对应的partition。具体流程如下:

1、将bounds和input数据都转成可直接比较的arrow-row类型。

2、针对每个batch,对将数据与bounds进行比较并确定所在partition id:

  • 如果bounds.len<=128,直接进行比较。

  • 如果bounds.len>128,进行二分查找提速。

图片

三、优化效果

通过构造sql语句测试加速效果:

sql测试例子

11.8GB数据量:

insert overwrite table blaze_t.like_lineitem select * from tpch_parquet_1000.lineitem order by l_quantity
实现Native RangePartitioning

执行计划:

图片

sql 时间1073.516 s

Stage Total Time Across All Tasks: 8.9h

没有实现Native RangePartitioning,会回退到spark的RangePartitioning

图片

sql 时间 1357.814 s

Stage Total Time Across All Tasks  38.1h

Blaze‍‍Spark‍‍‍

sql总耗时

1073.516 s

1357.814 s

Stage Total Time Across All Tasks

8.9h

38.1h

Stage时间提升

(38.1-8.9)/38.1 = 0.7664042

多个不同sql测试取均值

Stage时间提升:76.94%

四、总结

  • 多次测试取均值,RangePartitioning 实现native相比旧版执行时间下降30%,资源开销节约70%

  • 由于采样结果可能较少导致bounds小于partition num-1,RangePartitioning可能实际执行的partition num与设置不同。

 

http://www.dtcms.com/wzjs/346347.html

相关文章:

  • 深圳市企业网站seo营销工具网站制作的步骤
  • 电商网站开发哪家好百度推广是什么
  • 公司做网站排名百度竞价规则
  • 艾奇视觉网站建设数据分析师培训
  • 婚礼策划网站设计哪里可以免费推广广告
  • 零度业务网站seo关键词优化培训
  • 佛山网站建设的品牌如何被百度收录
  • 做电锯电音的网站链接买卖是什么意思
  • 我要学习做网站网站统计数据分析
  • 做电商网站都需要学什么软件流氓网站
  • 做网站用的什么软件上海seo培训
  • 网站建设设计设计今日的头条新闻
  • 网站建设开发设计营销公司厦门黑龙江今日新闻
  • 网站怎么样被百度收录海外推广服务
  • 做网页专题 应该关注哪些网站建立营销型网站
  • 照片网站怎么做汕头seo优化公司
  • 手机网站开发设计优化师培训机构
  • 安徽建设银行招聘网站足球世界排名国家最新
  • 新闻静态网站咋做全网营销推广软件
  • 网站建设 计入哪个科目石家庄手机端seo
  • 政府手机网站建设网站空间
  • 教学设计的网站竞价sem托管公司
  • 织梦笑话娱乐网站源码2w数据+36条采集规则阿里巴巴运营
  • 广州做响应式网站多少钱在线一键建站系统
  • 专业网站建设哪家权威seo专员是干什么的
  • wordpress漏洞总结谷歌seo视频教程
  • 专业做淘宝开店的网站爱站网关键词挖掘查询
  • 门户网站html模板长沙seo网络公司
  • 做传奇网站云服务器地域改选哪里网站模板建站
  • 南城微信网站建设有没有帮忙推广的平台