Spring的同一个服务会加载多次的问题分析及解决方法

 更新时间:2022年10月16日 08:56:46   作者:时钟在说话  
这篇文章主要介绍了Spring的同一个服务为什么会加载多次,我们先来梳理一下 Web 容器中如何加载 Bean,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下

问题现象

最近在本地调试公司的一个Web项目时,无意中发现日志中出现了两次同一个服务的init记录,项目都是基于Spring来搭建的,按理说服务都是单例的,应该只有一次服务加载日志才对,本着对工作认真负责(闲来无事)的态度,必然要一探究竟。

问题分析

为什么同一个 Bean 会被容器初始化两次?

首先,我们先来梳理一下 Web 容器中如何加载 Bean:

在 Web 容器中,ContextLoaderListenerDispatchServlet 都会在容器启动的时候加载
Bean,区别在于 DispatchServlet 一般会加载 MVC 相关的 Bean,ContextLoaderListener
会加载 Spring 相关的 Bean,二者会分别生成一个WebApplicationContext

根据 web.xml 的加载顺序,listener 会先于 Servlet 加载,当获取 Bean 时,会优先从
DispatchServlet 生成的 WebApplicationContext 中查找,如果找不到再从ContextLoaderListener 生成的 WebApplicationContext 中查找。

那么如果这两个加载了同样的Bean,到底该用谁的呢?

如果二者的配置文件中定义了相同的 Bean,则实际使用中只会用到 DispatchServlet 中的
Bean,ContextLoaderListener 中的 Bean 无法调用,造成内存泄漏。

接下来我们看一下项目中的 web.xml 配置,如下图所示,ContextLoaderListener
DispatchServlet加载了相同的配置 spring.xml,所以会出现两次 Bean 的初始化现象。

解决方案

经过上面的分析,我们知道了,之所以同一个Bean会被加载两次,是由于我们在DispatchServletContextLoaderListener都定义了这个Bean。

因此,我们要做的就是让ContextLoaderListenerDispatcherServlet分别加载不同的Bean:

新增applicationContext.xml,其中声明ContextLoaderListener要加载的Bean:

修改spring.xml中的包扫描范围,让DispatcherServlet只加载mvc相关的Bean:

启动服务,查看初始化信息,Service只被初始化了一次:

到此这篇关于Spring的同一个服务为什么会加载多次?的文章就介绍到这了,更多相关Spring的同一个服务为什么会加载多次?内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 改变JAVA窗体属性的操作方法

    改变JAVA窗体属性的操作方法

    在本篇内容里小编给大家详细分析了关于改变JAVA窗体属性的操作方法和步骤,需要的朋友们学习下。
    2018-12-12
  • Google Guava 缓存工具使用详解

    Google Guava 缓存工具使用详解

    这篇文章主要介绍了Guava自加载缓存LoadingCache使用指南,通过这些内容介绍,了解了LoadingCache的基本原理和用法,包括如何创建和配置缓存,以及如何结合Java 8的特性来优化代码,需要的朋友可以参考下
    2023-12-12
  • Java高效调试排查代码技巧详解

    Java高效调试排查代码技巧详解

    这篇文章主要介绍了Java高效调试排查代码技巧,调试是一项不可或缺的技能,无论你是经验丰富的开发者,还是初入编程世界的新手,都难免会遇到代码出错的情况,有效的调试能帮助我们快速定位并解决问题,提高开发效率,需要的朋友可以参考下
    2025-04-04
  • Java实现基本排序算法的示例代码

    Java实现基本排序算法的示例代码

    排序就是将一串记录按照其中某个或某些关键字的大小,递增或递减的排列起来的操作。本文将用Java实现一些基本的排序算法,感兴趣的可以了解一下
    2022-07-07
  • java读取其他服务接口返回的json数据示例代码

    java读取其他服务接口返回的json数据示例代码

    这篇文章主要给大家介绍了关于java读取其他服务接口返回的json数据的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧。
    2018-03-03
  • 深入理解Java设计模式之享元模式

    深入理解Java设计模式之享元模式

    这篇文章主要介绍了JAVA设计模式之享元模式的的相关资料,文中示例代码非常详细,供大家参考和学习,感兴趣的朋友可以了解下
    2021-11-11
  • Mybatis懒加载的实现

    Mybatis懒加载的实现

    这篇文章主要介绍了Mybatis懒加载的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-07-07
  • Java如何实现压缩文件与解压缩zip文件

    Java如何实现压缩文件与解压缩zip文件

    这篇文章主要介绍了Java如何实现压缩文件与解压缩zip文件问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-12-12
  • Java后端向前端返回文件流实现下载功能

    Java后端向前端返回文件流实现下载功能

    后端可以使用Java中servlet提供的HttpServletResponse,核心步骤是要设置响应的数据类型,设置为某一类文件类型或二进制格式,以及响应头,然后用ServletOutputStream将文件以流的形式发送到前端,本文介绍Java后端向前端返回文件流实现下载功能,感兴趣的朋友一起看看吧
    2023-12-12
  • Mybatis-Plus如何使用分页实例详解

    Mybatis-Plus如何使用分页实例详解

    最近在研究mybatis,然后就去找简化mybatis开发的工具,下面这篇文章主要给大家介绍了关于Mybatis-Plus如何使用分页的相关资料,文中通过实例代码介绍的非常详细,需要的朋友可以参考下
    2022-03-03

最新评论