java.lang.NoClassDefFoundError: org/apache/kafka/common/security/auth/SecurityProtocol

在编写kafka操作API的过程中,查询的方法都没有什么问题,删除、修改topic或者消费组的时候,会出现一大堆红色报错:

java.lang.NoClassDefFoundError: org/apache/kafka/common/security/auth/SecurityProtocol

	at kafka.zk.BrokerIdZNode$.$anonfun$decode$3(ZkData.scala:213)
	at scala.collection.TraversableLike.$anonfun$map$1(TraversableLike.scala:234)
	at scala.collection.immutable.Map$Map1.foreach(Map.scala:120)
	at scala.collection.TraversableLike.map(TraversableLike.scala:234)
	at scala.collection.TraversableLike.map$(TraversableLike.scala:227)
	at scala.collection.AbstractTraversable.map(Traversable.scala:104)
	at kafka.zk.BrokerIdZNode$.$anonfun$decode$2(ZkData.scala:212)
	at scala.Option.map(Option.scala:146)
	at kafka.zk.BrokerIdZNode$.decode(ZkData.scala:212)
	at kafka.utils.ZkUtils.parseBrokerJson(ZkUtils.scala:708)
	at kafka.utils.ZkUtils.$anonfun$getCluster$1(ZkUtils.scala:702)
	at scala.collection.Iterator.foreach(Iterator.scala:929)
	at scala.collection.Iterator.foreach$(Iterator.scala:929)
	at scala.collection.AbstractIterator.foreach(Iterator.scala:1417)
	at scala.collection.IterableLike.foreach(IterableLike.scala:71)
	at scala.collection.IterableLike.foreach$(IterableLike.scala:70)
	at scala.collection.AbstractIterable.foreach(Iterable.scala:54)
	at kafka.utils.ZkUtils.getCluster(ZkUtils.scala:700)
	at com.sunline.channel.kafkaAPI.manager.ConsoleApi.getCluster(ConsoleApi.java:42)
	at com.sunline.channel.kafkaAPI.manager.ConsoleApiTest.getCluster(ConsoleApiTest.java:25)
	at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
	at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
	at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
	at java.lang.reflect.Method.invoke(Method.java:498)
	at org.junit.runners.model.FrameworkMethod$1.runReflectiveCall(FrameworkMethod.java:50)
	at org.junit.internal.runners.model.ReflectiveCallable.run(ReflectiveCallable.java:12)
	at org.junit.runners.model.FrameworkMethod.invokeExplosively(FrameworkMethod.java:47)
	at org.junit.internal.runners.statements.InvokeMethod.evaluate(InvokeMethod.java:17)
	at org.springframework.test.context.junit4.statements.RunBeforeTestMethodCallbacks.evaluate(RunBeforeTestMethodCallbacks.java:75)
	at org.springframework.test.context.junit4.statements.RunAfterTestMethodCallbacks.evaluate(RunAfterTestMethodCallbacks.java:86)
	at org.springframework.test.context.junit4.statements.SpringRepeat.evaluate(SpringRepeat.java:84)
	at org.junit.runners.ParentRunner.runLeaf(ParentRunner.java:325)
	at org.springframework.test.context.junit4.SpringJUnit4ClassRunner.runChild(SpringJUnit4ClassRunner.java:252)
	at org.springframework.test.context.junit4.SpringJUnit4ClassRunner.runChild(SpringJUnit4ClassRunner.java:94)
	at org.junit.runners.ParentRunner$3.run(ParentRunner.java:290)
	at org.junit.runners.ParentRunner$1.schedule(ParentRunner.java:71)
	at org.junit.runners.ParentRunner.runChildren(ParentRunner.java:288)
	at org.junit.runners.ParentRunner.access$000(ParentRunner.java:58)
	at org.junit.runners.ParentRunner$2.evaluate(ParentRunner.java:268)
	at org.springframework.test.context.junit4.statements.RunBeforeTestClassCallbacks.evaluate(RunBeforeTestClassCallbacks.java:61)
	at org.springframework.test.context.junit4.statements.RunAfterTestClassCallbacks.evaluate(RunAfterTestClassCallbacks.java:70)
	at org.junit.runners.ParentRunner.run(ParentRunner.java:363)
	at org.springframework.test.context.junit4.SpringJUnit4ClassRunner.run(SpringJUnit4ClassRunner.java:191)
	at org.junit.runner.JUnitCore.run(JUnitCore.java:137)
	at com.intellij.junit4.JUnit4IdeaTestRunner.startRunnerWithArgs(JUnit4IdeaTestRunner.java:68)
	at com.intellij.rt.execution.junit.IdeaTestRunner$Repeater.startRunnerWithArgs(IdeaTestRunner.java:47)
	at com.intellij.rt.execution.junit.JUnitStarter.prepareStreamsAndStart(JUnitStarter.java:242)
	at com.intellij.rt.execution.junit.JUnitStarter.main(JUnitStarter.java:70)
