Zend Server: имя приложения уже существует

У нас возникла проблема на нашем Zend Server во время развертывания приложения.

Мы настроили виртуальный хост на нашем Zend-сервере под названием "dev.application-7.de". Мы пытаемся развернуть наш проект Zend Framework 2 через Jenkins на этом виртуальном хосте. Обычно это работает хорошо.

Но мы получили следующую ошибку в 3 из 170 сборок:

deploy:
    [exec] ======================================================================
    [exec]    The application has thrown an exception!
    [exec] ======================================================================
    [exec]  ZendServerWebApi\Model\Exception\ApiException
    [exec]  Invalid userAppName parameter: Application name 'application-7' already exists
    [exec] 2015-03-13T11:35:12+01:00 ERR (3): Invalid userAppName parameter: Application name 'application-7' already exists<zendServerAPIResponse xmlns="http://www.zend.com/server/api/1.9">
    [exec]     <requestData>
    [exec]         <apiKeyName><![CDATA[ZendStudio]]></apiKeyName>
    [exec]         <method>applicationDeploy</method>
    [exec]     </requestData>
    [exec] <errorData>
    [exec]  <errorCode>applicationConflict</errorCode>
    [exec]  <errorMessage><![CDATA[Invalid userAppName parameter: Application name 'application-7' already exists]]></errorMessage>
    [exec] </errorData></zendServerAPIResponse>

Чтобы решить эту проблему, мы удалили виртуальный хост и воссоздали его с той же конфигурацией, упомянутой ниже.

Есть ли другой способ решить проблему?


Дальнейшая информация

Версия Zend Server:

Версия 8.0.2, Developer Standard Edition, Профиль разработки

Версия ОС:

Ubuntu 14.04.1 LTS

Дженкинс версия:

1,599

Информация о Виртуальном хосте:

  • Тип: Zend-сервер определен
  • Создано в: 27 февраля 2015 8:18:23.
  • Корень документа: /usr/local/zend/var/apps/https/dev.application-7.de/443/1.0.0_177/public/
  • Безопасность: SSL включен
  • Путь к файлу сертификата /etc/apache2/ssl/dev.application-7.de.crt
  • Путь к файлу ключа /etc/apache2/ssl/dev.application-7.de.key
  • Путь к цепочке файлов /etc/apache2/ssl/dev.application-7.de.csr

Конфигурация Virtual-Hosts:

<VirtualHost *:443>
    SetEnv "APP_ENV" "dev"

    DocumentRoot "/usr/local/zend/var/apps/https/dev.application-7.de/443/1.0.0_177/public/"
    <Directory "/usr/local/zend/var/apps/https/dev.application-7.de/443/1.0.0_177/public/">
        Options +Indexes +FollowSymLinks
        DirectoryIndex index.php
        AllowOverride All
        Require all granted
    </Directory>

    SSLEngine on
    SSLCertificateFile "/etc/apache2/ssl/dev.application-7.de.crt"
    SSLCertificateKeyFile "/etc/apache2/ssl/dev.application-7.de.key"
    SSLCertificateChainFile "/etc/apache2/ssl/dev.application-7.de.csr"

    ServerName dev.application-7.de:443
    SetEnvIf Authorization "(.*)" HTTP_AUTHORIZATION=$1

    # include the folder containing the vhost aliases for zend server deployment
    IncludeOptional "/usr/local/zend/etc/sites.d/https/dev.application-7.de/443/*.conf"
</VirtualHost>

Файл сборки Ant:

