Подтвердить что ты не робот

Maven Deploy для нескольких серверов Tomcat

Каков самый минимальный пример развертывания войны на нескольких серверах tomcat с использованием maven, который можно записать?

Я пробовал следующие URL-адреса и задавал список рассылки, но не придумывал что-то короткое и просто работал.

В примере должны быть указаны серверы, определенные в примере где-нибудь (с примерами имен пользователей/паролей)

4b9b3361

Ответ 1

Идея Markus Lux также может применяться с решением Maven2 с управлением профилями:

<build>
    <plugins>
        <plugin>
            <groupId>org.codehaus.cargo</groupId>
            <artifactId>cargo-maven2-plugin</artifactId>
        </plugin>
    </plugins>
    ...
</build>
<profiles>
    <profile>
        <id>env-foo1</id>
        <!-- Activated when -Denv=foo1 is given as parameter. -->
        <activation>
            <property>
                <name>env</name>
                <value>foo1</value>
            </property>
        </activation>
        <properties>
            <deploy.env>xxx</deploy.env>
            <tomcat.manager>http://foo1/manager</tomcat.manager>
            <tomcat.manager.username>foo</tomcat.manager.username>
            <tomcat.manager.password>bar</tomcat.manager.password>
        </properties>
    </profile> 
    <profile>
        <id>env-foo2</id>
        <!-- Activated when -Denv=foo2 is given as parameter. -->
        <activation>
            <property>
                <name>env</name>
                <value>foo2</value>
            </property>
        </activation>
        <properties>
            <deploy.env>dev</deploy.env>
            <tomcat.manager>http://foo2/manager</tomcat.manager>
            <tomcat.manager.username>foo</tomcat.manager.username>
            <tomcat.manager.password>bar</tomcat.manager.password>
        </properties>
    </profile>
    ... 
</profiles>    

Затем вам просто нужно запустить X раз команду mvn с соответствующим параметром (-Denv = foo1, -Denv = foo2,...)


В дополнение к этому вы можете улучшить это решение, используя функцию Matrix Hudson Сервер непрерывной интеграции. Я кратко рассказал об этой функции здесь.

В принципе, вы просто определяете "нормальную" работу Maven2 в Hudson и с помощью функции Matrix, вы можете попросить Хадсона запустить эту работу несколько раз, по одному на среду. В других словах вы создаете свое задание Хадсона, а затем определяете "ось окружения" со всеми возможными значениями для параметра env:

  • foo1
  • foo2
  • foo3
  • ...

Затем Хадсон будет создавать приложение с помощью команды mvn и с параметром -Denv = foo1.Once эта сборка завершена, она будет создавать одно и то же приложение, но с параметром -Denv = foo2, и так далее...

Таким образом, Hudson будет развертывать ваше приложение в любой среде...

Я надеюсь, что мое решение поможет вам достичь ваших целей...

Ответ 2

Что касается использования нескольких профилей, жизненный цикл, казалось, дублировал определенные шаги - например. количество тестов удваивается при использовании профилей, активируемых переменными. Мы обнаружили, что использование каталитической библиотеки было намного более эффективным;) и более "минимальным". Используйте элемент "Исполнения", чтобы привязать цель "выполнить" к фазе жизненного цикла, чтобы упорядочить ее или запустить после пакета: mvn package antrun: run

Вы могли бы немного походить на библиотеку ant -contrib и создать цикл for со списком серверов, но здесь статическая конфигурация для 2 жестких кодированных серверных URL-адресов.

<plugin>
    <groupId>org.apache.maven.plugins</groupId>
    <artifactId>maven-antrun-plugin</artifactId>
    <version>1.6</version>
    <configuration>
        <target>
            <taskdef name="deploy" classname="org.apache.catalina.ant.DeployTask"/>
            <deploy url="http://tc-app-01:8080/manager" username="manager" password="pass"
                    path="/app-path" war="file:${project.build.directory}/${project.build.finalName}.${project.packaging}" update="true"/>

            <deploy url="http://tc-app-02:8080/manager" username="manager" password="pass"
                    path="/app-path" war="file:${project.build.directory}/${project.build.finalName}.${project.packaging}" update="true"/>
        </target>
    </configuration>
    <dependencies>
        <dependency>
            <groupId>tomcat</groupId>
            <artifactId>catalina-ant</artifactId>
            <version>6.0.29</version>
        </dependency>
    </dependencies>
</plugin>

Конкретная версия каталинии ant, использованная выше, была вручную развернута в нашем распределенном репозитории maven, ее можно найти в каталоге lib для дистрибутива tomcat.

Ответ 3

