7

GlassFish -maven-plugin ( https://maven-glassfish-plugin.dev.java.net/ ) を GlassFish v3 (私は Mac で Eclipse を使用しています) で使用しようとしていますが、うまくいきませんWeb アプリをデプロイするため。私は遭遇し続けます:

ドメインを開始するにはマスターパスワードが必要です。コンソールなし、プロンプトなし。--savemasterpassword=true を使用してドメインを作成するか、 --passwordfile オプションを使用してパスワード ファイルを提供する必要があります。

これが私のPOMファイルの関連部分です。

<profiles>
    <profile>
        <id>development</id>
        <activation>
            <property>
                <name>phase</name>
                <value>development</value>
            </property>
        </activation>
        <build>
            <plugins>
                <plugin>
                    <groupId>org.glassfish.maven.plugin</groupId>
                    <artifactId>maven-glassfish-plugin</artifactId>
                    <version>2.2-SNAPSHOT</version>
                    <configuration>
                        <glassfishDirectory>${glassfish.directory}</glassfishDirectory>
                        <user>${glassfish.user}</user>
                        <passFile>${glassfish.directory}/domains/${project.artifactId}/config/domain-passwords</passFile>
                        <domain>
                            <name>${project.artifactId}</name>
                        </domain>
                        <components>
                            <component>
                                <name>${project.artifactId}</name>
                                <artifact>${project.build.directory}/artifacts/${project.artifactId}.war</artifact>
                            </component>
                        </components>
                    </configuration>
                </plugin>
            </plugins>
        </build>
        <pluginRepositories>
            <pluginRepository>
                <id>ocean</id>
                <url>http://maven.ocean.net.au/snapshot</url>
                <releases>
                    <enabled>false</enabled>
                    <updatePolicy>never</updatePolicy>
                </releases>
                <snapshots>
                    <enabled>true</enabled>
                    <updatePolicy>always</updatePolicy>
                </snapshots>
            </pluginRepository>
        </pluginRepositories>
    </profile>
</profiles>

以下は、Maven が実行している start-domain コマンドです。

asadmin --host localhost --port 4848 --user admin --passwordfile /var/folders/sk/skcc8rAVGSynOBBaOwWN3U+++TI/-Tmp-/mgfp5377058868244877698.tmp --interactive=false --echo=true --terse= true start-domain --debug=false --domaindir /Applications/GlassFish/v3/glassfish/domains --help=false --upgrade=false --verbose=false mvnrepo

--passwordfile は一時ファイルを使用しているため、それが問題であると推測しています。何らかの理由で passFile パラメータが機能していません。

何か案は?私は私の仮定に間違っていますか?

4

2 に答える 2

11

Fairly Complete Configuration Exampleには、実際には<passFile>要素への参照がありますが、さまざまな目標のドキュメントではこの要素について言及されておらず、<passwordFile>代わりに参照されています (例として、glassfish:start-domainまたはglassfish:deployを参照してください)。したがって、それに応じてプロファイルのプラグインの構成を更新してみてください。

<plugin>
  <groupId>org.glassfish.maven.plugin</groupId>
  <artifactId>maven-glassfish-plugin</artifactId>
  <version>2.2-SNAPSHOT</version>
  <configuration>
    <glassfishDirectory>${glassfish.directory}</glassfishDirectory>
    <user>${glassfish.user}</user>
    <passwordFile>${glassfish.directory}/domains/${project.artifactId}/config/domain-passwords</passwordFile>
    <domain>
      <name>${project.artifactId}</name>
    </domain>
    <components>
      <component>
        <name>${project.artifactId}</name>
        <artifact>${project.build.directory}/artifacts/${project.artifactId}.war</artifact>
      </component>
    </components>
  </configuration>
</plugin>

補足として、組み込み API を使用して単一の JVM で Glassfish を実行できるmaven-embedded-glassfish-pluginをお勧めします。非常に素晴らしい。詳細については、v3 組み込みグラスフィッシュ用の maven プラグインの使用を参照してください。

更新:さらにテストを行いましたが、実際に私のマシンで問題を再現できませんでした(ため息)。

まず、次のコマンドを実行して新しいドメインを作成しました ( から<glassfish_home>/bin)。

$ ./asadmin create-domain  --savemasterpassword=true maven-glassfish-testcase

次に、maven の webapp アーキタイプを使用して新しい webapp を作成しました。

$ mvn archetype:create -DgroupId=com.mycompany.app \
      -DartifactId=maven-glassfish-testcase \
      -DarchetypeArtifactId=maven-archetype-webapp

そしてpom.xml、新しく作成された webapp を次のように更新しました。

<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.mycompany.app</groupId>
  <artifactId>maven-glassfish-testcase</artifactId>
  <packaging>war</packaging>
  <version>1.0-SNAPSHOT</version>
  <name>maven-glassfish-testcase Maven Webapp</name>
  <url>http://maven.apache.org</url>
  <properties>
    <glassfish.home>/home/pascal/opt/glassfishv3/glassfish</glassfish.home>
    <domain.username>admin</domain.username>
  </properties>
  <pluginRepositories>
    <pluginRepository>
      <id>ocean</id>
      <url>http://maven.ocean.net.au/snapshot</url>
      <releases>
        <enabled>false</enabled>
        <updatePolicy>never</updatePolicy>
      </releases>
      <snapshots>
        <enabled>true</enabled>
        <updatePolicy>always</updatePolicy>
      </snapshots>
    </pluginRepository>
  </pluginRepositories>
  <dependencies>
    <dependency>
      <groupId>junit</groupId>
      <artifactId>junit</artifactId>
      <version>3.8.1</version>
      <scope>test</scope>
    </dependency>
  </dependencies>
  <build>
    <finalName>maven-glassfish-testcase</finalName>
    <plugins>
      <plugin>
        <groupId>org.glassfish.maven.plugin</groupId>
        <artifactId>maven-glassfish-plugin</artifactId>
        <version>2.2-SNAPSHOT</version>
        <configuration>
          <glassfishDirectory>${glassfish.home}</glassfishDirectory>
          <user>${domain.username}</user>
          <passwordFile>${glassfish.home}/domains/${project.artifactId}/master-password</passwordFile>
          <debug>true</debug>
          <echo>true</echo>
          <domain>
            <name>${project.artifactId}</name>
            <adminPort>4848</adminPort> <!-- mandatory for mvn glassfish:deploy -->
          </domain>
          <components>
            <component>
              <name>${project.artifactId}</name>
              <artifact>${project.build.directory}/${project.build.finalName}.war</artifact>
            </component>
          </components>
        </configuration>
      </plugin>
    </plugins>
  </build>
</project>

この設定で実行mvn glassfish:start-domainすると、次の出力が生成されます。

$ mvn glassfish:開始ドメイン
[情報] プロジェクトをスキャンしています...
[情報] スナップショット org.glassfish.maven.plugin:maven-glassfish-plugin:2.2-SNAPSHOT: 海からの更新を確認しています
[情報]  -  -  -  -  -  -  -  -  -  -  -  -  -  -  -  -  -  -  -  -  -  -  - - -------------------------
[情報] maven-glassfish-testcase Maven Webapp のビルド
[情報] タスク セグメント: [glassfish:開始ドメイン]
[情報]  -  -  -  -  -  -  -  -  -  -  -  -  -  -  -  -  -  -  -  -  -  -  - - -------------------------
[INFO] [glassfish:start-domain {execution: default-cli}]
[INFO] asadmin --host localhost --port 4848 --user admin --passwordfile /home/pascal/opt/glassfishv3/glassfish/domains/maven-glassfish-testcase/master-password --interactive=false --echo= true --terse=true start-domain --debug=true --domaindir /home/pascal/opt/glassfishv3/glassfish/domains --help=false --upgrade=false --verbose=false maven-glassfish-testcase
[INFO] 開始ドメイン: maven-glassfish-testcase
[情報] ドメインの場所: /home/pascal/opt/glassfishv3/glassfish/domains/maven-glassfish-testcase
[情報] ログ ファイル: /home/pascal/opt/glassfishv3/glassfish/domains/maven-glassfish-testcase/logs/server.log
[情報] ドメインの管理ポート: 4848
[情報] ドメインのデバッグ ポート: 9009
[情報]  -  -  -  -  -  -  -  -  -  -  -  -  -  -  -  -  -  -  -  -  -  -  - - -------------------------
[情報] ビルド成功
[情報]  -  -  -  -  -  -  -  -  -  -  -  -  -  -  -  -  -  -  -  -  -  -  - - -------------------------
[情報] 合計時間: 27 秒
[INFO] 終了: Mon Dec 21 20:16:17 CET 2009
[情報] 最終記憶: 4M/53M
[情報]  -  -  -  -  -  -  -  -  -  -  -  -  -  -  -  -  -  -  -  -  -  -  - - -------------------------

ご覧のとおり、--passwordfileオプションは POM で指定されたファイルを使用して正しく渡されます。つまり、物事は期待どおりに機能しています。この設定をデバッグするために、パスワード ファイルへのパスをハード コードしてみてください。問題なく動作するはずです。

于 2009-12-20T16:17:24.247 に答える
1

Maven-Glassfish-Plugin 構成に「adminPassword」プロパティを誤って残してしまったことに気付くのに少し時間がかかりました (そのため、adminPassword と passwordFile の両方が設定されていました)。プラグインは、自分のものではなく一時パスワードファイルを使用していたため、上記のエラーが発生しました。

他の誰かが私と同じくらい愚かな場合に備えて;)

于 2010-07-25T17:33:26.580 に答える