3

Java で Vert.x を使用する最初の試みを開始しています。IDE は Netbeans バージョン 8.1 です。Vert.x はバージョン 3.0.0 です。このプロジェクトのコードを以下に示します。pom.xml ファイルも以下にリストされています。このコードは Netbeans IDE で実行されますが、ビルド (jar ファイル用) は、以下のビルド レポートに示されているエラーなしでは完了しません。したがって、生成された jar ファイルは実行されません。インターネットで見つけられるすべてのリソースを調査しましたが、適切な解決策/回答が見つかりません。この問題を解決するために誰かが提供できる助けをいただければ幸いです。

POM ファイルは、新しいプロジェクトの作成時に Netbeans IDE によって生成されます。 ファイル - 新しいプロジェクト - Maven - Archetype からのプロジェクト - vertx-java-archetype 次に、main() メソッドを追加しました。

詳細なビルド エラー レポート:

    --- maven-jar-plugin:2.3.2:jar (default-jar) @ mavenproject2 ---
    Building jar: C:\Projects\GenMatchJ\mavenproject2\target\mavenproject2-1.0-SNAPSHOT.jar

    --- maven-shade-plugin:2.3:shade (default) @ mavenproject2 ---
    Including io.vertx:vertx-core:jar:3.0.0 in the shaded jar.
    Including io.netty:netty-common:jar:4.0.28.Final in the shaded jar.
    Including io.netty:netty-buffer:jar:4.0.28.Final in the shaded jar.
    Including io.netty:netty-transport:jar:4.0.28.Final in the shaded jar.
    Including io.netty:netty-handler:jar:4.0.28.Final in the shaded jar.
    Including io.netty:netty-codec:jar:4.0.28.Final in the shaded jar.
    Including io.netty:netty-codec-http:jar:4.0.28.Final in the shaded jar.
    Including com.fasterxml.jackson.core:jackson-core:jar:2.5.3 in the shaded jar.
    Including com.fasterxml.jackson.core:jackson-databind:jar:2.5.3 in the shaded jar.
    Including com.fasterxml.jackson.core:jackson-annotations:jar:2.5.0 in the shaded jar.
    Including io.vertx:vertx-web:jar:3.0.0 in the shaded jar.
    Including io.vertx:vertx-auth-common:jar:3.0.0 in the shaded jar.

    --- exec-maven-plugin:1.3.2:exec (default) @ mavenproject2 ---
    ------------------------------------------------------------------------
    BUILD FAILURE
    ------------------------------------------------------------------------
    Total time: 3.290s
    Finished at: Sun Jun 05 13:01:40 EDT 2016
    Final Memory: 30M/313M
    ------------------------------------------------------------------------
    Failed to execute goal org.codehaus.mojo:exec-maven-plugin:1.3.2:exec (default) on project mavenproject2: The parameters 'executable' for goal org.codehaus.mojo:exec-maven-plugin:1.3.2:exec are missing or invalid -> [Help 1]

To see the full stack trace of the errors, re-run Maven with the -e switch.
Re-run Maven using the -X switch to enable full debug logging.