Это довольно поздний ответ на старый вопрос, но я уверен, что люди будут в этом заинтересованы. Я просто добился выполнения нескольких развертываний с использованием задач maven и ant. Секрет заключается в использовании макродефа (или 2 для меня, когда я горячо развертываю свои приложения в причале и должен переносить войну и файл xml) и используя файл свойств ant:

<plugin>
    <artifactId>maven-antrun-plugin</artifactId>
    <version>1.7</version>
    <executions>
        <execution>
            <phase>install</phase>
            <configuration>
                <tasks>
                    <taskdef name="scp"
                        classname="org.apache.tools.ant.taskdefs.optional.ssh.Scp"
                        classpath="/usr/local/java/ant/lib/ant-jsch.jar:/usr/local/java/ant/lib/jsch-0.1.45.jar" />
                    <macrodef name="deploy">
                        <attribute name="server" default="NOT SET" />
                        <attribute name="file" default="NOT SET" />
                        <attribute name="todir" default="NOT SET" />
                        <attribute name="port" default="NOT SET" />
                        <attribute name="passphrase" default="NOT SET" />
                        <attribute name="keyfile" default="NOT SET" />
                        <sequential>
                            <echo message="Deploying to @{server}" />
                            <echo message="Deploying @{file} to @{todir}" />
                            <scp
                                file="@{file}" todir="@{todir}"
                                port="@{port}" passphrase="@{passphrase}"
                                keyfile="@{keyfile}" />
                        </sequential>
                    </macrodef>
                    <macrodef name="deploy-app">
                        <attribute name="config" default="NOT SET" />
                        <sequential>
                            <property file="deploy.properties"/>
                            <echo message="Deploying to @{config}" />
                            <deploy server="${@{config}.jetty.server.host}"
                                    file="${project.build.directory}/${project.build.finalName}.${project.packaging}"
                                    todir="${@{config}.jetty.server.user}@${@{config}.jetty.server.host}:${@{config}.jetty.server.baseDir}/${@{config}.jetty.server.webappsDir}"
                                    port="${@{config}.jetty.server.port}"
                                    passphrase="${@{config}.jetty.server.passphrase}"
                                    keyfile="/home/steff/.ssh/id_rsa"/>
                            <deploy server="${@{config}.jetty.server.host}"
                                    file="${project.build.finalName}.xml"
                                    todir="${@{config}.jetty.server.user}@${@{config}.jetty.server.host}:${@{config}.jetty.server.baseDir}/${@{config}.jetty.server.contextDir}"
                                    port="${@{config}.jetty.server.port}"
                                    passphrase="${@{config}.jetty.server.passphrase}"
                                    keyfile="/home/steff/.ssh/id_rsa"/>                                     
                        </sequential>
                    </macrodef>                             
                    <deploy-app config="home"/>     
                    <deploy-app config="wap"/>
                </tasks>
            </configuration>
            <goals>
                <goal>run</goal>
            </goals>
        </execution>
    </executions>
</plugin>

Затем файл свойства должен выглядеть примерно так:

home.jetty.server.user=
home.jetty.server.port=
home.jetty.server.host=
home.jetty.server.baseDir=
home.jetty.server.webappsDir=
home.jetty.server.contextDir=
home.jetty.server.passphrase=
wap.jetty.server.user=
wap.jetty.server.port=
wap.jetty.server.host=
wap.jetty.server.baseDir=
wap.jetty.server.webappsDir=
wap.jetty.server.contextDir=
wap.jetty.server.passphrase=

и т.д. на блоке опций на конфигурацию сервера, используемой

<deploy-app config="<config>"/>

Фокус в том, что атрибут macrodef использует @{} как приоритет над оценкой свойства ${} в ant.

Ответ 4

Возможно, "самое минимальное" решение не является минимальным. Если у вас есть проблемы с этим в maven, попробуйте использовать ant: создайте две разные задачи развертывания (по одному на один сервер) и другую задачу, которая имеет их как зависимости. Существует несколько примеров развертывания на сервере tomcat с помощью ant. Просто Google. Сделав это, вам нужно интегрировать новые задачи ant в maven, что совсем не сложно с помощью плагина antrun.

Ответ 5

Этот ответ для Jetty и для немного другой ситуации, но вы можете найти его полезным в любом случае.

В предыдущем проекте мы использовали Jetty, поэтому я написал простой модуль развертывания Jetty, который периодически просматривал репозиторий maven и загружал и развертывал новые артефакты, как только они стали доступны. Это хорошо работает на небольшом кластере машин для разработки и разработки.

Код в коде Google можно найти в проекте Проект Polar Rose Jetty Maven Deployer.

Обратите внимание, что мы сделали это только для серверов разработки и промежуточного уровня. По-моему, производственные приложения никогда не должны обновляться автоматически.