码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • Spark报错NoSuchMethodError或ClassNotFoundException


    通过Spark-submit提交的任务抛出了java.lang.NoSuchMethodError或者ClassNotFoundException

    答:首先从自己jar包找原因,看看java -jar直接执行会不会冲突。

    如果没有,可能是spark环境里有别的版本的jar,可以加个输出:

         System.out.println("----------------------" + this.getClass().getResource("/com/google/common/collect/Sets.class"));

    就能看到实际加载的是哪个jar了。

    我这次就遇到了:------ jar:file:/data7/yarn/nm/usercache/hdfs/filecache/20/__spark_libs__917155435266718554.zip/guava-14.0.1.jar!/com/google/common/net/HostAndPort.class

    我jar里是guava-20.0,因此冲突了

    所以要用shade插件的高级功能来解决,把冲突的包名rename:

    configuration>

    relocations>

    relocation>

    pattern>com.google.commonpattern>

    shadedPattern>facetsdict.com.google.commonshadedPattern>

    relocation>

    relocation>

    pattern>org.apache.thriftpattern>

    shadedPattern>facetsdict.org.apache.thriftshadedPattern>

    relocation>

    relocations>

    configuration>

    记住,如果shade之后还有冲突,应该是还存在需要shade的包,找出来。它之所以冲突其实是因为spark会把其lib下的jar优先加载,并且如果已经有同路径同名类则后面再加载你的jar时候就跳过了。所以很多报错很奇怪其实因为这是运行期问题,不是编译期问题,java代码已经编译为了字节码,表面上你即使看反编译的字节码也看不出来的,运行起来才会发现驴唇不对马嘴。

  • 相关阅读:
    openpose 安装到简单实用 win11
    C++基础教程(转载)
    上周热点回顾(2.6-2.12)
    【python】JSON标准库文件介绍及python中json模块使用
    MQTT 消息服务器 EMQ简单对接DEMO
    小程序,公众号绑定微信开放平台帐号-UnionID机制
    前后端跨域请求问题解决方法
    神经网络 深度神经网络,深度神经网络知识图谱
    【每日一题】做菜顺序
    前端面试宝典总结1-HTML
  • 原文地址:https://blog.csdn.net/hellwhj/article/details/125515691
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号