Springboot 使用 Mybatis 启动失败排查定位

1496 篇文章 10 订阅
1494 篇文章 14 订阅

收获

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

第一个想到的应该是加一层 try-catch,自己把异常捕获出来。如果能看到异常,就离解决问题不远了

(补充闪电侠名言:如果能问题能复现,基本上就快解决了)

问题复现

  1. 引入依赖

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

  1. application.yml 配置

问题

  1. 编译通过,但这时项目启动出现了问题。启动日志中没有任何 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 名字冲突

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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值