128

次のように、mavenを使用して「logmanager」と呼ばれる小さなホームプロジェクト用の実行可能なjarファイルを生成しようとしています:

Maven を使用して依存関係を持つ実行可能な JAR を作成するにはどうすればよいですか?

そこに示されているスニペットを pom.xml に追加し、mvn assembly:assembly. logmanager/target に、logmanager-0.1.0.jar と logmanager-0.1.0-jar-with-dependencies.jar の 2 つの jar ファイルが生成されます。最初の jar をダブルクリックするとエラーが発生します。

Could not find the main class: com.gorkwobble.logmanager.LogManager. Program will exit.

jar-with-dependencies.jar をダブルクリックすると、少し異なるエラーが表示されます。

Failed to load Main-Class manifest attribute from: C:\EclipseProjects\logmanager\target\logmanager-0.1.0-jar-with-dependencies.jar

パスとクラス名をコピーして貼り付け、POM のスペルをチェックしました。私のメインクラスは、Eclipse 起動構成から正常に起動します。私のjarファイルが実行されない理由を誰かが理解するのを手伝ってくれますか? また、そもそもなぜ 2 つの瓶があるのでしょうか。さらに情報が必要な場合はお知らせください。

pom.xml参照用に完全な を次に示します。

<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/maven-v4_0_0.xsd">
  <modelVersion>4.0.0</modelVersion>
  <groupId>com.gorkwobble</groupId>
  <artifactId>logmanager</artifactId>
  <name>LogManager</name>
  <version>0.1.0</version>
  <description>Systematically renames specified log files on a scheduled basis. Designed to help manage MUSHClient logging and prevent long, continuous log files.</description>
  <build>
    <plugins>
        <plugin>
            <groupId>org.apache.maven.plugins</groupId>
            <artifactId>maven-jar-plugin</artifactId>
            <version>2.2</version>
            <!-- nothing here -->
        </plugin>
        <plugin>
            <groupId>org.apache.maven.plugins</groupId>
            <artifactId>maven-assembly-plugin</artifactId>
            <version>2.2-beta-4</version>
            <configuration>
              <descriptorRefs>
                <descriptorRef>jar-with-dependencies</descriptorRef>
              </descriptorRefs>
              <archive>
                <manifest>
                  <mainClass>com.gorkwobble.logmanager.LogManager</mainClass>
                </manifest>
              </archive>
            </configuration>
            <executions>
              <execution>
                <phase>package</phase>
                <goals>
                  <goal>single</goal>
                </goals>
              </execution>
            </executions>
          </plugin>
          <plugin>
            <groupId>org.apache.maven.plugins</groupId>
            <artifactId>maven-compiler-plugin</artifactId>
            <configuration>
              <source>1.6</source>
              <target>1.6</target>
            </configuration>
          </plugin>
    </plugins>
  </build>
  <dependencies>
    <!-- commons-lang -->
    <dependency>
        <groupId>commons-lang</groupId>
        <artifactId>commons-lang</artifactId>
        <version>2.4</version>
    </dependency> 

    <!-- Quartz scheduler -->
    <dependency>
        <groupId>opensymphony</groupId>
        <artifactId>quartz</artifactId>
        <version>1.6.3</version>
    </dependency>
    <!-- Quartz 1.6.0 depends on commons collections -->
    <dependency>
      <groupId>commons-collections</groupId>
      <artifactId>commons-collections</artifactId>
      <version>3.1</version>
    </dependency>
    <!-- Quartz 1.6.0 depends on commons logging -->
    <dependency>
      <groupId>commons-logging</groupId>
      <artifactId>commons-logging</artifactId>
      <version>1.1</version>
    </dependency>
    <!-- Quartz 1.6.0 requires JTA in non J2EE environments -->
    <dependency>
      <groupId>javax.transaction</groupId>
      <artifactId>jta</artifactId>
      <version>1.1</version>
      <scope>runtime</scope>
    </dependency>

    <!-- junitx test assertions -->
    <dependency>
        <groupId>junit-addons</groupId>
        <artifactId>junit-addons</artifactId>
        <version>1.4</version>
        <scope>test</scope>
    </dependency>

    <!-- junit dependency; FIXME: make this a separate POM -->
    <dependency>
      <groupId>junit</groupId>
      <artifactId>junit</artifactId>
      <version>4.1</version>
    </dependency>

  </dependencies>
  <dependencyManagement>
  </dependencyManagement>
</project>
4

4 に答える 4

248

実際、あなたが言及した質問の回答は間違っていると思います( UPDATE - 20101106:誰かが修正しました。この回答は編集前のバージョンを参照しています)。


logmanager/target に、logmanager-0.1.0.jar と logmanager-0.1.0-jar-with-dependencies.jar の 2 つの jar ファイルが生成されます。

