GlassFish v3 и Glassfish-Maven-плагин (Mac) - PullRequest
7 голосов
/ 20 декабря 2009

Я пытаюсь использовать glassfish-maven-plugin (https://maven -glassfish-plugin.dev.java.net / ) с GlassFish v3 (я на Mac и использую Eclipse ) и я не могу заставить мое веб-приложение развернуться. Я продолжаю сталкиваться с:

Мастер-пароль необходим для запуска домена. Нет консоли, никаких подсказок невозможно. Вам следует либо создать домен с параметром --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>

Вот команда start-domain, которую выполняет Maven.

asadmin --host localhost --port 4848 - администратор пользователя --passwordfile /var/folders/sk/skcc8rAVGSynOBBaOwWN3U+++TI/-Tmp-/mgfp5377058868244877698.tmp --interactive = false --echo = true - -terse = истинный стартовый домен --debug = false --domaindir / Applications / GlassFish / v3 / glassfish / domains --help = false --upgrade = false --verbose = false mvnrepo

--passwordfile использует временный файл, поэтому я предполагаю, что это проблема. По какой-то причине параметр passFile не работает.

Есть идеи? Я не прав с моим предположением?

Ответы [ 2 ]

11 голосов
/ 20 декабря 2009

В Fairly Complete Пример конфигурации действительно есть ссылка на элемент <passFile>, но документация по различным целям не упоминает этот элемент и ссылается на * Вместо 1006 * (см., Например, glassfish: начальный домен или glassfish: развертывание ). Итак, попробуйте обновить конфигурацию вашего плагина в своем профиле соответственно:

<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>

В качестве дополнительного примечания я рекомендую maven-embedded-glassfish-plugin , который позволяет запускать Glassfish в одной JVM с помощью встроенного API. Очень хорошо. Подробнее см. Использование плагина maven для v3 glassfish .

ОБНОВЛЕНИЕ: Я провел дополнительное тестирование и не смог воспроизвести вашу проблему на моей машине (вздох).

Сначала я создал новый домен, выполнив следующую команду (с <glassfish_home>/bin):

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

Затем я создал новое веб-приложение, используя архетип веб-приложения maven:

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

И обновил 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.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:start-domain
[INFO] Scanning for projects...
[INFO] snapshot org.glassfish.maven.plugin:maven-glassfish-plugin:2.2-SNAPSHOT: checking for updates from ocean
[INFO] ------------------------------------------------------------------------
[INFO] Building maven-glassfish-testcase Maven Webapp
[INFO]    task-segment: [glassfish:start-domain]
[INFO] ------------------------------------------------------------------------
[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] Started domain: maven-glassfish-testcase
[INFO] Domain location: /home/pascal/opt/glassfishv3/glassfish/domains/maven-glassfish-testcase
[INFO] Log file: /home/pascal/opt/glassfishv3/glassfish/domains/maven-glassfish-testcase/logs/server.log
[INFO] Admin port for the domain: 4848
[INFO] Debug port for the domain: 9009
[INFO] ------------------------------------------------------------------------
[INFO] BUILD SUCCESSFUL
[INFO] ------------------------------------------------------------------------
[INFO] Total time: 27 seconds
[INFO] Finished at: Mon Dec 21 20:16:17 CET 2009
[INFO] Final Memory: 4M/53M
[INFO] ------------------------------------------------------------------------

Как видите, опция --passwordfile передается правильно с использованием файла, указанного в POM. Другими словами, все работает так, как ожидалось. Может быть, попробуйте с жестко заданным путем к файлу паролей отладить этот параметр, он должен просто работать!

1 голос
/ 25 июля 2010

Мне потребовалось некоторое время, чтобы понять, что я случайно оставил свойство "adminPassword" в конфигурации Maven-Glassfish-Plugin (поэтому у меня были установлены оба adminPassword и passwordFile). Плагин все еще использовал временный файл паролей вместо моего собственного, что привело к указанной выше ошибке.

На всякий случай, если кто-то еще так же глуп, как я;)

...