Caused by: java.lang.ClassNotFoundException: org.apache.kafka.common.security.auth.SecurityProtocol
	at java.net.URLClassLoader.findClass(URLClassLoader.java:381)
	at java.lang.ClassLoader.loadClass(ClassLoader.java:424)
	at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:338)
	at java.lang.ClassLoader.loadClass(ClassLoader.java:357)
	... 48 more

我的pom依赖是这样的:

<dependency>
            <groupId>org.springframework.kafka</groupId>
            <artifactId>spring-kafka</artifactId>
            <version>1.1.0</version>
        </dependency>
        <dependency>
            <groupId>org.apache.kafka</groupId>
            <artifactId>kafka_2.12</artifactId>
            <version>1.1.0</version>
        </dependency>
在网上各种搜,很多答案都是缺少jar包,有的说是kafka版本要换回到0.8.2.2,当然这也是一种方案,姑且可以算作方案一。
但是我的整个项目的Kafka版本使用的是最新版本,包括发送,接收消息等功能。而且全局搜索了一下,是存在这个类的,只是不在该路径下而已。那么思索一下,系统加载这个类的方法肯定不是期望版本中的,那么。。。。。。。。。。。。。
对呀,很可能是jar包冲突!!!
于是查了maven依赖的Jar包,果然有个冲突:

这里写图片描述
那么,pom依赖变成如下所示:

<dependency>
			<groupId>org.springframework.kafka</groupId>
			<artifactId>spring-kafka</artifactId>
			 <version>1.1.0</version>
			<exclusions>
				<exclusion>
					<groupId>org.apache.kafka</groupId>
					<artifactId>kafka-clients</artifactId>
				</exclusion>
			</exclusions>
		</dependency>
		<dependency>
			<groupId>org.apache.kafka</groupId>
			<artifactId>kafka_2.12</artifactId>
			<version>1.1.0</version>
		</dependency>

解决冲突以后,再次执行,错误便消失了,删除修改操作轻松搞定~

如果大家有关于Spring Boot Spring Cloud等相关问题,可添加个人微信进行交流讨论,还可以关注微信公众号——青梅主码,进行更多干货获取!

个人微信号:1272808775

微信公众号~关注后,回复:java,即可获得群名片。加入java技术讨论群。

`java.lang.NoClassDefFoundError: org/apache/thrift/TException` 错误通常表示 Java 虚拟机(JVM)在运行时找不到 `org.apache.thrift.TException` 类。这可能是由于类路径配置问题、依赖缺失或版本不兼容等原因导致的。以下是一些可能的解决方法: ### 检查类路径 确保 Thrift 相关的 JAR 文件已经正确添加到类路径中。在不同的环境中,类路径的配置方式有所不同: #### 命令行运行 如果是通过命令行运行 Java 程序,需要在 `java` 命令中使用 `-cp` 或 `-classpath` 选项指定类路径。例如: ```sh java -cp path/to/thrift.jar:your/other/jars/* YourMainClass ``` #### IDE 环境 在 IDE(如 IntelliJ IDEA 或 Eclipse)中,需要将 Thrift 的 JAR 文件添加到项目的依赖中。以 IntelliJ IDEA 为例,可以在项目的 `Project Structure` -> `Modules` -> `Dependencies` 中添加 Thrift 的 JAR 文件。 ### 检查依赖管理工具 如果使用 Maven 或 Gradle 等依赖管理工具,需要确保在项目的配置文件中正确添加了 Thrift 的依赖。 #### Maven 在 `pom.xml` 文件中添加以下依赖: ```xml <dependency> <groupId>org.apache.thrift</groupId> <artifactId>libthrift</artifactId> <version>your-thrift-version</version> </dependency> ``` 将 `your-thrift-version` 替换为实际使用的 Thrift 版本号。 #### Gradle 在 `build.gradle` 文件中添加以下依赖: ```groovy implementation 'org.apache.thrift:libthrift:your-thrift-version' ``` 同样,将 `your-thrift-version` 替换为实际使用的 Thrift 版本号。 ### 检查版本兼容性 确保使用的 Thrift 版本与项目中的其他依赖兼容。不同版本的 Thrift 可能会有一些 API 或类的变化,如果版本不兼容,可能会导致 `NoClassDefFoundError` 错误。 ### 检查 Hive 安装 如果是在 Hive 安装或使用过程中出现该错误,确保 Hive 安装目录下的 `lib` 文件夹中包含 Thrift 的 JAR 文件。如果缺少,可以从 Apache Thrift 的官方网站下载相应版本的 JAR 文件,并将其复制到 Hive 的 `lib` 文件夹中。 ### 清理和重建项目 有时候,缓存文件可能会导致类路径问题。可以尝试清理项目的缓存文件,并重新构建项目。在 IDE 中,可以通过 `Build` -> `Clean Project` 和 `Build` -> `Rebuild Project` 来完成。 ### 检查环境变量 确保 `CLASSPATH` 环境变量包含了 Thrift 的 JAR 文件路径。可以使用以下命令查看和修改环境变量: ```sh # 查看环境变量 echo $CLASSPATH # 修改环境变量 export CLASSPATH=$CLASSPATH:/path/to/thrift.jar ```
评论 3
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值