今天搭个环境写点小东西,结果一直卡在application.properties无法自动加载这里,网上找了很多办法,都没能有效解决,最后自己慢慢的分析了一下,发现了问题的所在,于是总结了下这类问题的分析和解决方案,在此分享出来。
0x01.问题
- 环境:SpringBoot 2.21RELEASE,Mybaties-Plus 3.0.5。
- 描述:启动一直报错。经检查url写法正确,且确实能用数据库工具连上。
0x02.分析过程
- 在启动类上配置禁止自动配置数据源:
@SpringBootApplication(exclude = {DataSourceAutoConfiguration.class})
- 启动,发现报错:8080端口冲突。
- 查看配置文件,发现端口明明进行了修改。说明application.properties文件根本没有进行加载。
- 查看编译后二点target目录,发现果然不存在application.properties文件。
- 为防止这些文件被过滤掉了,在pom文件的build标签下加入:
<resources>
<resource>
<directory>${basedir}/src/main/java</directory>
<includes>
<include>**/*.*</include>
</includes>
<filtering>false</filtering>
</resource>
<resource>
<directory>${basedir}/src/main/resources</directory>
<includes>
<include>**/*.*</include>
</includes>
<filtering>false</filtering>
</resource>
</resources>
- 这样理论上这些文件是不会被过滤了的。但是启动后查看target目录,里面依然没有application.properties。
- 那么SpringBoot启动过程中,肯定因为某些原因没有找到application.properties。启动入口处下断点,一步步跟进去(这里详细步骤过长,最好先了解下Springboot的启动流程),发现根本没有去找application.properties,经过和另一个项目对比,发现了问题的关键所在,我误把这个项目的打包方式写成pom包!!!
- 最后解决方案就是:将打包方式改为jar包。
pom:打出来可以作为其他项目的maven依赖,在工程A中添加工程B的pom,A就可以使用B中的类。用在父级工程或聚合工程中。用来做jar包的版本控制。
jar包:通常是开发时要引用通用类,打成jar包便于存放管理。当你使用某些功能时就需要这些jar包的支持,需要导入jar包。
war包:是做好一个web网站后,打成war包部署到服务器。目的是节省资源,提供效率。
0x03.此类问题通用解决方案
- 遇到SpringBoot无法加载application.properties,问题无非是三个:
1.application.properties书写有误(无法解析)
- 重新检查语法,空格,属性名等,最好复制到没有问题的项目中测试一下。
- 这种问题一般很好解决。
2.被拦截,过滤(无法找到)
- 这个方面就要进行多个方面的查错,包括IDE,项目环境,配置等。例如maven项目可加入上述代码确保配置文件没有被过滤。
- 最好能去debug一下springboot的启动。
3.打包方式不对(不去找)
- 注意这个工程是干嘛用的,如果是实际service,那么就要打成jar包。
遇错不要慌,先Google,找不到就自己Debug,Hhhh。