maven - Storm-starter与intellij idea,maven项目找不到类

标签 maven intellij-idea apache-storm

我是storm和intellij idea的初学者,当我将storm-starter(apache-storm-0.9.5.zip)导入intellij idea(14 CE OS)时,一切正常,但是当我运行“ExclamationTopology”时",出现问题如下:

Exception in thread "main" java.lang.NoClassDefFoundError: backtype/storm/topology/IRichSpout
	at java.lang.Class.forName0(Native Method)
	at java.lang.Class.forName(Class.java:264)
	at com.intellij.rt.execution.application.AppMain.main(AppMain.java:122)
Caused by: java.lang.ClassNotFoundException: backtype.storm.topology.IRichSpout
	at java.net.URLClassLoader.findClass(URLClassLoader.java:381)
	at java.lang.ClassLoader.loadClass(ClassLoader.java:424)
	at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:331)
	at java.lang.ClassLoader.loadClass(ClassLoader.java:357)
	... 3 more

Process finished with exit code 1

这个接口(interface)来自storm-core,但是这个maven管理的jar在我的库中 为什么会发生这种事..?

最佳答案

Strom 已在服务器端安装了所需的 jar。因此,如果查看 pom.xml,您会发现类似于以下内容的内容: https://github.com/apache/storm/blob/master/examples/storm-starter/pom.xml

<dependency>
  <groupId>org.apache.storm</groupId>
  <artifactId>storm-core</artifactId>
  <version>${project.version}</version>
  <!-- keep storm out of the jar-with-dependencies -->
  <scope>provided</scope>
</dependency>

提供的范围仅在编译和测试类路径上可用。因此,您的项目可以编译,但在运行时会失败并出现异常:java.lang.NoClassDefFoundError。

请注释 pom.xml 中的作用域行并更新 Maven 依赖项以解决此问题。它应该看起来像:

<dependency>
  <groupId>org.apache.storm</groupId>
  <artifactId>storm-core</artifactId>
  <version>${project.version}</version>
  <!-- keep storm out of the jar-with-dependencies -->
  <!-- <scope>provided</scope> -->
</dependency>

关于maven - Storm-starter与intellij idea,maven项目找不到类,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30724424/

相关文章:

maven - 在 Tomcat 上阅读电子邮件 : ClassNotFoundException: javax. mail.MessagingException

java - 导入maven项目但父模块被禁用

apache-storm - 以编程方式获取 Storm 拓扑统计信息

java - 无法使用 Struts 2.5 运行简单的登录应用程序

java - 启动应用程序时出现 FileNotFoundException (Logback)

java - 编译时不断报java : invalid source release: 1. 9错误

java - 使用 File.listFiles() 时出现 IntelliJ "may cause NullPointerException"警告

java - Apache Storm : Ack not working

java - Storm : Spout for reading data from a port

maven - 第谷 - 导入包上的 "Unsatisfied constraint"