For more information about the errors and possible solutions, please read the following articles:
[Help 1] http://cwiki.apache.org/confluence/display/MAVEN/PluginParameterException

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">
  <modelVersion>4.0.0</modelVersion>

  <groupId>com.ssp</groupId>
  <artifactId>mavenproject2</artifactId>
  <version>1.0-SNAPSHOT</version>
  <packaging>jar</packaging>

  <dependencyManagement>
    <dependencies>
      <dependency>
        <groupId>io.vertx</groupId>
        <artifactId>vertx-dependencies</artifactId>
        <version>3.0.0</version>
        <type>pom</type>
        <scope>import</scope>
      </dependency>
    </dependencies>
  </dependencyManagement>


  <dependencies>
    <dependency>
      <groupId>io.vertx</groupId>
      <artifactId>vertx-core</artifactId>
    </dependency>
    <dependency>
      <groupId>io.vertx</groupId>
      <artifactId>vertx-web</artifactId>
    </dependency>
  </dependencies>

  <build>
    <plugins>
      <plugin>
        <groupId>org.apache.maven.plugins</groupId>
        <artifactId>maven-compiler-plugin</artifactId>
        <version>3.3</version>
        <configuration>
          <source>1.8</source>
          <target>1.8</target>
        </configuration>
      </plugin>
      <plugin>
        <groupId>org.apache.maven.plugins</groupId>
        <artifactId>maven-shade-plugin</artifactId>
        <version>2.3</version>
        <executions>
          <execution>
            <phase>package</phase>
            <goals>
              <goal>shade</goal>
            </goals>
            <configuration>
              <transformers>
                <transformer implementation="org.apache.maven.plugins.shade.resource.ManifestResourceTransformer">
                  <manifestEntries>
                    <Main-Class>io.vertx.core.Starter</Main-Class>
                    <Main-Verticle>com.ssp.mavenproject2.Main</Main-Verticle>
                  </manifestEntries>
                </transformer>
                <transformer implementation="org.apache.maven.plugins.shade.resource.AppendingTransformer">
                  <resource>META-INF/services/io.vertx.core.spi.VerticleFactory</resource>
                </transformer>
              </transformers>
              <artifactSet></artifactSet>
              <outputFile>${project.build.directory}/mavenproject2-${project.version}-fat.jar</outputFile>
            </configuration>
          </execution>
        </executions>
      </plugin>
      <plugin>
        <groupId>org.codehaus.mojo</groupId>
        <artifactId>exec-maven-plugin</artifactId>
        <version>1.3.2</version>
        <executions>
          <execution>
            <phase>verify</phase>
            <goals>
              <goal>exec</goal>
            </goals>
          </execution>
        </executions>
        <configuration>
          <mainClass>io.vertx.core.Starter</mainClass>
          <additionalClasspathElements>
            <additionalClasspathElement>${basedir}/src/main/java/</additionalClasspathElement>
          </additionalClasspathElements>
          <systemProperties>
            <systemProperty>
              <key>vertx.deployment.options.redeploy</key>
              <value>true</value>
            </systemProperty>
            <systemProperty>
              <key>vertx.deployment.options.redeployScanPeriod</key>
              <value>100</value>
            </systemProperty>
          </systemProperties>
          <arguments>
            <argument>run</argument>
            <argument>com/ssp/mavenproject2/Main.java</argument>
            <!--                  <argument>-cluster</argument>
            <argument>-cluster-host</argument>
            <argument>127.0.0.1</argument>-->
          </arguments>
        </configuration>
      </plugin>
    </plugins>
  </build>
    <name>MainSsp</name>
    <description>Main entry point for SSP Example with embedded Vert.x</description>
</project>

ソースコード:

package com.ssp.mavenproject2;

import io.vertx.core.AbstractVerticle;
import io.vertx.core.Vertx;

import javax.swing.JOptionPane;


/**
 *
 */
public class Main extends AbstractVerticle {

  public static void main(String[] args) {


      JOptionPane.showMessageDialog(null, "This Vert.x/Java integration is UUUGGGGHH tough without documentation...");


      // Create an HTTP server which simply returns "Hello World!" to each request.
      Vertx.vertx().createHttpServer().requestHandler(req -> req.response().end("Hello World!")).listen(8080);

      Vertx.vertx().setPeriodic(3000, res -> {
        System.out.println("Periodic event triggered.");
      });

      try{

          Thread.sleep(30000);
      }catch(Exception e)
      {
         System.out.println("Exception caught");
      }
  }  

  @Override
  public void start() throws Exception {
    vertx.setPeriodic(3000, res -> {
      System.out.println("Periodic event triggered.");
    });
  }

}
4

2 に答える 2

0

実行しようとしているように見えますmvn exec:execが、そのためには実行可能ファイルを指定する必要があります (取得しているエラー)。その場合、実行可能ファイルは Java バイナリである必要があります。たとえば、/usr/java/latest/bin/javaLinux と Oracle RPM を使用している場合です。

またはmvn exec:java、実行可能ファイルが存在することを認識しjava、pom ファイルからクラスパスの依存関係を選択する方法を知っている必要があります。

コードに注意を払うと、public static void mainメソッドが呼び出されないことがわかります。実行プラグインはクラスではなく vert.x スターターを使用するため、アプリの起動時にサーバーはなく、定期的なコードが実行されるだけです。メソッドの内部start

メインを実行すると、バーチクルをデプロイすることができないため、サーバーはありますが、定期的なタスクはありません。これを達成するには、次を追加する必要があります。

vertx.deployVerticle(Main.class.getName());
于 2016-06-09T14:10:27.793 に答える