Intellij Apache Ignite 项目不会生成有效的 JAR 文件

Intellij Apache Ignite Project won't generate a working JAR File

我的 Intellij 项目 运行 在 IDE 中完美无缺,但任何试图从中提取有效 .jar 文件的方法都会导致某种错误。 我的项目使用 Maven、Spring 和 Apache Ignite。 这是我的 pom.xml 文件:

<?xml version="1.0" encoding="UTF-8"?>
<project
    xmlns="http://maven.apache.org/POM/4.0.0"
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <build>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
                <version>2.1.1.RELEASE</version>
            </plugin>
            <plugin>
                <groupId>org.apache.maven.plugins</groupId>
                <artifactId>maven-compiler-plugin</artifactId>
                <version>3.8.0</version>
                <configuration>
                    <source>1.8</source>
                    <target>1.8</target>
                </configuration>
            </plugin>
        </plugins>
    </build>
    <modelVersion>4.0.0</modelVersion>

    <groupId>org.apache.ignite</groupId>
    <artifactId>ignite-gettings-started</artifactId>
    <version>1.0.0</version>

    <dependencies>
        <dependency>
            <groupId>javax.cache</groupId>
            <artifactId>cache-api</artifactId>
            <version>1.0.0</version>
        </dependency>

        <dependency>
            <groupId>org.apache.ignite</groupId>
            <artifactId>ignite-core</artifactId>
            <version>2.1.0</version>
        </dependency>

        <dependency>
            <groupId>org.apache.ignite</groupId>
            <artifactId>ignite-spring</artifactId>
            <version>2.1.0</version>
        </dependency>

        <dependency>
            <groupId>org.apache.ignite</groupId>
            <artifactId>ignite-indexing</artifactId>
            <version>2.1.0</version>
        </dependency>

        <dependency>
            <groupId>org.apache.maven.plugins</groupId>
            <artifactId>maven-compiler-plugin</artifactId>
            <version>3.8.0</version>
        </dependency>



    </dependencies>

    <properties>
        <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
        <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
    </properties>

</project>

清单:

Manifest-Version: 1.0
Main-Class: server.ServerNodeExample

并且,文件夹结构:

- project
  - .idea
  - out
  - src
    - main
      - java
        - examples
          - ...
        - server
          - ...
      - resources
        - META-INF
          - MANIFEST.MF
    - test
  - target
  - pom.xml

我在下面列出了尝试:

1 - pom.xml 目录中的 运行 mvn clean install:编译正常,但我得到错误 no main manifest attribute 相对于我的 jar 文件。

2 - 我打开了 jar 文件,那里的清单很不一样:

Manifest-Version: 1.0
Archiver-Version: Plexus Archiver
Built-By: evandro.teixeira
Created-By: Apache Maven 3.3.9
Build-Jdk: 1.8.0_191

所以我在上面附加了这一行:

Main-Class: server.ServerNodeExample

现在我发现自己陷入了这个奇怪的异常:

  :$ java -jar ignite-gettings-started-1.0.0.jar 
Error: A JNI error has occurred, please check your installation and try again
Exception in thread "main" java.lang.NoClassDefFoundError: org/apache/ignite/IgniteException
  at java.lang.Class.getDeclaredMethods0(Native Method)
  at java.lang.Class.privateGetDeclaredMethods(Class.java:2701)
  at java.lang.Class.privateGetMethodRecursive(Class.java:3048)
  at java.lang.Class.getMethod0(Class.java:3018)
  at java.lang.Class.getMethod(Class.java:1784)
  at sun.launcher.LauncherHelper.validateMainClass(LauncherHelper.java:544)
  at sun.launcher.LauncherHelper.checkAndLoadMain(LauncherHelper.java:526)
Caused by: java.lang.ClassNotFoundException: org.apache.ignite.IgniteException
  at java.net.URLClassLoader.findClass(URLClassLoader.java:382)
  at java.lang.ClassLoader.loadClass(ClassLoader.java:424)
  at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:349)
  at java.lang.ClassLoader.loadClass(ClassLoader.java:357)
  ... 7 more

有什么想法吗?

如果您希望能够 运行 您的项目 java -jar,您将需要构建一个 fat jar。这不取决于您的依赖项的性质,只要您有任何依赖项即可。

您也可以尝试使用 Spring Boot,它会为您做一个 fat jar。

而且我不建议使用 Apache Ignite 2.1,因为它太旧了,当您弄清楚如何启动项目时,Apache Ignite 2.7 应该已经出来了。