package最初のものは、フェーズ中に生成された logmanager モジュールの JAR ですjar:jar(モジュールには type のパッケージがあるためjar)。2 つ目はによって生成されたアセンブリでassembly:assemblyあり、現在のモジュールのクラスとその依存関係を含める必要があります (記述子を使用した場合jar-with-dependencies)。

最初の jar をダブルクリックするとエラーが発生します。

Could not find the main class: com.gorkwobble.logmanager.LogManager. Program will exit.

参照として投稿されたリンクの推奨構成を適用した場合、次のような実行可能なアーティファクトを生成するように jar プラグインを構成しました。

  <plugin>
    <groupId>org.apache.maven.plugins</groupId>
    <artifactId>maven-jar-plugin</artifactId>
    <configuration>
      <archive>
        <manifest>
          <addClasspath>true</addClasspath>
          <mainClass>com.gorkwobble.logmanager.LogManager</mainClass>
        </manifest>
      </archive>
    </configuration>
  </plugin>

確かに実行可能ですが、1.これlogmanager-0.1.0.jarはあなたが望むものではなく(すべての依存関係がないため)、2.含まれていませんcom.gorkwobble.logmanager.LogManager(これはエラーが言っていることです。jarの内容を確認してください)。

jar-with-dependencies.jar をダブルクリックすると、少し異なるエラーが表示されます。

Failed to load Main-Class manifest attribute from: C:\EclipseProjects\logmanager\target\logmanager-0.1.0-jar-with-dependencies.jar

ここでも、アセンブリ プラグインを推奨どおりに構成すると、次のようになります。

  <plugin>
    <groupId>org.apache.maven.plugins</groupId>
    <artifactId>maven-assembly-plugin</artifactId>
    <configuration>
      <descriptorRefs>
        <descriptorRef>jar-with-dependencies</descriptorRef>
      </descriptorRefs>
    </configuration>
  </plugin>

このセットアップでlogmanager-0.1.0-jar-with-dependencies.jarは、現在のモジュールのクラスその依存関係が含まれていますが、エラーによると、エントリが含まれてMETA-INF/MANIFEST.MF いませんMain-Class(logmanager-0.1.0.jar と同じ MANIFEST.MF ではない可能性があります)。jar は実際に実行可能ではありません。これもまた、必要なものではありません。


したがって、私の提案はconfiguration、maven-jar-plugin から要素を削除し、maven-assembly-plugin を次のように構成することです。

  <plugin>
    <groupId>org.apache.maven.plugins</groupId>
    <artifactId>maven-jar-plugin</artifactId>
    <version>2.2</version>
    <!-- nothing here -->
  </plugin>
  <plugin>
    <groupId>org.apache.maven.plugins</groupId>
    <artifactId>maven-assembly-plugin</artifactId>
    <version>2.2-beta-4</version>
    <configuration>
      <descriptorRefs>
        <descriptorRef>jar-with-dependencies</descriptorRef>
      </descriptorRefs>
      <archive>
        <manifest>
          <mainClass>org.sample.App</mainClass>
        </manifest>
      </archive>
    </configuration>
    <executions>
      <execution>
        <phase>package</phase>
        <goals>
          <goal>single</goal>
        </goals>
      </execution>
    </executions>
  </plugin>

もちろん、org.sample.App実行したいクラスに置き換えてください。おまけに、フェーズにバインドassembly:singleしたので、もう走る必要はありません。実行するだけで、標準ビルド中にアセンブリが生成されます。packageassembly:assemblymvn install

そのため、上記の構成で pom.xml を更新して実行してくださいmvn clean install。次に、targetディレクトリに cd して再試行します。

java -jar logmanager-0.1.0-jar-with-dependencies.jar

エラーが発生した場合は、質問を更新して、META-INF/MANIFEST.MFファイルの内容と関連する部分pom.xml(プラグイン構成部分) を投稿してください。また、次の結果を投稿してください。

java -cp logmanager-0.1.0-jar-with-dependencies.jar com.gorkwobble.logmanager.LogManager

コマンドラインで正常に動作していることを示します(Eclipseが何を言っているかに関係なく)。

編集: Java 6 の場合、maven-compiler-plugin を構成する必要があります。これを pom.xml に追加します。

  <plugin>
    <groupId>org.apache.maven.plugins</groupId>
    <artifactId>maven-compiler-plugin</artifactId>
    <configuration>
      <source>1.6</source>
      <target>1.6</target>
    </configuration>
  </plugin>
于 2009-11-29T05:00:27.427 に答える
5

パッケージでアセンブリ ゴールを実行したくない場合は、次のコマンドを使用できます。

mvn package assembly:single

ここでパッケージはキーワードです。

于 2011-04-05T07:43:28.133 に答える
-1

プロジェクトを右クリックし、maven ビルド、maven クリーン、maven 生成リソース、および maven インストールを指定します。jar ファイルが自動的に生成されます。

于 2016-04-22T11:16:12.977 に答える