收获
- 当遇到项目启动失败,却没有错误日志打印出来的时候,试试在 run 方法上加个 try-catch,即可捕获到异常
- Mybatis 的别名扫描路径不要指定的太宽泛,有可能会出现 Bean 名冲突,导致初始化失败
- 联想到之前碰到的问题,例如:

第一个想到的应该是加一层 try-catch,自己把异常捕获出来。如果能看到异常,就离解决问题不远了
(补充闪电侠名言:如果能问题能复现,基本上就快解决了)
问题复现
- 引入依赖

- 创建 Mapper 类、mapper.xml、在启动类上加 @MapperScan 注解

- application.yml 配置

问题
- 编译通过,但这时项目启动出现了问题。启动日志中没有任何 Error 错误,每次启动到一半就显示 Tomcat 自动 stop。甚至在 @PostConstruct 方法里打断点都进不来。具体情况如图:由日志可见,每次执行到:
2021-08-25 16:33:47.110 INFO 95322 --- [ost-startStop-1] o.a.c.c.C.[Tomcat].[localhost].[/] : Initializing Spring embedded WebApplicationContext
这条日志之后,tomcat 就会自动停止:
2021-08-25 16:33:47.356 INFO 95322 --- [ main] o.apache.catalina.core.StandardService : Stopping service [Tomcat]
为此绞尽脑汁,Google 了大量帖子,有的帖子说是数据库没连上,有的帖子说是 spring-logging 的依赖冲突,等等,试了很多办法,都没有解决。
卡在这个问题上卡了一个多小时,突然看到一个帖子:
”在启动方法上套个 try-catch 就知道是什么异常了“
恍然大悟,在 run 方法上套了个 try-catch,终于抓出来了异常:

原来是,在 application.yml 里我指定 mybatis 的别名扫描路径下,有 Bean 名字冲突

缩小了指定的别名扫描路径之后,问题解决!
|