sparkStreaming消费kafka时发生"java.lang.NoSuchMethodError: net.jpountz.util.Utils.checkRange"的解决办法

在使用Spark Streaming从Kafka消费数据时遇到'java.lang.NoSuchMethodError: net.jpountz.util.Utils.checkRange'错误。问题源于版本不匹配。解决方法是将编译后的class文件覆盖到spark-streaming-kafka-0-8-assembly_2.11.jar中的相应文件,参照Apache Kafka的特定提交和Stack Overflow上的讨论进行修复。

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

问题描述:

开发环境为spark2.0 + kafka0.8,spark-streaming-kafka-0-8-assembly_2.11.jar
sparkStreaming消费kafka时遇到如下错误:
18/02/27 10:19:17 WARN ReceiverSupervisorImpl: Reported error Error handling message; exiting - java.lang.NoSuchMethodError: net.jpountz.util.Utils.checkRange([BII)V
18/02/27 10:19:17 WARN ReceiverTracker: Error reported by receiver for stream 0: Error handling message; exiting - java.lang.NoSuchMethodError: net.jpountz.util.Utils.checkRange([BII)V
at org.apache.kafka.common.message.KafkaLZ4BlockInputStream.read(KafkaLZ4BlockInputStream.java:176)

问题原因:

1.spark2.0用到了lz4-1.3.0.jar,kafka0.8用到了lz4-1.2.0.jar,而程序运行时使用的是lz4-1.3.0.jar。
2.lz4-1.3.0.jar包中net.jpountz.util.Utils 类中没有checkRange,该方法位于net.jpountz.util.SafeUtils和net.jpountz.util.UnsafeUtils.(lz4-1.2.0.jar包有net.jpountz.util.Utils.checkRange​,但使用lz4-1.2.0.jar spa
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值