解决Exception in thread "main" java.lang.NoClassDefFoundError: kafka/serializer/StringDecoder

问题出现在Spark Streaming连Kafka的Jar包上传到服务器用spark-submit运行的时候:

如果在本地环境能够运行而去服务器报错,大概率原因是缺少两个jar包

kafka_2.11-0.8.2.1.jarmetrics-core-2.2.0.jar

jar包版本已你自己的为准,可以在IDEA你的项目里搜索(双击Shift开启全局搜索)这两个Jar包,上传到$SPARK_HOME/libs文件夹中再运行即可。

手把手教程:

metrics-core-2.2.0.jar为例:

解决Exception in thread "main" java.lang.NoClassDefFoundError: kafka/serializer/StringDecoder

然后找到它右键Show in Explorer即可找到该jar包,之后上传到服务器即可。

解决Exception in thread "main" java.lang.NoClassDefFoundError: kafka/serializer/StringDecoder