<?xml version="1.0" encoding="UTF-8"?>
<project name="application-7-de-2" default="build">
    <!-- By default, we assume all tools to be on the $PATH -->
    <!-- <property name="toolsdir" value=""/> -->

    <!-- Uncomment the following when the tools are in ${basedir}/vendor/bin -->
    <!-- <property name="toolsdir" value="${basedir}/vendor/bin/"/> -->

    <!-- Uncomment the following when the tools are in a custom path -->
    <property name="baseuri" value="https://dev.application-7.de:443"/>
    <property name="appname" value="application-7-de"/>
    <property name="defaultserver" value="false"/>
    <property name="toolsdir" value="/usr/local/zend/bin/"/>
    <property name="params" value="APP_ENV=dev"/>

    <property name="host" value="http://our-zend-server.de:10081"/>
    <property name="key" value="ZendStudio"/>
    <property name="secret" value="OUR_SECRET"/>

    <target name="build" depends="prepare,composer,lint,phploc-ci,pdepend,phpmd-ci,phpcs-ci,phpcpd-ci,phpunit,phpdox,zpk,deploy" description=""/>
    <target name="build-parallel" depends="prepare,lint,tools-parallel,phpunit,phpdox" description=""/>
    <target name="tools-parallel" description="Run tools in parallel">
        <parallel threadCount="2">
            <sequential>
                <antcall target="pdepend"/>
                <antcall target="phpmd-ci"/>
            </sequential>
            <antcall target="phpcpd-ci"/>
            <antcall target="phpcs-ci"/>
            <antcall target="phploc-ci"/>
        </parallel>
    </target>
    <target name="clean" unless="clean.done" description="Cleanup build artifacts">
        <delete dir="${basedir}/build/api"/>
        <delete dir="${basedir}/build/coverage"/>
        <delete dir="${basedir}/build/logs"/>
        <delete dir="${basedir}/build/pdepend"/>
        <delete dir="${basedir}/build/phpdox"/>
        <property name="clean.done" value="true"/>
    </target>
    <target name="prepare" unless="prepare.done" depends="clean" description="Prepare for build">
        <mkdir dir="${basedir}/build/api"/>
        <mkdir dir="${basedir}/build/coverage"/>
        <mkdir dir="${basedir}/build/logs"/>
        <mkdir dir="${basedir}/build/pdepend"/>
        <mkdir dir="${basedir}/build/phpdox"/>
        <property name="prepare.done" value="true"/>
    </target>
    <target name="composer" depends="prepare" description="Update dependencies">
        <exec executable="${toolsdir}composer" failonerror="true">
            <arg value="update"/>
            <arg value="--working-dir"/>
            <arg path="${basedir}"/>
        </exec>
    </target>
    <target name="lint" description="Perform syntax check of sourcecode files">
        <apply executable="php" failonerror="true">
            <arg value="-l" />
            <fileset dir="${basedir}/module">
                <include name="**/*.php" />
                <modified />
            </fileset>
            <fileset dir="${basedir}/tests">
                <include name="**/*.php" />
                <modified />
            </fileset>
        </apply>
    </target>
    <target name="phploc" description="Measure project size using PHPLOC and print human readable output. Intended for usage on the command line.">
        <exec executable="${toolsdir}phploc">
            <arg value="--count-tests" />
            <arg path="${basedir}/module" />
            <arg path="${basedir}/tests" />
        </exec>
    </target>
    <target name="phploc-ci" depends="prepare" description="Measure project size using PHPLOC and log result in CSV and XML format. Intended for usage within a continuous integration environment.">
        <exec executable="${toolsdir}phploc">
            <arg value="--count-tests" />
            <arg value="--log-csv" />
            <arg path="${basedir}/build/logs/phploc.csv" />
            <arg value="--log-xml" />
            <arg path="${basedir}/build/logs/phploc.xml" />
            <arg path="${basedir}/module" />
            <arg path="${basedir}/tests" />
        </exec>
    </target>
    <target name="pdepend" depends="prepare" description="Calculate software metrics using PHP_Depend and log result in XML format. Intended for usage within a continuous integration environment.">
        <exec executable="${toolsdir}pdepend">
            <arg value="--jdepend-xml=${basedir}/build/logs/jdepend.xml" />
            <arg value="--jdepend-chart=${basedir}/build/pdepend/dependencies.svg" />
            <arg value="--overview-pyramid=${basedir}/build/pdepend/overview-pyramid.svg" />
            <arg path="${basedir}/module" />
        </exec>
    </target>
    <target name="phpmd" description="Perform project mess detection using PHPMD and print human readable output. Intended for usage on the command line before committing.">
        <exec executable="${toolsdir}phpmd">
            <arg path="${basedir}/module" />
            <arg value="text" />
            <arg path="${basedir}/build/phpmd.xml" />
        </exec>
    </target>
    <target name="phpmd-ci" depends="prepare" description="Perform project mess detection using PHPMD and log result in XML format. Intended for usage within a continuous integration environment.">
        <exec executable="${toolsdir}phpmd">
            <arg path="${basedir}/module" />
            <arg value="xml" />
            <arg path="${basedir}/build/phpmd.xml" />
            <arg value="--reportfile" />
            <arg path="${basedir}/build/logs/pmd.xml" />
        </exec>
    </target>
    <target name="phpcs" description="Find coding standard violations using PHP_CodeSniffer and print human readable output. Intended for usage on the command line before committing.">
        <exec executable="${toolsdir}phpcs">
            <arg value="--standard=PSR2" />
            <arg value="--extensions=php" />
            <arg value="--ignore=autoload.php" />
            <arg path="${basedir}/module" />
            <arg path="${basedir}/tests" />
        </exec>
    </target>
    <target name="phpcs-ci" depends="prepare" description="Find coding standard violations using PHP_CodeSniffer and log result in XML format. Intended for usage within a continuous integration environment.">
        <exec executable="${toolsdir}phpcs" output="/dev/null">
            <arg value="--report=checkstyle" />
            <arg value="--report-file=${basedir}/build/logs/checkstyle.xml" />
            <arg value="--standard=PSR2" />
            <arg value="--extensions=php" />
            <arg value="--ignore=autoload.php" />
            <arg path="${basedir}/module" />
        </exec>
    </target>
    <target name="phpcpd" description="Find duplicate code using PHPCPD and print human readable output. Intended for usage on the command line before committing.">
        <exec executable="${toolsdir}phpcpd">
            <arg path="${basedir}/module" />
        </exec>
    </target>
    <target name="phpcpd-ci" depends="prepare" description="Find duplicate code using PHPCPD and log result in XML format. Intended for usage within a continuous integration environment.">
        <exec executable="${toolsdir}phpcpd">
            <arg value="--log-pmd" />
            <arg path="${basedir}/build/logs/pmd-cpd.xml" />
            <arg path="${basedir}/module" />
        </exec>
    </target>
    <target name="phpunit" depends="prepare" description="Run unit tests with PHPUnit">
        <exec executable="${toolsdir}phpunit" failonerror="true">
            <arg value="--log-junit"/>
            <arg value="build/logs/junit.xml"/>
            <arg value="--configuration"/>
            <arg path="${basedir}/tests/phpunit.xml"/>
        </exec>
    </target>
    <target name="phpdox" depends="phploc-ci,phpcs-ci,phpmd-ci" description="Generate project documentation using phpDox">
        <exec executable="${toolsdir}phpdox" dir="${basedir}/build"/>
    </target>
    <target name="zpk" depends="phpdox">
        <exec executable="${toolsdir}zs-client" failonerror="true">
            <arg value="packZpk"/>
            <arg value="--folder=${basedir}"/>
            <arg value="--destination=${basedir}"/>
            <arg value="--name=application.zpk"/>
        </exec>
    </target>
    <target name="deploy" depends="zpk">
        <exec executable="${toolsdir}zs-client" failonerror="true">
            <arg value="installApp"/>
            <arg value="--baseUri=${baseuri}"/>
            <arg value="--userAppName=${appname}"/>
            <arg value="--defaultServer=${defaultserver}"/>
            <arg value="--userParams=${params}"/>
            <arg value="--zpk=${basedir}/application.zpk"/>
            <arg value="--zsurl=${host}"/>
            <arg value="--zskey=${key}"/>
            <arg value="--zssecret=${secret}"/>
        </exec>
    </target>
</project>

0 ответов

Другие вопросы по тегам