【问题标题】:Deployed Spring-Boot war doesn't work in Tomcat部署的 Spring-Boot 战争在 Tomcat 中不起作用
【发布时间】:2019-10-27 17:57:04
【问题描述】:

我将使用 Java8 的 Spring-Boot 应用程序部署到 Tomcat 8.5 中,但是当我使用 CURL 发送一些请求时,我得到了 404 响应。我不知道我做错了什么。

我不是 Java 新手,但这是我第一次在服务器上设置环境来部署我的应用程序。我关注的博文:https://linuxize.com/post/how-to-install-tomcat-9-on-ubuntu-18-04/

唯一不同的是,我在 Ubuntu 16.04 上安装了 Tomcat 8.5,并没有设置管理器界面。

我的 Spring-Boot 入口点:

@SpringBootApplication
public class Application extends SpringBootServletInitializer {
    public static void main(String[] args) {
        SpringApplication.run(Application.class, args);
    }

    @Override
    protected SpringApplicationBuilder configure(SpringApplicationBuilder builder) {
        return builder.sources(Application.class);
    }
}

我的 pom.xml:

<packaging>war</packaging>

    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>2.0.2.RELEASE</version>
    </parent>

    <groupId>
        some.group.id
    </groupId>
    <artifactId>
        server
    </artifactId>
    <!--<version>-->
        <!--1.0-SNAPSHOT-->
    <!--</version>-->

    <properties>
        <commons-lang.version>3.6</commons-lang.version>
        <guava.version>25.0-jre</guava.version>
        <jwt.version>0.9.0</jwt.version>
        <joda-time.version>2.9.9</joda-time.version>
        <junit.version>4.12</junit.version>
        <mockito.version>2.17.0</mockito.version>
        <start-class>some.group.id.Application</start-class>
    </properties>

    <dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-security</artifactId>
        </dependency>
        <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
        </dependency>
        <dependency>
            <groupId>javax.servlet</groupId>
            <artifactId>javax.servlet-api</artifactId>
        </dependency>
        <dependency>
            <groupId>org.apache.commons</groupId>
            <artifactId>commons-lang3</artifactId>
            <version>${commons-lang.version}</version>
        </dependency>
        <dependency>
            <groupId>com.google.guava</groupId>
            <artifactId>guava</artifactId>
            <version>${guava.version}</version>
        </dependency>
        <dependency>
            <groupId>io.jsonwebtoken</groupId>
            <artifactId>jjwt</artifactId>
            <version>${jwt.version}</version>
        </dependency>
        <dependency>
            <groupId>joda-time</groupId>
            <artifactId>joda-time</artifactId>
            <version>${joda-time.version}</version>
        </dependency>

        <dependency>
            <groupId>junit</groupId>
            <artifactId>junit</artifactId>
            <version>${junit.version}</version>
            <scope>test</scope>
        </dependency>
        <dependency>
            <groupId>org.mockito</groupId>
            <artifactId>mockito-core</artifactId>
            <version>${mockito.version}</version>
            <scope>test</scope>
        </dependency>
        <dependency>
            <groupId>com.google.guava</groupId>
            <artifactId>guava-testlib</artifactId>
            <version>${guava.version}</version>
            <scope>test</scope>
        </dependency>
        <dependency>
            <groupId>com.h2database</groupId>
            <artifactId>h2</artifactId>
            <version>1.4.199</version>
            <scope>runtime</scope>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-data-jpa</artifactId>
            <version>2.1.4.RELEASE</version>
        </dependency>
        <dependency>
            <groupId>com.google.firebase</groupId>
            <artifactId>firebase-admin</artifactId>
            <version>6.8.1</version>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-tomcat</artifactId>
            <scope>provided</scope>
        </dependency>



    </dependencies>

    <build>
        <plugins>
            <plugin>
                <groupId>
                    org.springframework.boot
                </groupId>
                <artifactId>
                    spring-boot-maven-plugin
                </artifactId>
            </plugin>
        </plugins>
    </build>

我将 Tomcat 作为服务启动:

Description=Tomcat 8 servlet container
After=network.target

[Service]
Type=forking

User=tomcatuser
Group=tomcatuser

#Environment="JAVA_HOME=/usr/lib/jvm/default-java"
Environment="JAVA_OPTS=-Djava.security.egd=file:///dev/urandom -Djava.awt.headless=true"

Environment="CATALINA_BASE=/opt/tomcat/latest"
Environment="CATALINA_HOME=/opt/tomcat/latest"
Environment="CATALINA_PID=/opt/tomcat/latest/temp/tomcat.pid"
Environment="CATALINA_OPTS=-Xms512M -Xmx1024M -server -XX:+UseParallelGC"

ExecStart=/opt/tomcat/latest/bin/startup.sh
ExecStop=/opt/tomcat/latest/bin/shutdown.sh

[Install]
WantedBy=multi-user.target

JAVA_HOME 是在 /etc/environment 中设置的,所以它被注释掉了。

我将我的应用程序部署到 AWS,并且它工作正常。当我从 IntelliJ 在本地运行它时,它也可以工作。所以,我认为这与我的 Tomcat 设置有关。另外,我没有任何日志文件,例如 catalina.out。

【问题讨论】:

  • 404 表示 tomcat 已启动并正在运行,但它没有找到与您请求的 url 的任何映射。您可能正在请求http:localhost:8080/my-cool-url,但也许您正在my-app 上下文路由下运行您的spring 应用程序,所以在这种情况下您应该请求http:localhost:8080/my-app/my-cool-url。目前的信息很难判断。但我建议你尝试访问Tomcat提供的Web管理器,看看是否可以通过它访问应用程序。
  • “我没有任何日志文件,例如 catalina.out” 然后从修复它开始,这样您就可以看到任何错误消息,解释您的 webapp 可能存在的原因启动失败。
  • @lealceldeiro,我错了。这是“我的应用”部分。

标签: java spring-boot ubuntu-16.04 tomcat8


【解决方案1】:

@lealceldeiro 的回答帮助了我

错误是我请求的资源没有应用程序上下文路由的名称。我部署的战争名为“app.war”,因此,我请求的 URL 错误:

host-address:8080/resource-uri

正确的网址是:

host-address:8080/app/resource-uri

【讨论】:

  • 为什么需要在服务器上安装tomcat? Spring Boot 'spring-boot-starter-web' 有自己的(嵌入式 tomcat)。您只需要以“java -jar app.war”的形式运行您的应用程序
  • 很高兴我的评论对您有所帮助。请记住,即使it is one of your own posts,您也可以accept this post as correct
  • @lealceldeiro,是的,我知道。但我得到一个弹出窗口:你可以在 2 天内接受你自己的答案。所以我会等 2 天 :)
  • @ОлегГаврилів,我有点赶时间,所以没有研究。但是谢谢你的提示,我也会看看的。
猜你喜欢
  • 2015-10-28
  • 2017-04-15
  • 2019-03-21
  • 1970-01-01
  • 2019-03-23
  • 1970-01-01
  • 2018-03-23
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多