Springboot 使用 Mybatis 启动失败排查定位
创始人
2024-03-25 07:46:59
0

收获

  1. 当遇到项目启动失败,却没有错误日志打印出来的时候,试试在 run 方法上加个 try-catch,即可捕获到异常

  2. Mybatis 的别名扫描路径不要指定的太宽泛,有可能会出现 Bean 名冲突,导致初始化失败

  3. 联想到之前碰到的问题,例如:

编辑切换为居中

添加图片注释,不超过 140 字(可选)

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

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

问题复现

  1. 引入依赖

编辑切换为居中

添加图片注释,不超过 140 字(可选)

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

编辑切换为居中

添加图片注释,不超过 140 字(可选)

  1. application.yml 配置

编辑切换为居中

添加图片注释,不超过 140 字(可选)

问题

  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,终于抓出来了异常:

编辑切换为居中

添加图片注释,不超过 140 字(可选)

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

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

                                      资源获取:

大家点赞、收藏、关注、评论啦 、查看👇🏻👇🏻👇🏻微信公众号获取联系方式👇🏻👇🏻👇🏻

 精彩专栏推荐订阅:下方专栏👇🏻👇🏻👇🏻👇🏻

每天学四小时:Java+Spring+JVM+分布式高并发,架构师指日可待

相关内容

热门资讯

AWSECS:访问外部网络时出... 如果您在AWS ECS中部署了应用程序,并且该应用程序需要访问外部网络,但是无法正常访问,可能是因为...
AWSElasticBeans... 在Dockerfile中手动配置nginx反向代理。例如,在Dockerfile中添加以下代码:FR...
AWR报告解读 WORKLOAD REPOSITORY PDB report (PDB snapshots) AW...
AWS管理控制台菜单和权限 要在AWS管理控制台中创建菜单和权限,您可以使用AWS Identity and Access Ma...
北信源内网安全管理卸载 北信源内网安全管理是一款网络安全管理软件,主要用于保护内网安全。在日常使用过程中,卸载该软件是一种常...
​ToDesk 远程工具安装及... 目录 前言 ToDesk 优势 ToDesk 下载安装 ToDesk 功能展示 文件传输 设备链接 ...
Azure构建流程(Power... 这可能是由于配置错误导致的问题。请检查构建流程任务中的“发布构建制品”步骤,确保正确配置了“Arti...
群晖外网访问终极解决方法:IP... 写在前面的话 受够了群晖的quickconnet的小水管了,急需一个新的解决方法&#x...
AWSECS:哪种网络模式具有... 使用AWS ECS中的awsvpc网络模式来获得最佳性能。awsvpc网络模式允许ECS任务直接在V...
不能访问光猫的的管理页面 光猫是现代家庭宽带网络的重要组成部分,它可以提供高速稳定的网络连接。但是,有时候我们会遇到不能访问光...