记一次Caused by: java.lang.NoSuchFieldError 排查过程

本文详细解析了在使用UDF函数时遇到的jar包冲突问题,具体表现为NoSuchFieldError异常,通过分析代码和jar包版本,最终定位并解决了问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

错误现象

UDF 函数里引用了httpclient jar包,用来请求外网,报错

Caused by: java.lang.NoSuchFieldError: INSTANCE
	at org.apache.http.conn.ssl.SSLConnectionSocketFactory.<clinit>(SSLConnectionSocketFactory.java:151)
	at org.apache.http.impl.client.HttpClientBuilder.build(HttpClientBuilder.java:977)
	at org.apache.http.impl.client.HttpClients.createDefault(HttpClients.java:56)
	at com.daojia.bigdata.map.GaoDei.evaluate(GaoDei.java:32)
	... 23 more

分析问题

  1. 此问题典型的jar包冲突,执行引用了的class类没有这个属性,导致报错了
  2. 找出代码里有问题的类,加载来源于哪个jar包
  3. 分析代码里引用的jar包版本,是4.5.9,这个jar包在hive目录下也有,只是版本不一样,明显加载了4.2.5的这个,问题找到
  4. 解决方法,把机器上已存在jar包升级,此方法不推荐,怕产生其它问题,第二个方法修改代码引用的jar包版本,和线上一致,问题解决

问题总结

所类问题NoSuchxx,都是一样的问题,都是加载了,不是我们想加载的类导致的,核心解决是找出有问题的类,从哪个jar包加载的,再处理问题,一味的去百度,解决不了自身的问题

java: java.lang.NoSuchFieldError: Class com.sun.tools.javac.tree.JCTree$JCImport does not have member field 'com.sun.tools.javac.tree.JCTree qualid' java.lang.RuntimeException: java.lang.NoSuchFieldError: Class com.sun.tools.javac.tree.JCTree$JCImport does not have member field 'com.sun.tools.javac.tree.JCTree qualid' at jdk.compiler/com.sun.tools.javac.api.JavacTaskImpl.invocationHelper(JavacTaskImpl.java:168) at jdk.compiler/com.sun.tools.javac.api.JavacTaskImpl.doCall(JavacTaskImpl.java:100) at jdk.compiler/com.sun.tools.javac.api.JavacTaskImpl.call(JavacTaskImpl.java:94) at org.jetbrains.jps.javac.JavacMain.compile(JavacMain.java:238) at org.jetbrains.jps.javac.ExternalJavacProcess.compile(ExternalJavacProcess.java:191) at org.jetbrains.jps.javac.ExternalJavacProcess.access$400(ExternalJavacProcess.java:33) at org.jetbrains.jps.javac.ExternalJavacProcess$CompilationRequestsHandler$1.run(ExternalJavacProcess.java:264) at java.base/java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1144) at java.base/java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:642) at java.base/java.lang.Thread.run(Thread.java:1583) Caused by: java.lang.NoSuchFieldError: Class com.sun.tools.javac.tree.JCTree$JCImport does not have member field 'com.sun.tools.javac.tree.JCTree qualid' at lombok.javac.JavacImportList.getFullyQualifiedNameForSimpleNameNoAliasing(JavacImportList.java:53) at lombok.core.TypeResolver.typeRefToFullyQualifiedName(TypeResolver.java:60) at lombok.javac.HandlerLibrary.handleAnnotation(HandlerLibrary.java:247) at lombok.javac.JavacTransformer$AnnotationVisitor.visitAnnotationOnType(JavacTransformer.java:79) at lombok.javac.JavacNode.traverse(JavacNode.java:132) at lombok.javac.JavacAST.traverseChildren(JavacAST.java:222) at lombok.javac.JavacNode.traverse(JavacNode.java:95) at lombok.javac.JavacAST.traverseChildren(JavacAST.java:222) at lombok.javac.JavacNode.traverse(JavacNode.java:90) at lombok.javac.JavacAST.traverse(JavacAST.java:218) at lombok.javac.JavacTransformer.transform(JavacTransformer.java:63) at lombok.javac.apt.LombokProcessor.process(LombokProcessor.java:328) at lombok.core.AnnotationProcessor$JavacDescriptor.process(AnnotationProcessor.java:187) at lombok.core.AnnotationProcessor.process(AnnotationProcessor.java:241) at lombok.launch.AnnotationProcessorHider$AnnotationProcessor.process(AnnotationProcessor.java:90) at org.jetbrains.jps.javac.APIWrappers$ProcessorWrapper.process(APIWrappers.java:157) at java.base/jdk.internal.reflect.DirectMethodHandleAccessor.invoke(DirectMethodHandleAccessor.java:103) at java.base/java.lang.reflect.Method.invoke(Method.java:580) at org.jetbrains.jps.javac.APIWrappers$1.invoke(APIWrappers.java:313) at jdk.proxy2/jdk.proxy2.$Proxy8.process(Unknown Source) at jdk.compiler/com.sun.tools.javac.processing.JavacProcessingEnvironment.callProcessor(JavacProcessingEnvironment.java:1021) at jdk.compiler/com.sun.tools.javac.processing.JavacProcessingEnvironment.discoverAndRunProcs(JavacProcessingEnvironment.java:937) at jdk.compiler/com.sun.tools.javac.processing.JavacProcessingEnvironment$Round.run(JavacProcessingEnvironment.java:1265) at jdk.compiler/com.sun.tools.javac.processing.JavacProcessingEnvironment.doProcessing(JavacProcessingEnvironment.java:1380) at jdk.compiler/com.sun.tools.javac.main.JavaCompiler.processAnnotations(JavaCompiler.java:1272) at jdk.compiler/com.sun.tools.javac.main.JavaCompiler.compile(JavaCompiler.java:946) at jdk.compiler/com.sun.tools.javac.api.JavacTaskImpl.lambda$doCall$0(JavacTaskImpl.java:104) at jdk.compiler/com.sun.tools.javac.api.JavacTaskImpl.invocationHelper(JavacTaskImpl.java:152) ... 9 more
03-21
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

wending-Y

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值