springboot 项目运行时突现神秘错误
近期,一位开发人员在springboot项目运行过程中遭遇了一个困扰其许久的错误:
creating a new sqlSession sqlsession [org.apache.ibatis.session.defaults.defaultsqlsession@2dbe837b] was not registered for synchronization because synchronization is not active
登录后复制
令人诧异的是,项目代码并未做任何改动,以往运行良好。困惑不解的开发人员在网上苦苦搜寻答案,却发现这个错误并不是常见的代码错误。
进一步排查,开发人员检查了项目的yml配置文件,发现相关配置如下:
server: port: 8080 spring: datasource: druid: driver-class-name: com.mysql.cj.jdbc.driver url: jdbc:mysql://110.35.20.7:3306/cos?useunicode=true&characterencoding=utf8&autoreconnect=true&allowmultiqueries=true&zerodatetimebehavior=converttonull&usessl=false&servertimezone=asia/shanghAI username: mes_it password: 123456 mybatis-plus: config-location: classpath:mybatis/mybatis-config.xml mapper-locations: classpath:mybatis/mapper/*.xml
登录后复制
检查配置后,开发人员发现并没有明显的错误。正当他一筹莫展之际,一位经验丰富的程序员为他指点了一条明路:
解决办法:
前往 csdn 博客网址 https://blog.csdn.net/web1829…,查看一篇题为《sqlsession [org.apache.ibatis.session.defaults.defaultsqlsession@2dbe837b] was not registered for synchronization because synchronization is not active》的文章。
这篇文章详细分析了导致该错误的原因,并给出了相应的解决方案。按照文章中的指导,开发人员在项目中添加了以下代码:
@Configuration public class MyBatisConfig { @Bean @Scope("prototype") @Primary public SqlSessionFactory sqlSessionFactory(@Qualifier("dataSource") DataSource dataSource) { return new SqlSessionFactoryBean().getObject(); } }
登录后复制
添加代码后,开发人员重新启动项目,错误消失,项目恢复正常运行。
© 版权声明
文章版权归作者所有,未经允许请勿转载。
【小浪云服务商 - 服务器12元起 - 挂机宝5元起】
THE END
暂无评论内容