当前位置:网站首页>Scala,Spark依赖jar包冲突解决方法
Scala,Spark依赖jar包冲突解决方法
2022-08-02 03:28:00 【Code_LT】
问题背景:
在提交任务运行时,报了如下错误:
Caused by: java.lang.BootstrapMethodError: call site initialization exception
…
Caused by: java.lang.invoke.LambdaConversionException: Invalid receiver type interface org.apache.http.Header; not a subtype of implementation type interface org.apache.http.NameValuePair
问题原因
环境中httpclient包版本太低(其他类似报错也是对应包版本问题导致)
解决方案
确定哪个包引起
找到报错中的错误信息,如本例中:
org.apache.http.Header
org.apache.http.NameValuePair
在IDEA中新建一个文件,复制上述两行代码,然后按住Ctrl,点击Header和NameValuePair跳转到他们的定义文件中。然后按住Ctrl点击定义文件上方的package,这里是http。会在IDEA左侧显示属于哪个jar包。
package org.apache.http;
IDEA里解决冲突
如果是在IDEA中开发,可参考
https://www.cnblogs.com/xxoome/p/13858569.html
解决,但该方法只是在你本地开发环境(即IDEA中解决了冲突),当提交到集群环境中运行时,是会报一样的错。甚至在本地开发环境压根没遇到过jar包冲突,但到集群上去跑时,就会报错。原因是因为集群环境有自己jar包使用顺序。
spark环境中解决冲突
当我们用spark-submit或spark-shell提交代码时,Spark application运行加载依赖有三个地方:
- SystemClasspath – Spark安装时候提供的依赖包 【SystemClassPath】
- Spark-submit --jars 提交的依赖包 【UserClassPath】
- Spark-submit app.jar或者shadowJar打的jar 【UserClassPath】
Spark 依赖包默认优先级
默认加载顺序如下:
SystemClasspath – Spark安装时候提供的依赖包
UserClassPath – Spark-submit --jars 提交的依赖包 或用户的app.jar
具体参考:
https://blog.csdn.net/adorechen/article/details/90722933
https://blog.csdn.net/a822631129/article/details/118933856
https://blog.csdn.net/weixin_43845733/article/details/109678670
边栏推荐
- win10内存占用很高,关闭所有应用程序依然降不下来(win11)
- Nest 的实现原理?理解了 reflect metadata 就懂了
- 最简单的FRP内网穿透教程
- Windows下MySQL数据库报“ERROR 2003 (HY000): Can‘t connect to MySQL server on ‘localhost:8000‘ (10061)”错误解决
- Jetpack中各个组件简介
- Flutter入门之网络请求篇
- 功能强大的黑科技网站--10连
- 《scala 编程(第3版)》学习笔记2
- 不懂“赚钱逻辑”,你永远都是社会最底层(广告电商)
- 备战金九银十:Android 高级架构师的学习路线及面试题分享
猜你喜欢
随机推荐
VS2017报错:LNK1120 1 个无法解析的外部命令
laravel 写api接口时 session获取不到处理办法
超级云APP,陪伴您一起成长的软件
Syncthing文件同步方案完全攻略(亲测有效)
C# 关键字学习手记
18张图,直观理解神经网络、流形和拓扑
C# Form按ESC关闭窗体
Out of memory error on GPU 0. Cannot allocate xxxGB memory on GPU 0, available memory is only xxx
元宇宙是一个炒作的科幻概念,还是互联网发展的下半场?
修复APP的BUG,热修复的知识点和大厂的相关资料汇总
Mysql创建索引
ffmpeg 有声视频合成背景音乐(合成多声音/合成多音轨)
关于我的项目-微信公众号~
View与ViewGroup
[Spark]-RDD详解之变量&操作
广告电商「私域打工人」职业前景:你离月薪6万,还差多远?
Two-Stream Convolutional Networks for Action Recognition in Videos双流网络论文精读
Kotlin - 延迟初始化和密封类
英语每日打卡
大厂底层必修:“应用程序与 AMS 的通讯实现”









