Spring Boot————BeanCreationNotAllowedException异常分析

引言

在对数据库进行新增记录的JUnit测试时,抛出一个BeanCreationNotAllowedException异常:

异常分析与解决

异常信息太长,图片截不下,粘贴来看:

Exception in thread "pool-2-thread-1" org.springframework.beans.factory.BeanCreationNotAllowedException: Error creating bean with name 'redisConnectionFactory': Singleton bean creation not allowed while singletons of this factory are in destruction (Do not request a bean from a BeanFactory in a destroy method implementation!) 

异常代码:

    @Testpublic void testAddOrUpdateUser() throws InterruptedException {JSONObject teacher = new JSONObject();teacher.put("role", "teacher");teacher.put("teacherName", "王力宏");teacher.put("jobTitle", "助理教授");teacher.put("gender", "男");teacher.put("username", "wanglihong");SystemResult addOrUpdateUser = userService.addOrUpdateUser(teacher);System.out.println(addOrUpdateUser);}

 测试方法的关键调用函数是:userService.addOrUpdateUser(teacher); 可是在这个方法内部完全没有用到redis的相关内容,而且奇怪的是:用debug模式运行方法的话完全可以成功

莫名其妙!

来看一下addOrUpdateUser方法:

    @Override@SuppressWarnings("rawtypes")public SystemResult addOrUpdateUser(Object user) {Boolean isTeacher = checkSvc.checkTeacherByRole(user);boolean isStudent = !isTeacher;String userStr = null;Class clazz = null;if (isTeacher) {// 添加教师Teacher teacher = JSONObject.toJavaObject(JSONObject.parseObject(JSONObject.toJSONString(user)),Teacher.class);DBProcessor.execute(() -> {tchrRep.save(teacher);});// ......} else if (isStudent) {// ......}logger.info("添加或更新<" + clazz.getSimpleName() + "> : " + userStr);String resultMessage = "添加或更新" + (isTeacher ? "教师" : "学生") + "成功!";return new SystemResult(SysContents.SUCCESS, resultMessage, clazz.getSimpleName().toLowerCase());}

我已经简化了部分代码,关键就是执行save方法的前后,可以看出此处的save方法,我为了充分利用并发性,采用了多线程的方式,将保存任务交给了一个ExecutorService——DBProcessor去执行。

交给一个新的线程去执行就是问题所在!

其实,细致分析一下就可以发现,我们采用debug的方式,或者将任务不交给线程去执行,而是串行直接执行任务,就不会有问题,原因就是,分配新的线程执行任务需要一定的性能和时间开销,因此会稍微比JUnit测试方法延迟一些。这样当JUnit方法执行完成立刻退出之后,整个系统环境也就直接退出关闭,没有给新的线程足够的时间去执行任务,因此才会导致插入失败。

顺着这个思路,我在JUnit方法执行到addOrUpdateUser之后sleep 1秒钟,果然顺利通过测试。

至于异常所描述的创建bean失败,我想就是因为JUnit测试结束之后过早退出系统环境的原因。

另外,这个问题网上的出错原因也并不一致,还要根据自己的问题具体分析。

如有疑问,欢迎留言。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/558818.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

一篇博客读懂设计模式之---委派模式

一篇博客读懂设计模式之—委派模式 委派模式可能大家听起来不太熟悉&#xff0c;但是在代码开发的时候却很好用&#xff0c;下面从几个方面来介绍一下 what&#xff1a;是什么&#xff1f; 委派模式&#xff1a;顾名思义&#xff0c;委托其他对象或者实例来帮我们完成任务&am…

XML模板解析————Dom4j解析xml案例分析

引言 目前项目中包含大量的xml模板文件&#xff0c;现就xml模板的数据解析、提取、及部分常用方法做简单的应用和总结。 一、XML文件转为Document对象 通过SAXReader对象的read方法&#xff0c;读取Document对象。 SAXReader reader new SAXReader(); Document document …

教你如何一篇博客读懂设计模式之—--工厂模式

一篇博客读懂设计模式之—工厂模式 工厂模式在我们日常开发的时候经常用到&#xff0c;相信大家都有了一定的了解&#xff0c;工厂模式是一种创建对象的设计模式&#xff0c;它提供一种创建对象的最佳方式。 主要过程是&#xff1a; 定义一个创建对象的接口&#xff0c;让其子…

Jackson快速入门

引言 上一篇博客《XML模板解析————Dom4j解析xml案例分析》简单讲解了关于xml模板的解析&#xff0c;使用到了dom4j&#xff0c;这篇文章其实算是个姊妹篇&#xff0c;都是对于目前工作中的一些任务&#xff0c;如xml、json相互解析所涉及到的知识。 但是相对于xml而言&am…

一篇文章读懂MySQL的各种联合查询

一篇文章读懂MySQL的各种联合查询 联合查询是指将两个或两个以上的表的数据根据一定的条件合并在一起! 联合查询主要有以下几种方式&#xff1a; 全连接&#xff1a;将一张表的数据与另外一张表的数据彼此交叉联合查询出来 举例如下&#xff1a; 先建两张表&#xff1a; CR…

Class.forName()、Class.class、getClass() 区别

问&#xff1a;简单谈谈你对 Java 中 Class.forName()、Class.class、getClass() 三者的理解&#xff1f; Class.class 的形式会使 JVM 将使用类装载器将类装入内存&#xff08;前提是类还没有装入内存&#xff09;&#xff0c;不做类的初始化工作&#xff0c;返回 Class 对象…

教你如何一篇博客读懂设计模式之—--原型模式

教你如何一篇博客读懂设计模式之----原型模式 what&#xff1a;是什么 原型模式&#xff1a; 用于创建重复的对象&#xff0c;既不用一个属性一个属性去set和get&#xff0c;又不影响性能&#xff0c;原型模式产生的对象和原有的对象不是同一个实例&#xff0c;他们的地址也…

Java反射————Method根据方法名称字符串调用方法

引言 之前浏览廖雪峰老师的个人博客网站&#xff0c;无意间发现了关于在Java8中获取参数的方法&#xff0c;随手一转《Java 8中获取参数名称》&#xff0c;没想到今天遇到一个功能&#xff0c;非常符合这种反射调用的使用场景。回看了这篇之前转载的文章&#xff0c;然后根据自…

一篇文章看懂@Scheduled定时器/@Async/CompletableFuture

一篇文章看懂Scheduled定时器/Async/CompletableFuture Scheduled注解解析&#xff1a; 1.cron&#xff1a;最重要的一个参数 cron表达式[秒] [分] [小时] [日] [月] [周] [年]&#xff08;[年]可省略&#xff09; 简单了解一下&#xff0c;网上有现成的工具 示例&#xff…

一篇搞懂HTTP协议

本文转自 &#xff1a;flyhero 码上实战《一个HTTP打趴80%面试者》 HTTP协议简介 HTTP&#xff08;超文本传输协议&#xff09;是应用层上的一种客户端/服务端模型的通信协议,它由请求和响应构成&#xff0c;且是无状态的。&#xff08;暂不介绍HTTP2&#xff09; 协议&…

注册gmail邮件,遇到“此电话号码无法用于进行验证”该怎么办

注册gmail邮件&#xff0c;遇到“此电话号码无法用于进行验证”该怎么办&#xff1f; 跟浏览器语言的设置有关&#xff0c;将语言改为英文即可&#xff0c;亲测有效&#xff01;

Jackson高级操作————节点树

引言 继《Jackson快速入门》基础篇之后的树模型相关操作。 节点树模型 ObjectMapper构建JsonNode节点树&#xff0c;类似于DOM解析器的XML。 Testpublic void testJsonTree() throws JsonProcessingException, IOException {String jsonString "{\"name\":\…

spring源码分析第一天------源码分析知识储备

spring源码分析第一天------源码分析知识储备 Spring源码分析怎么学? 1、环境准备&#xff1b; 2、思路 看&#xff1a;是什么&#xff1f; 能干啥 想&#xff1a;为什么&#xff1f; 实践&#xff1a;怎么做&#xff1f; 调试的时候&#xff0c;完全可以在…

Jackson高级操作————流式API与JsonGenerator、JsonParser

引言 继《Jackson快速入门》之后的高级相关操作。 Jackson提供了一种对于性能要求应用程序操作json更加高效的方式——流式API&#xff0c;这种方式开销小&#xff0c;性能高&#xff0c;因此&#xff0c;如果应用程序或者程序逻辑对于性能有一定要求&#xff0c;可以使用这种…

Mysql高级教程思维导图

Mysql高级教程思维导图 1、思维导图总览&#xff1a; 2、MySQL架构介绍&#xff1a; 2.1、MySQL简介 2.2、MySQL Linux版安装 2.3、MySQL配置文件 2.4、MySQL逻辑架构介绍 2.5、MySQL存储引擎 2.6、MySQL的用户和权限管理 2.7、MySQL一些杂项配置 ’ 3、索引优化分析 3.1、性…

Eclipse(STS 4)闪退导致EGit插件异常

引言 到目前为止&#xff0c;STS已经闪退过三次了。 问题很棘手&#xff0c;我需要冷静。 首先出现了一个问题就是&#xff0c;EGit无法commit。 第二个问题是切换分支报错。 闪退重启后EGit无法提交代码 观察闪退出现的时机&#xff0c;一般出现在我 commit 代码的时候&…

spring源码分析第二天------spring系统概述以及IOC实现原理

1、Spring5 概述 Spring 是一个开源的轻量级 Java SE&#xff08;Java 标准版本&#xff09;/Java EE&#xff08;Java 企业版本&#xff09;开发应用框架&#xff0c; 其目的是用于简化企业级应用程序开发。 Spring 框架除了帮我们管理对象及其依赖关系&#xff0c;还提供像通…

Linux进阶之路————Linux概述

引言 Linux是一个开源、免费的操作系统。学习Linux知识分为以下几个阶段&#xff1a; 第一阶段&#xff1a;Linux环境下的基本操作命令&#xff0c;包括文件操作命令&#xff08;rm、mkdir、chmod、chown&#xff09;编辑工具使用&#xff08;vi、vim&#xff09;Linux用户管…

spring源码分析第三天------spring核心IOC容器和依赖注入原理

基于XML的依赖注入 1、依赖注入发生的时间 当 Spring IOC 容器完成了 Bean 定义资源的定位、载入和解析注册以后&#xff0c;IOC 容器中已经管理类 Bean 定义的相关数据&#xff0c;但是此时 IOC 容器还没有对所管理的 Bean 进行依赖注入&#xff0c;依赖注入在以下两种情况 …

Linux进阶之路————远程登录与vim编辑器

远程登录 远程的Linux系统中&#xff0c;如果希望通过ssh协议登录&#xff0c;那么在Linux需要有一个sshd服务监听22端口&#xff0c;也就是说要想通过ssh登录远程linux&#xff0c;那么linux必须安装sshd服务&#xff0c;并开启。这是一个远程登录成功的前提。 vi、vim编辑器…