博客
关于我
Spark Sql JDBC实现 聚合、union、同数据源Join等下推
阅读量:617 次
发布时间:2019-03-13

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

Spark SQL优化:JDBC数据源的高效处理

在实际项目中,Spark SQL处理JDBC数据源时,常会遇到以下问题:频繁的JDBC连接、内存计算的复杂度以及数据源的网络IO消耗。这些问题在数据量较大或分布式环境下尤为明显。然而,通过对Spark SQL的优化,可以有效地减少JDBC连接次数,提升性能。

问题分析

在之前的案例中,通过简单的查询同一数据库的两张表(emp和dept),Spark SQL进行了三次JDBC连接请求。这意味着每次查询都需要与数据库建立三次连接,导致额外的网络开销和IO时间消耗。此外,聚合和Join操作未能下沉到数据库层面,进一步增加了内存计算的复杂度。

具体表现为:

  • 三次JDBC连接:数据源频繁被访问,增加了网络通信的开销。
  • 聚合和Join未下沉:这些操作仍需在内存中执行,导致额外的计算负担。
  • 优化方案

    为了解决上述问题,我们采用了Spark的扩展接口(Extensions)来优化Spark的Relational Buckley Operator(RBO)和Columnar Bulk Operator(CBO)规则。这种方法的核心原理是将计算尽可能推送到底层数据库,减少内存操作。

    优化效果

    优化后的执行计划显示,JDBC连接次数从三次减少到一次,且聚合和Join操作下沉到了SQL层。这种方式充分利用了数据库的本地索引和缓存机制,避免了在内存中进行复杂的计算。

    具体表现为:

  • Jdbc连接减少:数据库操作合并为一次,减少了网络IO的开销。
  • 聚合和Join下沉:这些操作直接在数据库层面执行,提升了性能。
  • 性能测试

    在本地数据库环境下进行测试时,优化后的查询执行时间显著减少。尽管数据量不大,优化仍带来性能提升。生产环境下的提升将更为明显。

    总结

    通过优化Spark SQL的RBO和CBO规则,我们成功地将JDBC连接次数减少,提升了性能。这种方式移动了计算,而非数据,充分发挥了数据库的优势。未来工作中,可以进一步探索数据库索引和缓存的优化策略,以进一步提升性能。

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

    你可能感兴趣的文章
    No Feign Client for loadBalancing defined. Did you forget to include spring-cloud-starter-loadbalanc
    查看>>
    No mapping found for HTTP request with URI [/...] in DispatcherServlet with name ...的解决方法
    查看>>
    No module named cv2
    查看>>
    No module named tensorboard.main在安装tensorboardX的时候遇到的问题
    查看>>
    No module named ‘MySQLdb‘错误解决No module named ‘MySQLdb‘错误解决
    查看>>
    No new migrations found. Your system is up-to-date.
    查看>>
    No qualifying bean of type XXX found for dependency XXX.
    查看>>
    No resource identifier found for attribute 'srcCompat' in package的解决办法
    查看>>
    No toolchains found in the NDK toolchains folder for ABI with prefix: mips64el-linux-android
    查看>>
    NO.23 ZenTaoPHP目录结构
    查看>>
    NoClassDefFoundError: org/springframework/boot/context/properties/ConfigurationBeanFactoryMetadata
    查看>>
    Node JS: < 一> 初识Node JS
    查看>>
    Node-RED中使用JSON数据建立web网站
    查看>>
    Node-RED中使用node-red-browser-utils节点实现选择Windows操作系统中的文件并实现图片预览
    查看>>
    Node-RED中使用Notification元件显示警告讯息框(温度过高提示)
    查看>>
    Node-RED中实现HTML表单提交和获取提交的内容
    查看>>
    Node.js 函数是什么样的?
    查看>>
    Node.js 实现类似于.php,.jsp的服务器页面技术,自动路由
    查看>>
    node.js 怎么新建一个站点端口
    查看>>
    Node.js 文件系统的各种用法和常见场景
    查看>>