Apache Maven의 exec-maven-plugin에서 main class를 찾지 못합니다
이클립스에 Apache Maven을 사용해서 자바 프로젝트를 진행하려고 합니다.
현재 문제를 요약하면 제 컴퓨터에서는 안되는데 다른데서는 된다는... 즉 제 컴퓨터 설정이 이상하다는 소리가 되겠군요 -_-;;
이 문제 해결을 위해 검색은 당연하고 SO에 질문까지 해봤지만 그렇게 좋은 답을 얻진 못하였습니다 ㅠㅠ
일단 현재 상황부터 말씀드리자면..
기본 예제로 시작해서 pom파일만 건드렸습니다.
그리고 컴파일은 됩니다.
mvn -e compile exec:java
오류 없이 BUILD SUCCESS가 뜹니다.
그런데 실행이 안됩니다.
mvn -e clean exec:java
이런 에러가 발생합니다.
[WARNING] [WARNING] Some problems were encountered while building the effective settings [WARNING] expected START_TAG or END_TAG not TEXT (position: TEXT seen ...ore artifacts.\n |\n | Default: ${user.home}/.m2/repository\n <l... @53:5) @ C:\apache-maven-3.3.3\conf\settings.xml, line 53, column 5 [WARNING] expected START_TAG or END_TAG not TEXT (position: TEXT seen ...ore artifacts.\n |\n | Default: ${user.home}/.m2/repository\n <l... @53:5) @ C:\apache-maven-3.3.3\conf\settings.xml, line 53, column 5 [WARNING] [INFO] Scanning for projects... [INFO] [INFO] ------------------------------------------------------------------------ [INFO] Building MavenTestProject 0.0.1-SNAPSHOT [INFO] ------------------------------------------------------------------------ [INFO] [INFO] --- maven-clean-plugin:2.5:clean (default-clean) @ MavenTestProject --- [INFO] Deleting C:\Users\bonavision_laptop\Desktop\Project\JadeX\MavenTestProject\MavenTestProject\target [INFO] [INFO] --- exec-maven-plugin:1.4.0:java (default-cli) @ MavenTestProject --- [WARNING] java.lang.ClassNotFoundException: com.jadex.qna.MavenTestProject.App at java.net.URLClassLoader.findClass(URLClassLoader.java:381) at java.lang.ClassLoader.loadClass(ClassLoader.java:424) at java.lang.ClassLoader.loadClass(ClassLoader.java:357) at org.codehaus.mojo.exec.ExecJavaMojo$1.run(ExecJavaMojo.java:281) at java.lang.Thread.run(Thread.java:745) [INFO] ------------------------------------------------------------------------ [INFO] BUILD FAILURE [INFO] ------------------------------------------------------------------------ [INFO] Total time: 0.900 s [INFO] Finished at: 2015-06-15T17:42:19+09:00 [INFO] Final Memory: 8M/153M [INFO] ------------------------------------------------------------------------ [ERROR] Failed to execute goal org.codehaus.mojo:exec-maven-plugin:1.4.0:java (default-cli) on project MavenTestProject: An exception occured while executing the Java class. com.jadex.qna.MavenTestProject.App -> [Help 1] [ERROR] [ERROR] To see the full stack trace of the errors, re-run Maven with the -e switch. [ERROR] Re-run Maven using the -X switch to enable full debug logging. [ERROR] [ERROR] For more information about the errors and possible solutions, please read the following articles: [ERROR] [Help 1] <a href="http://cwiki.apache.org/confluence/display/MAVEN/MojoExecutionException " rel="nofollow">http://cwiki.apache.org/confluence/display/MAVEN/MojoExecutionException </a>
내용을 보면 main class를 못찾는다는 말인데...
제 pom 파일에는 이렇게 설정해두었습니다.
<plugin> <groupId>org.codehaus.mojo</groupId> <artifactId>exec-maven-plugin</artifactId> <version>1.4.0</version> <executions> <execution> <phase>package</phase> <goals> <goal>java</goal> </goals> </execution> </executions> <configuration> <mainClass>com.jadex.qna.MavenTestProject.App</mainClass> </configuration> </plugin>
이것과 관련하여...
mvn -e clean exec:java -Dexec.mainClass=com.jadex.qna.MavenTestProject.App
도 해봤지만 같은 오류가 발생합니다.
제가 SO에 질문했던 링크를 같이 올려드리겠습니다.
첫번째: http://stackoverflow.com/questions/30836673/exec-maven-plugin-error-even-on-working-example
두번째: http://stackoverflow.com/questions/30841617/exec-maven-plugin-error-can-compile-but-can-not-run-project
그리고 이건 프로젝트 전체입니다. Maven Project quickstart 생성시 만들어지는 기본 코드에 pom만 수정한 것이고...
첫 질문 보시면 아시겠지만 제 pom파일로 댓글달아주신 분이 구동 성공하셨다고 하는군요...
https://github.com/arincblossom/MavenTestProject
초기엔 JDK path 문제라고 여겨져서 다른 블로그를 찾아서
이클립스에 설정된 자체 build path와 프로젝트의 build path를 모두 바꿨습니다.
그 이후로 이 상태입니다.
환경변수는 MAVEN_HOME, JAVA_HOME 그리고 path에 %MAVEN_HOME%\bin 추가... 이렇게 설정해놨고 다 동작 잘 하는거 확인 했습니다.
뭐가 문제일까요 ㅠㅠ 4일째 이걸로 고생중인데 해답을 찾았을 수 있었으면 좋겠습니다.
댓글 달기