多模块maven项目部署到tomcat部署失败,filter不生效(已解决)
一、问题描述
多模块maven项目idea运行的时候,没有什么问题,但是部署到生产环境的tomcat时(条件限制只能古板部署),启动失败,模块功能没有提供,但没什么报错(被另一个子模块的启动日志蒙蔽了)。
二、问题分析
经过详细检查,找到了问题日志。启动时,竟然先启动了子模块,导致主模块启动失败(maven root和端口都有冲突),但是这个BaseApplication是已经在启动项里面处理过的,如下
@SpringBootApplication
@Slf4j
@ComponentScan(
excludeFilters = {@ComponentScan.Filter(type = FilterType.ASSIGNABLE_TYPE, classes = {BaseApplication.class})},
basePackages = {"xxx"}
)
@MapperScan(
basePackages = {"xxx"}
)
public class DzapiApplication extends SpringBootServletInitializer {
@ComponentScan.Filter 已经把BaseApplication过滤了,但是没生效,因为本地启动没问题,一定是部署的问题。所以在tomcat的拦截器和过滤器上找原因,当然,检查了大部分配置没找到问题。所以切换方向,开始百度。
三、解决办法(重点)
1.第一种就是在不找到原因的基础下,直接解决(推荐)
他启动了BaseApplication,而实际上子模块本来就不需要启动项,所以直接注释掉整个BaseApplication,然后把过滤的代码也注释掉
@ComponentScan(
// excludeFilters = {@ComponentScan.Filter(type = FilterType.ASSIGNABLE_TYPE, classes = {BaseApplication.class})},
basePackages = {"xxx"}
)
再去打包war包并启动。就正常了
2.第二种就是在部署上面,找到答案(有时候生产环境tomcat不能乱动)
在tomact的conf文件夹下,编辑server.xml。
server.xml有个标签叫Host,有个属性是appBase,需要把这个改成具体的地址,即可生效。
实际上我本来就是webapp目录,不应该有这个问题。
原来:
改成:
之后,再去启动,Surprise!就可以看到启动的是主模块的启动项了
我可以找不到根本原因,但我从不放弃去寻找的决定。 --鲁树人