关于 Apache Spark 的参数设置,用于优化和调整 Spark 应用程序的行为和性能

关于 Apache Spark 的参数设置,用于优化和调整 Spark 应用程序的行为和性能

下面是每个配置的简要说明:

spark.dynamicAllocation.enabled=true:启用动态资源分配,允许 Spark 根据任务需求自动调整执行器的数量。

spark.shuffle.service.enabled=false:禁用独立的 Shuffle 服务,将 Shuffle 过程合并到 Executor 中。

spark.dynamicAllocation.initialExecutors=10:初始执行器的数量,当动态资源分配启用时使用。

spark.dynamicAllocation.minExecutors=10:执行器的最小数量。

spark.dynamicAllocation.maxExecutors=500:执行器的最大数量。

spark.dynamicAllocation.executorAllocationRatio=0.5:用于执行器分配的比例,表示给每个应用程序分配的资源相对于集群中所有可用资源的比例。

spark.dynamicAllocation.executorIdleTimeout=60s:执行器空闲时自动释放的超时时间。

spark.dynamicAllocation.cachedExecutorIdleTimeout=30min:空闲缓存执行器的超时时间,该执行器可以更快地重新分配给作业。

spark.dynamicAllocation.shuffleTracking.enabled=true:启用作业的 Shuffle 动态分配跟踪。

spark.dynamicAllocation.shuffleTracking.timeout=30min:Shuffle 动态分配跟踪的超时时间。

spark.dynamicAllocation.schedulerBacklogTimeout=1s:作业调度队列中作业等待的超时时间。

spark.dynamicAllocation.sustainedSchedulerBacklogTimeout=1s:作业调度队列中连续等待的时间阈值。

spark.cleaner.periodicGC.interval=5min:垃圾回收的周期间隔。

spark.sql.adaptive.enabled=true:启用自适应查询执行,允许 Spark 在运行时动态调整查询执行计划。

spark.sql.adaptive.forceApply=false:是否强制应用自适应执行。

spark.sql.adaptive.logLevel=info:自适应执行的日志级别。

spark.sql.adaptive.advisoryPartitionSizeInBytes=256m:用于自适应执行的建议分区大小。

spark.sql.adaptive.coalescePartitions.enabled=true:启用自适应分区合并。

spark.sql.adaptive.coalescePartitions.minPartitionNum=1:分区合并的最小分区数。

spark.sql.adaptive.coalescePartitions.initialPartitionNum=8192:分区合并的初始分区数。

spark.sql.adaptive.fetchShuffleBlocksInBatch=true:在批量中获取 Shuffle 块。

spark.sql.adaptive.localShuffleReader.enabled=true:启用本地 Shuffle 读取。

spark.sql.adaptive.skewJoin.enabled=true:启用自适应倾斜连接优化。

spark.sql.adaptive.skewJoin.skewedPartitionFactor=5:用于检测倾斜分区的标准差因子。

spark.sql.adaptive.skewJoin.skewedPartitionThresholdInBytes=400m:倾斜分区的阈值。

spark.sql.adaptive.nonEmptyPartitionRatioForBroadcastJoin=0.2:广播连接时的非空分区比例。

spark.sql.autoBroadcastJoinThreshold=-1:自动广播连接阈值,-1 表示禁用。

这些参数可以根据具体的需求和环境进行调整和定制,以优化 Spark 应用程序的性能和资源利用

相关推荐
不睡懒觉的橙10 分钟前
【医疗大数据】医疗保健领域的大数据管理:采用挑战和影响
大数据·人工智能·信息可视化·人机交互·健康医疗
数分大拿的Statham38 分钟前
PostgreSQL中的regexp_split_to_table函数详解,拆分字段为多行
大数据·数据库·postgresql·数据分析·数据清洗
月夜星辉雪2 小时前
【RabbitMQ 项目】服务端:路由交换模块
分布式·rabbitmq
super_journey2 小时前
RabbitMq中交换机(Exchange)、队列(Queue)和路由键(Routing Key)
分布式·中间件·rabbitmq
howard20052 小时前
大数据时代:历史、发展与未来
大数据
翔云API2 小时前
人证合一接口:智能化身份认证的最佳选择
大数据·开发语言·node.js·ocr·php
知识分享小能手2 小时前
mysql学习教程,从入门到精通,SQL 删除数据(DELETE 语句)(19)
大数据·开发语言·数据库·sql·学习·mysql·数据开发
学习使我快乐——玉祥3 小时前
es查询语法
大数据·elasticsearch·搜索引擎
灰色孤星A3 小时前
分布式事务学习笔记(二)Seata架构、TC服务器部署、微服务集成Seata
分布式·微服务·架构·seata·分布式事务·tc服务器·微服务集成seata
哈尔滨财富通科技4 小时前
财富通公司开发维修售后小程序,解决售后维修问题
大数据·小程序·云计算·售后小程序·哈尔滨小程序