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+分布式高并发,架构师指日可待

相关内容

热门资讯

保存时出现了1个错误,导致这篇... 当保存文章时出现错误时,可以通过以下步骤解决问题:查看错误信息:查看错误提示信息可以帮助我们了解具体...
汇川伺服电机位置控制模式参数配... 1. 基本控制参数设置 1)设置位置控制模式   2)绝对值位置线性模...
不能访问光猫的的管理页面 光猫是现代家庭宽带网络的重要组成部分,它可以提供高速稳定的网络连接。但是,有时候我们会遇到不能访问光...
表格中数据未显示 当表格中的数据未显示时,可能是由于以下几个原因导致的:HTML代码问题:检查表格的HTML代码是否正...
本地主机上的图像未显示 问题描述:在本地主机上显示图像时,图像未能正常显示。解决方法:以下是一些可能的解决方法,具体取决于问...
表格列调整大小出现问题 问题描述:表格列调整大小出现问题,无法正常调整列宽。解决方法:检查表格的布局方式是否正确。确保表格使...
不一致的条件格式 要解决不一致的条件格式问题,可以按照以下步骤进行:确定条件格式的规则:首先,需要明确条件格式的规则是...
Android|无法访问或保存... 这个问题可能是由于权限设置不正确导致的。您需要在应用程序清单文件中添加以下代码来请求适当的权限:此外...
【NI Multisim 14...   目录 序言 一、工具栏 🍊1.“标准”工具栏 🍊 2.视图工具...
银河麒麟V10SP1高级服务器... 银河麒麟高级服务器操作系统简介: 银河麒麟高级服务器操作系统V10是针对企业级关键业务...