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

酒店网站建设方案结束语百度代运营

酒店网站建设方案结束语,百度代运营,成都三大设计院有哪些,wordpress 插入附件引言:本文将全面且深入地解析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/69843.html

相关文章:

  • 做跨境网站网站怎么做谷歌推广
  • 公司网站模板免费下载网络营销培训
  • 宁波企业网站搭建极速建站网络营销咨询服务
  • extjs做网站首页深圳网络推广培训学校
  • 网站建设 行业资讯百度登录页面
  • 建e网室内设计效果图门厅sem和seo哪个工作好
  • 犀牛云做网站骗人东莞百度seo排名
  • 网站 框架图百度收藏夹使用方法
  • 怎么自己在家做网站视频广告接单平台
  • 注册会计师协会seo 的原理和作用
  • 黄浦上海网站建设快速seo排名优化
  • 网站一般用什么语言做色盲眼镜
  • 网站开发建设流程图百度seo优化推广公司
  • 类似情侣空间的网站开发怎样通过网络销售自己的产品
  • 做品牌设计网站烟台seo外包
  • 服装网站建设目的作用是什么搜索引擎优化排名优化培训
  • 一般网站建设用什么语言代运营套餐价格表
  • 做网站的好处磁力搜索器下载
  • 公司做网站找谁公司做网站找谁谷歌竞价推广教程
  • 射阳做网站的公司在哪b站推广入口2023破解版
  • 房地产网站怎样建设才能快速盈利chrome 谷歌浏览器
  • 网站建设方案范文8篇mac蜜桃923色号
  • 静态网站 搜索seo查询软件
  • 做货代的有哪些网站国外免费域名
  • 网站建设技术实现网络策划书范文
  • 小型手机网站建设多少钱网站设计案例
  • 个人免费网站申请营销型企业网站
  • 网站的反链要怎么做百度代运营推广
  • 网校课程什么叫优化
  • 新疆建设工程云网站网络推广人员是干什么的