博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
spark写mysql优化简书_Spark SQL:性能优化
阅读量:7025 次
发布时间:2019-06-28

本文共 1760 字,大约阅读时间需要 5 分钟。

目录

1.在内存中缓存数据

2.性能优化相关参数

1.在内存中缓存数据

性能调优主要是将数据放入内存中操作。通过spark.cacheTable("tableName")或者dataFrame.cache()。使用spark.uncacheTable("tableName")来从内存中去除table。

Demo案例:

(1)从Oracle数据库中读取数据,生成DataFrame

val mysqlDF = spark.read.format("jdbc")

.option("url","jdbc:mysql://192.168.109.1:3306/company?serverTimezone=UTC&characterEncoding=utf-8")

.option("dbtable","company.emp")

.option("user","root")

.option("password","000000").load

scala> val mysqlDF = spark.read.format("jdbc").option("url","jdbc:mysql://192.168.109.1:3306/company?serverTimezone=UTC&characterEncoding=utf-8").option("user","root").option("password","000000").option("dbtable","emp").option("driver","com.mysql.jdbc.Driver").load

(2)将DataFrame注册成表:

mysqlDF.registerTempTable("emp")

注意:必须注册成一张表,才可以缓存

(3)执行查询,并通过Web Console监控执行的时间

spark.sql("select * from emp").show

67fa1d1ab7b0

(4)将表进行缓存,并查询两次,并通过Web Console监控执行的时间

spark.sqlContext.cacheTable("emp")

spark.sql("select * from emp").show

67fa1d1ab7b0

(5)清空缓存:

spark.sqlContext.cacheTable("emp")

spark.sqlContext.clearCache

2.性能优化相关参数

(1)将数据缓存到内存中的相关优化参数

spark.sql.inMemoryColumnarStorage.compressed

//默认为 true

//Spark SQL 将会基于统计信息自动地为每一列选择一种压缩编码方式。

spark.sql.inMemoryColumnarStorage.batchSize

//默认值:10000

//缓存批处理大小。缓存数据时, 较大的批处理大小可以提高内存利用率和压缩率,但同时也会带来 OOM(Out Of Memory)的风险。

(2)其他性能相关的配置选项(不过不推荐手动修改,可能在后续版本自动的自适应修改)

spark.sql.files.maxPartitionBytes

//默认值:128 MB

//读取文件时单个分区可容纳的最大字节数

spark.sql.files.openCostInBytes

//默认值:4M

//打开文件的估算成本, 按照同一时间能够扫描的字节数来测量。当往一个分区写入多个文件的时候会使用。高估更好, 这样的话小文件分区将比大文件分区更快 (先被调度)。

spark.sql.autoBroadcastJoinThreshold

//默认值:10M

//用于配置一个表在执行 join 操作时能够广播给所有 worker 节点的最大字节大小。通过将这个值设置为 -1 可以禁用广播。注意,当前数据统计仅支持已经运行了 ANALYZE TABLE COMPUTE STATISTICS noscan 命令的 Hive Metastore 表。

spark.sql.shuffle.partitions

//默认值:200

//用于配置 join 或聚合操作混洗(shuffle)数据时使用的分区数。

转载地址:http://gwsxl.baihongyu.com/

你可能感兴趣的文章
vmware下CentOS使用NAT联网
查看>>
MD5加密函数实现
查看>>
DbUtils使用笔记
查看>>
Struts2数据校验
查看>>
iOS开发UI篇—UITableview控件使用小结
查看>>
Go(6 [接口 类型断言])
查看>>
峰任策划:SEO对网络营销有什么帮助?
查看>>
Qt学习:QLineEdit的程序示例
查看>>
信用卡号的验证
查看>>
用poi实现doc转html
查看>>
微软解释近期多因素身份验证崩溃原因
查看>>
Confluence 6 配置管理员会话的安全
查看>>
Build Castles(构建城堡)
查看>>
学会这 18 个工具,你一定能真正理解如何监控网络带宽!
查看>>
flash文件怎么打开 怎么将swf格式转换成avi视频
查看>>
虚拟机的克隆并更改主机名
查看>>
Java并发编程:什么是CAS?这回总算知道了
查看>>
分享一波Android面试题
查看>>
python入门系列:文件操作
查看>>
适合练习的10个Python项目,每个项目都不到500行代码
查看>>