[发明专利]一种解决Spark数据倾斜问题的负载均衡方法及装置有效
申请号: | 201810374429.5 | 申请日: | 2018-04-24 |
公开(公告)号: | CN108572873B | 公开(公告)日: | 2021-08-24 |
发明(设计)人: | 田文洪;黄超杰;王金;尚明生 | 申请(专利权)人: | 中国科学院重庆绿色智能技术研究院 |
主分类号: | G06F9/50 | 分类号: | G06F9/50 |
代理公司: | 北京同恒源知识产权代理有限公司 11275 | 代理人: | 赵荣之 |
地址: | 400714 *** | 国省代码: | 重庆;50 |
权利要求书: | 查看更多 | 说明书: | 查看更多 |
摘要: | |||
搜索关键词: | 一种 解决 spark 数据 倾斜 问题 负载 均衡 方法 装置 | ||
1.一种解决Spark数据倾斜问题的负载均衡方法,其特征在于:包括:
S1:监测计算节点的平均CPU利用率、内存利用率,SparkExecutor进程启动后,初始化Executor的权重信息;
S2:每一个计算节点根据预设抽样比例对本地中间数据进行抽样,然后计算节点将本地抽样信息通过消息通信发送给Master节点;
S3:Master节点汇总所有计算节点的抽样信息,然后根据预设抽样比例,建立数据分布的直方图,预测数据分布的总体特征;
S4:根据数据分布情况,将数据划分为多个分区,分区数为所有Executor总核数的整数倍,分区过程中对大型Key进行拆分;
S5:计算Executor的性能因子,每一个数据分区对应为一个Executor任务,然后将任务按照贪心策略分配给性能因子最高的Executor;
S6:在整个过程中,Executor的权重根据其负载和资源利用率动态调整,重复步骤S5直到任务分配完毕;Executor的权重调整过程为:
初始化每个Executor的计算能力计数值Capabilityi以及监测次数值Counti;
计算每个Executor的CPU利用率CUi以及内存利用率MUi,如果Executor的CPU利用率CUi和内存利用率MUi都没有超过其对应的CPU利用率上界CUupperbound和内存利用率上界MUupperbound,则对其计算能力计数值Capabilityi以及监测次数值Counti都增加1,否则只增加监测次数值Counti;
当监测次数值Counti到达设置的调整周期T 时,正式开始对Executor的权重进行调整,如果计算能力计数值Capabilityi大于α×T,就增加Executor的权重,如果计算能力计数值Capabilityi小于β×T,就减少Executor的权重,其中,α和β为预设的调节因子;
每次权重调整完毕时都将计算能力计数值Capabilityi以及监测次数值Counti重新设置为0,重复该过程直到任务完成。
2.根据权利要求1所述的解决Spark数据倾斜问题的负载均衡方法,其特征在于:在步骤S1中,Executor的权重初始值
Wi=Speedcpu×(1-Rcpu)×(1-Rmem),
其中,Speedcpu为节点CPU的主频大小,Rcpu表示为节点的CPU平均利用率,Rmem表示为节点的内存利用率。
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于中国科学院重庆绿色智能技术研究院,未经中国科学院重庆绿色智能技术研究院许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/201810374429.5/1.html,转载请声明来源钻瓜专利网。
- 数据显示系统、数据中继设备、数据中继方法、数据系统、接收设备和数据读取方法
- 数据记录方法、数据记录装置、数据记录媒体、数据重播方法和数据重播装置
- 数据发送方法、数据发送系统、数据发送装置以及数据结构
- 数据显示系统、数据中继设备、数据中继方法及数据系统
- 数据嵌入装置、数据嵌入方法、数据提取装置及数据提取方法
- 数据管理装置、数据编辑装置、数据阅览装置、数据管理方法、数据编辑方法以及数据阅览方法
- 数据发送和数据接收设备、数据发送和数据接收方法
- 数据发送装置、数据接收装置、数据收发系统、数据发送方法、数据接收方法和数据收发方法
- 数据发送方法、数据再现方法、数据发送装置及数据再现装置
- 数据发送方法、数据再现方法、数据发送装置及数据再现装置