【问题标题】:Tomcat Failed to start component using cargo mavenTomcat无法使用cargo maven启动组件
【发布时间】:2018-11-27 07:46:00
【问题描述】:

我正在尝试将war文件部署到tomcat,使用端口8080上的cargo maven插件(这是免费的,我检查了),我得到catalina.LifeCycleException: Failed to start component [Connector[AJP/1.3-auto-1]]

它还说输入的端口号无效,但在 server.xml 文件中端口指定为:<Connector port="8080" protocol="HTTP/1.1" connectionTimeout="20000" redirectPort="8443" />

我是否缺少其他配置?

货物配置:

<plugin>
            <groupId>org.codehaus.cargo</groupId>
            <artifactId>cargo-maven2-plugin</artifactId>
            <version>1.4.14</version>
            <configuration>
                <container>
                    <containerId>tomcat8x</containerId>
                    <type>installed</type>
                    <zipUrlInstaller>
                        <url>http://repo.release.cerner.corp/external/repo/org/apache/tomcat/apache-tomcat/${apache.tomcat.version}/apache-tomcat-${apache.tomcat.version}.tar.gz</url>
                    </zipUrlInstaller>
                    <dependencies>
                        <dependency>
                            <groupId>com.oracle</groupId>
                            <artifactId>ojdbc6</artifactId>
                        </dependency>
                    </dependencies>
                    <timeout>300000</timeout>
                </container>
                <configuration>
                    <configfiles>
                        <configfile>
                            <file>${project.basedir}/src/test/resources/context/context.xml</file>
                            <todir>conf</todir>
                        </configfile>
                    </configfiles>
                    <properties>
                        <cargo.servlet.port>${apache.tomcat.servletPort}</cargo.servlet.port>
                        <cargo.rmi.port>${apache.tomcat.rmiPort}</cargo.rmi.port>
                        <cargo.tomcat.ajp.port>${apache.tomcat.ajpPort}</cargo.tomcat.ajp.port>
                        <cargo.logging>low</cargo.logging>
                        <!--uncomment to enable debugging on the server-->
                        <!--<cargo.jvmargs> "-Xdebug" "-Xrunjdwp:transport=dt_socket,server=y,suspend=y,address=7998"-->
                        <!--</cargo.jvmargs>-->
                    </properties>
                </configuration>
                <deployables>
                    <deployable>
                        <groupId>${project.groupId}</groupId>
                        <artifactId>sample-war</artifactId>
                        <type>war</type>
                        <properties>
                            <context>sample-war</context>
                        </properties>
                    </deployable>
                </deployables>
            </configuration>
            <executions>
                <execution>
                    <id>start-container</id>
                    <goals>
                        <goal>start</goal>
                    </goals>
                    <phase>pre-integration-test</phase>
                </execution>
                <execution>
                    <id>stop-container</id>
                    <goals>
                        <goal>stop</goal>
                    </goals>
                    <phase>post-integration-test</phase>
                </execution>
            </executions>
        </plugin>
    </plugins>

【问题讨论】:

    标签: java tomcat tomcat8 cargo


    【解决方案1】:

    更改cargo configuration中的端口号:

    <configuration>
          <properties>
            <cargo.servlet.port>8080</cargo.servlet.port>
          </properties>
        </configuration>
    

    或者在命令行覆盖它

    mvn -Dcargo.servlet.port=8080 cargo:start
    

    【讨论】:

      【解决方案2】:

      在您的 HTTP 连接器旁边,您在 server.xml 中配置了一个 AJP 连接器元素,并指定了端口 -1

      <Connector
        port="-1"
        protocol="AJP/1.3"
        ...
      />
      

      如果您不需要 AJP,请将此连接器注释掉,方法是将其包装在 &lt;!-- --&gt; 注释元素中。否则,您需要更正端口设置才能使用 AJP。

      或者,您可能需要使用 cargo 属性指定 AJP:

      cargo.tomcat.ajp.port

      【讨论】:

      • 添加属性消除了错误,但是Tomcat还是没有启动,我的cargo属性是这样的:'${apache.tomcat.servletPort} ${apache.tomcat.rmiPort}${apache.tomcat.ajpPort}.tomcat.ajp.port> '
      • 通常错误Failed to start component [Connector[AJP/1.3-auto-1]] 不是致命的并且不会阻止Apache Tomcat 启动。这是您第一次提到您的 Tomcat 没有启动 btw。我想其中一个日志文件中肯定还有其他错误。
      猜你喜欢
      • 1970-01-01
      • 2011-04-19
      • 2016-12-16
      • 1970-01-01
      • 1970-01-01
      • 2013-06-03
      • 1970-01-01
      • 2015-06-14
      • 2011-04-17
      相关资源
      最近更新 更多