Шторм-стартер с интеллигентной идеей, проект maven не смог найти класс

Я начинаю идею шторма и интеллигенции, когда я импортирую шторм-стартер (apache-storm-0.9.5.zip) в идею интеллидж (ОС 14 CE), все в порядке, но когда я запускаю "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

этот интерфейс взят из штормового ядра, но этот управляемый файл maven находится в моей библиотеке. Почему это произошло?

1 ответ

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>
Другие вопросы по тегам