springboot打war包部署到tomcat后无法访问的解决方法

摘要

建立了一个springboot工程作为后端服务,由于springboot内嵌tomcat组件,所以在本地IDE进行开发时,直接run一个main方法就可以将这个服务跑起来,并提供外部API访问,何其简单方便快捷。

但是在本地爽快地完成开发调试后,将项目打包成war包并部署到线上tomcat,发现tomcat确实有解析到项目,但是却一直访问不了,报404错误,这是为什么呢?深陷其久,终发现原因!

问题复现

springboot项目打包成war后,将war包进行解压,得到下面两个目录:

META-INF
WEB-INF

在服务器上某个目录新建文件夹,例如:localservice,作为项目工程访问根路径目录,然后在tomcatserver.xml文件做项目地址虚拟目录映射,配置如下:

<Host name="wxservice.guangzhuiyuantest.cn" appBase="" unpackWARs="true" autoDeploy="true">	  
	<Alias>10.17.1.11</Alias>
	<Context path="/localservice" docBase="/home/site/guangzhuiyuan/app/localservice" reloadable="false">
			<Valve className="org.apache.catalina.valves.AccessLogValve" directory="/home/logs/localservice"
				prefix="10.17.1.11_access_log." suffix=".txt"
				pattern="%t &quot;%r&quot; %s %b %D %F" />
</Host>

这种方式部署项目跟直接把war包放在tomcatwebapps目录下是一样的,都能够将其部署在tomcat上。

然后启动tomcat,神奇的是,tomcat启动后,在work目录是build出该项目了的,证明tomcat已经解析到,但进行访问就是404:

image-20200628154955707

纠结了好久,之前一直以为是tomcatserver.xmlcontext节点配置错误,一直没往项目本身问题方面考虑,因为自己本地调试时都是正常启动且能够访问的。后来地觉得,如果直接把war放在tomcatwebapps目录下会不会就好了呢?结果果然还是太天真。

后来对比了一下以前的旧项目,才发现猫腻。

解决方法

两步走:

(1)如果你部署项目到tomcat后,tomcat启动失败,有可能是tomcat依赖冲突,移除掉就好;又或者成功,但在项目的pom.xmltomcat依赖的都主要这样处理:

<!-- 移除springboot中web模块的tomcat依赖 -->
<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-web</artifactId>
    <exclusions>
        <exclusion>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-tomcat</artifactId>
        </exclusion>
    </exclusions>
</dependency>

<!-- 这个依赖让你能够在程序入口类:xxxAppAplication中直接执行main方法启动tomcat -->
<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-tomcat</artifactId>
    <!-- 但是这里一定要设置为provided -->
    <scope>provided</scope>
</dependency>

(2)原本没有经过任何处理的(即创建springboot项目时自动生成的)入口类是这样的:

@SpringBootApplication()
public class LocalserviceApplication {

    public static void main(String[] args) {
        SpringApplication.run(LocalserviceApplication.class, args);
    }

}

但是这种方式是以jar包形式执行启动的,如果你要将项目打包成war包放在tomcat上执行,这个类得继承一下SpringBootServletInitializer,并重写configure方法,如下:

@SpringBootApplication()
public class LocalserviceApplication extends SpringBootServletInitializer {

    public static void main(String[] args) {
        SpringApplication.run(LocalserviceApplication.class, args);
    }

    // 按照下面的方式重写
    @Override
    protected SpringApplicationBuilder configure(SpringApplicationBuilder builder) {
        return builder.sources(LocalserviceApplication.class);
    }

}

然后再重新打包war包,操作跟之前一样,再访问,不出其他意外情况的话就能够正常访问了。


THE END

  • 4
    点赞
  • 17
    收藏
    觉得还不错? 一键收藏
  • 4
    评论
当我们将Spring Boot项目打成war部署Tomcat时,可能会遇到jar冲突的问题。下面是一般的解决方法: 1. 排查冲突的jar:可以使用命令`mvn dependency:tree`来查看项目依赖的所有jar,找到冲突的jar。 2. 排除冲突的jar:在pom.xml文件中,可以使用`<exclusions>`标签来排除冲突的jar。例如: ```xml <dependency> <groupId>com.example</groupId> <artifactId>example</artifactId> <version>1.0</version> <exclusions> <exclusion> <groupId>org.springframework</groupId> <artifactId>spring-core</artifactId> </exclusion> </exclusions> </dependency> ``` 3. 使用不同的版本:在pom.xml文件中,可以指定不同的版本来避免冲突。例如: ```xml <dependency> <groupId>org.springframework</groupId> <artifactId>spring-core</artifactId> <version>5.2.3.RELEASE</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-web</artifactId> <version>4.3.7.RELEASE</version> </dependency> ``` 4. 使用maven-shade-plugin插件:可以使用maven-shade-plugin插件来将所有的依赖打进一个可执行的jar中,避免冲突。例如: ```xml <build> <plugins> <plugin> <groupId>org.apache.maven.plugins</groupId> <artifactId>maven-shade-plugin</artifactId> <version>3.2.4</version> <configuration> <createDependencyReducedPom>false</createDependencyReducedPom> </configuration> <executions> <execution> <phase>package</phase> <goals> <goal>shade</goal> </goals> <configuration> <transformers> <transformer implementation="org.apache.maven.plugins.shade.resource.ManifestResourceTransformer"> <mainClass>com.example.Application</mainClass> </transformer> </transformers> </configuration> </execution> </executions> </plugin> </plugins> </build> ``` 这些方法中,最好的解决方法是使用maven-shade-plugin插件,因为它可以将所有的依赖打进一个可执行的jar中,避免冲突。
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值