1. ホーム
  2. java

[解決済み] mavenで実行可能なjarをビルドする?

2022-07-18 08:34:09

質問

私は、以下のように、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 ファイルが実行されないのか、どなたか教えていただけませんか?また、そもそもなぜ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>

どのように解決するのですか?

実は、私は、この記事の中の 質問 というのは が間違っている ( 更新 - 20101106: 誰かがそれを修正しました。 これ のことを指しています。 バージョンの編集の前にある を参照してください)、これは、少なくとも部分的には、あなたが問題に遭遇する理由を説明します。


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

1つ目のjarは package フェーズで jar:jar (モジュールはパッケージングタイプの jar ). もう一つは、生成されたアセンブリが 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>

そこで logmanager-0.1.0.jar は確かに実行可能ですが、1. これはあなたが望むものではありません (すべての依存関係を持たないからです) し、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-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:singlepackage フェーズを実行する必要がないように assembly:assembly を実行する必要はありません。ただ mvn install を実行するだけで、標準的なビルドの間にアセンブリが生成されます。

というわけで、pom.xml を上記の構成で更新し、以下のように実行してください。 mvn clean install . に cd してください。 target ディレクトリに移動して、もう一度試してみてください。

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>