Maven Tomcat(嵌入式)

时间:2015-04-15 16:55:09

标签: maven tomcat

我试图通过tomcat maven插件将战争部署到嵌入式tomcat服务器。控制台显示服务器启动正常。

似乎没有部署战争。当我访问http://localhost:9090/foohttp://localhost:9090

时,我从Tomcat获得HTTP状态404

我在target / tomcat / webapps

中看不到war文件或爆炸的war文件

由于我无法控制的因素,我的配置有点(非常)非标准:

  • 该项目使用除Maven之外的其他方法来构建war文件。
  • 该项目未按Maven标准设置。
  • 项目的包装类型为POM。

POM:

<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/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>
    <groupId>com.foo</groupId>
    <artifactId>foo</artifactId>
    <version>0.0.1-SNAPSHOT</version>
    <packaging>pom</packaging>
    <name>iCON</name>
    <build>
        <plugins>
            <plugin>
                <groupId>org.apache.tomcat.maven</groupId>
                <artifactId>tomcat7-maven-plugin</artifactId>
                <version>2.2</version>
                <configuration>
                    <ignorePackaging>true</ignorePackaging>
                    <warFile>foo.war</warFile>
                    <port>9090</port>
                </configuration>
            </plugin>
        </plugins>
    </build>
</project>

输出mvn tomcat7:运行

[INFO] Scanning for projects...
[INFO]
[INFO] ------------------------------------------------------------------------
[INFO] Building foo 0.0.1-SNAPSHOT
[INFO] ------------------------------------------------------------------------
[INFO]
[INFO] >>> tomcat7-maven-plugin:2.2:run (default-cli) > process-classes @ foo >>>
[INFO]
[INFO] <<< tomcat7-maven-plugin:2.2:run (default-cli) < process-classes @ foo <<<
[INFO]
[INFO] --- tomcat7-maven-plugin:2.2:run (default-cli) @ foo ---
[INFO] Running war on http://localhost:9090/foo
[INFO] Creating Tomcat server configuration at C:\someDir\aProject\target\tomcat
[INFO] create webapp with contextPath: /foo
Apr 15, 2015 12:50:56 PM org.apache.coyote.AbstractProtocol init
INFO: Initializing ProtocolHandler ["http-bio-9090"]
Apr 15, 2015 12:50:56 PM org.apache.catalina.core.StandardService startInternal
INFO: Starting service Tomcat
Apr 15, 2015 12:50:56 PM org.apache.catalina.core.StandardEngine startInternal
INFO: Starting Servlet Engine: Apache Tomcat/7.0.47
Apr 15, 2015 12:50:58 PM org.apache.coyote.AbstractProtocol start
INFO: Starting ProtocolHandler ["http-bio-9090"]

1 个答案:

答案 0 :(得分:1)

我设法使用与几周前相同的插件在嵌入式tomcat上部署战争。

我的配置如下

<build>
<finalName>MSHAService</finalName>
<plugins>
  <plugin>
    <groupId>org.apache.tomcat.maven</groupId>
    <artifactId>tomcat7-maven-plugin</artifactId>
    <version>2.2</version>
    <configuration>
      <url>http://localhost:8080/manager/text</url>
      <server>localhost</server>
      <path>/MSHA</path>
      <username>user-acc-in-tomcat</username>
      <password>some-password</password>
    </configuration>
  </plugin>
</plugins>

您可能会错过配置中的一些参数。

此外,当您访问http://localhost:9090/foohttp://localhost:9090

时,您说您获得HTTP Status 404

您正在查看控制台日志,但查看访问日志可能会为您提供有关此内容的更多信息。 在此处查看有关tomcat日志的更多信息:https://tomcat.apache.org/tomcat-8.0-doc/logging.html