返回顶部
首页 > 资讯 > 后端开发 > Python >springboot项目突然启动缓慢的解决
  • 894
分享到

springboot项目突然启动缓慢的解决

2024-04-02 19:04:59 894人浏览 独家记忆

Python 官方文档:入门教程 => 点击学习

摘要

目录SpringBoot项目突然启动缓慢springboot启动太慢优化1.组件自动扫描带来的问题(@SpringBootApplication)2.如何避免组件自动扫描带来的问题(

springboot项目突然启动缓慢

springboot项目在debug模式下本来运行的挺快,后来某一天突然启动一半就卡在那一点一点龟速前进,还以为是我电脑问题,或者我写的代码问题,后来在网上搜了一下,结合自身项目情况,原来是断点问题,

有个断点无论如何都去不掉。可能是之前遗留的,后代码删除了,

也可能是因为这个地方的代码属于加载运行的什么节点,总之去不掉

后来根据网上的方法,在debug模式窗口下,选择Run菜单,点击Remove All Breakpoints的选项(好像也可以选择Skip All Breakpoing。)

然后所有断点都去掉了,重新启动,流畅!!!

springboot启动太慢优化

接下来我们一起探讨下每个问题。

1.组件自动扫描带来的问题(@SpringBootApplication)

我们在第一篇博客就介绍了,我们默认情况下,我们会使用@SpringBootApplication注解来自动获取应用的配置信息,但这样也会带来一些副作用。使用这个注解后,会触发自动配置(auto-configuration)和组件扫描(component scanning),这跟使用@Configuration、@EnableAutoConfiguration和@ComponentScan三个注解的作用是一样的。这样做给开发带来方便的同时,会有以下的一些影响:

(a)会导致项目启动时间变长(原因:加载了我们不需要使用的组件,浪费了cpu资源和内存资源)。当启动一个大的应用程序,或将做大量的集成测试启动应用程序时,影响会特别明显。

(b)会加载一些不需要的多余的实例(beans)。

(c)会增加CPU消耗和内存的占用。

2.如何避免组件自动扫描带来的问题(不使用@ SpringBootApplication)

本着有问题就要解决的心态,针对以上的问题,我们要怎么解决呢?很明显,既然@SpringBootApplication加载了一些不必要的配置,那么我们想是否可以就加载我们自己指定的配置呢?我们的思路不使用@SpringBootApplication,并且不使用@ComponentScan注解(此注解会自动扫描我们注解了@Controller,@Service的注解的类,加载到Spring ioc容器中),然后我们使用@Configuration和@EnableAutoConfiguration进行配置启动类,代码如下:


package com.kfit.spring_boot_perfORMance; 
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.EnableAutoConfiguration;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration; 
import com.kfit.spring_boot_performance.controller.HelloController;
 

//移除 @SpringBootApplication and @ComponentScan, 用 @EnableAutoConfiguration 来替代
@Configuration
@EnableAutoConfiguration
public class App {     
    public static void main(String[] args) {
       SpringApplication.run(App.class, args);
    }
}

3.引发的问题——无法扫描组件

我们正要为我们的代码改良庆幸的时候,我们发现问题来了。启动之后,访问我们编写的访问页面/index,

出现错误:There was an unexpected error (type=Not Found, status=404).

这是由于什么引起的呢?还记得我们刚刚介绍的@ComponentScan注解嘛,启用这个注解Spring才能够进行自动组件的扫描,否则无法扫描到我们编写的组件类。那么问题来了,怎么办呢?问题的解决就是:显式进行配置。

注入代码如下(假设我们写的类是HelloController,在这里博主直接写在App.java启动类进行注入):


   @Bean
    public HelloController helloController(){
        return new HelloController();
    }

在以上的代码中用 @Bean 注解明确显式配置,以便被 Spring 扫描到。

在重新启动之后,我们就可以正常访问/index页面了。

到这里肯定就会有人会说:那这样的话,不是会增加我们的编码量。我只能说:你既要加载快,又要不编码,博主实在不知道怎么办了。凡事有利有弊,自己权衡利弊。

4.千古红楼只一梦,竹篮打水一场空

有人不相信,这个真的能启动更快吗,于是乎就编码进行测试。哈哈,露馅了,还是一样启动的跟蜗牛一样慢。那为什么是这样呢?为什么我们研究了半天,最终却是:千古红楼只一梦,竹篮打水一场空。

聪明的读者,会注意到我们提到:@SpringBootApplication注解的作用跟@EnableAutoConfiguration注解的作用是相当的,那就意味着它也能带来上述的问题。要避免这些问题,我们就要知道我们的组件列表是哪些?

5.debug debug,bug bug更健康

我们在上面说了,我们的问题就是如何知道我们的组件列表是哪些?这时候debug就隆重登场了,鼓掌欢迎debug先生上场。

请问debug先生:在此时此刻您有什么获奖感言?

debug先生:经历了慢慢人生,我终于发现我的价值了。在这里我要感谢CCTV、感谢MTV、感谢可口可乐,感谢非常可乐、感谢加多宝、感谢王老吉、感谢主办方SpringBoot,让我有机会在这个舞台跟大家见面。谢谢你们,我一定不会让大家失望的。

好了,废话不多说了,我们先看看如何使用debug呢?

第一种情况:使用spring-boot:run启动方式

这种情况的话,完整的运行代码是:


spring-boot:run -Ddebug

第二种情况:使用Run As —— Java Application启动方式

这种情况的话,配置VM参数即可,具体操作如下:

【右键】——【Run As】——【Run Configurations…】——【选择Arguments】——【VM arguments】中加入:【-Ddebug】。

这时候在启动的时候,我们就能看到控制台打印出了一些我们平时没看到过的日志信息。

=========================
AUTO-CONFIGURATION REPORT
=========================
Positive matches:
-----------------

DispatcherServletAutoConfiguration matched
- @ConditionalOnClass found required class 'org.springframework.WEB.servlet.DispatcherServlet' (OnClassCondition)
- @ConditionalOnWebApplication (required) found StandardServletEnvironment (OnWebApplicationCondition)
//此处省略剩下的打印信息…

6.分析Positive matches和Negative matches

在打印信息里,我们有必要先了解下这里的一些知识:

(a) Positive match:累出匹配到对应类的配置项。

(b) Negative match:不包括某个配置项的原因。

现在以DataSourceAutoConfiguration举例说明:

(a)@ConditionalOnClass表示对应的类在classpath目录下存在时,才会去解析对应的配置文件,对于DataSourceAutoConfiguration来说就是指:只有javax.sql.DataSource和org.springframework.jdbc.datasource.embedded.EmbeddedDatabaseType类都存在时,就会配置对应的数据库资源。

(b)@ConditionalOnMissinGClass表示对应的类在classpath目录下找不到。

(c)OnClassCondition用于表示匹配的类型(postive or negative)。

OnClassCondition是最普遍的浏览探测条件,除此之外,Spring Boot也使用别的探测条件,如:OnBeanCondition用于检测指定bean实例存在与否、OnPropertyCondition用于检查指定属性是否存在等等。

符合negative match代表一些配置类(xxxConfiguration之类的),它们虽然存在于classpath目录,但是修饰它们的注解中依赖的其他类不存在。

7.再次优化配置信息

根据上面的理论知识,我们只需要在启动的时候,显式地引入这些组件,拷贝Positive matches中列出的信息:


DispatcherServletAutoConfiguration 
EmbeddedServletContainerAutoConfiguration 
ErrormvcAutoConfiguration 
HttpEncodingAutoConfiguration 
HttpMessageConvertersAutoConfiguration 
JacksonAutoConfiguration 
JmxAutoConfiguration 
MultipartAutoConfiguration 
ServerPropertiesAutoConfiguration 
PropertyPlaceholderAutoConfiguration 
ThymeleafAutoConfiguration 
WebMvcAutoConfiguration 
websocketAutoConfiguration

然后来更新项目配置,显式地引入这些组件,引入之后,再运行一下应用确保没有错误发生:


@Configuration
@Import({
        DispatcherServletAutoConfiguration.class,
        EmbeddedServletContainerAutoConfiguration.class,
        ErrorMvcAutoConfiguration.class,
        HttpEncodingAutoConfiguration.class,
        HttpMessageConvertersAutoConfiguration.class,
        JacksonAutoConfiguration.class,
        JmxAutoConfiguration.class,
        MultipartAutoConfiguration.class,
        ServerPropertiesAutoConfiguration.class,
        PropertyPlaceholderAutoConfiguration.class,
        ThymeleafAutoConfiguration.class,
        WebMvcAutoConfiguration.class,
        WebSocketAutoConfiguration.class,
})
public class App {

在上面的代码中,我们可以删掉我们不需要的组件信息,来挺高应用的性能,比如在项目中没有使用Jmx和WebSocket功能的话,那么我们就可以删除JmxAutoConfiguration.class和WebSocketAutoConfiguration.class。

删除掉之后,再次运行项目,确保一切正常。

8.小结一下

在本篇文章中我们介绍了如何加速spring boot快速启动,主要的思路就是废弃@SpringBootApplication显式的引入我们所需要的组件。

以上为个人经验,希望能给大家一个参考,也希望大家多多支持编程网。

--结束END--

本文标题: springboot项目突然启动缓慢的解决

本文链接: https://lsjlt.com/news/156414.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • springboot项目突然启动缓慢的解决
    目录springboot项目突然启动缓慢springboot启动太慢优化1.组件自动扫描带来的问题(@SpringBootApplication)2.如何避免组件自动扫描带来的问题(...
    99+
    2024-04-02
  • springboot项目突然启动缓慢的解决方法
    这篇文章将为大家详细讲解有关springboot项目突然启动缓慢的解决方法,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。springboot项目突然启动缓慢springboot项目在debu...
    99+
    2023-06-25
  • win10突然启动很慢如何解决
    如果Windows 10突然启动变得很慢,有几个可能的原因和解决方法:1. 清理磁盘空间:确保你的计算机有足够的磁盘空间。删除不需要...
    99+
    2023-08-31
    win10
  • springboot-启动bean冲突的解决
    目录启动bean冲突启动提示bean重复问题先说结论原理启动bean冲突 在一次启动中遇到了bean冲突的问题,提示存在两个名称重复的bean org.springframework...
    99+
    2024-04-02
  • springboot项目启动慢的问题排查方式
    目录springboot项目启动慢的问题排查1.最开始查看的启动日志,是在输出:2. 启动项目,打印日志级别改为debug,查看更详细信息如何优化SpringBoot的项目的启动速度...
    99+
    2024-04-02
  • springboot项目启动的时候参数无效的解决
    目录springboot项目启动的时候参数无效改动run方法的参数,添加args参数如下springboot项目启动参数设置问题Spring boot项目常用的几种启动方式war包部...
    99+
    2024-04-02
  • idea启动项目很久很慢的一种解决方案
    一、问题描述         IntelliJ idea 在启动项目时,很久很慢。 二、解决         在不买个更强更贵的前提下,有以下一种解决方案(ಥ_ಥ)          ​​​​​​​    1、方案依据         一般...
    99+
    2023-09-04
    intellij-idea java ide
  • vue-admin-element项目突然就起不来了的解决
    目录vue-admin-element项目突然就起不来解决方案如下一、将项目设置为私有二、将项目的仓库地址添上即可vue-admin-element项目突然就起不来 INFO &nb...
    99+
    2022-11-13
    vue-admin-element vue-admin-element项目 vue-admin-element起不来
  • win10突然蓝屏自动重启如何解决
    这篇文章主要讲解了“win10突然蓝屏自动重启如何解决”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“win10突然蓝屏自动重启如何解决”吧!为什么win10突然蓝屏自动重启的解决办法:方法一...
    99+
    2023-07-01
  • springBoot启动报错log4j冲突的解决方案
    springBoot启动报错log4j冲突 先上一段报错内容 SLF4J: Class path contains multiple SLF4J bindings. SLF4J: ...
    99+
    2024-04-02
  • SpringBoot 项目的创建与启动
    ✅作者简介:2022年博客新星 第八。热爱国学的Java后端开发者,修心和技术同步精进。 🍎个人主页:Java Fans的博客 🍊个人信条:不迁怒,不贰过。小知识...
    99+
    2023-09-05
    spring boot java spring
  • springBoot启动报错log4j冲突如何解决
    这篇文章主要讲解了“springBoot启动报错log4j冲突如何解决”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“springBoot启动报错log4j冲突如何解决”吧!springBoo...
    99+
    2023-06-20
  • 如何解决springboot-启动bean冲突问题
    小编给大家分享一下如何解决springboot-启动bean冲突问题,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!启动bean冲突在一次启动中遇到了bean冲突的问题,提示存在两个名称重复的beanorg.springfr...
    99+
    2023-06-29
  • 解决SpringBoot web项目启动后立即关闭的问题
    SpringBoot web项目启动后立即关闭 我们在写spring boot web项目时,有时会遇到启动后立即关闭的情况,或者是无法加载某些类,这是什么呢原因呢?  仔...
    99+
    2024-04-02
  • springboot启动feign项目报错:Service id not legal hostnam的解决
    目录springboot启动feign项目报错:Service id not legal hostnam在feign项目中,定义接口调用服务启动时报出异常信息度娘后发现问题所在配置文...
    99+
    2024-04-02
  • vue项目首次加载缓慢怎么解决
    本篇内容介绍了“vue项目首次加载缓慢怎么解决”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!首先我们可以安装webpack-bundle-a...
    99+
    2023-07-01
  • springboot程序启动慢-未配置hostname的解决
    目录springboot程序启动慢-未配置hostname具体日志如下通过jstack查看线程发现如下信息查看源码如下Spring Boot启动速度慢的原因总结前提条件原因一原因二原...
    99+
    2024-04-02
  • 使用bat启动springboot项目并解决乱码问题
    目录1.springboot项目打包jar2.编写bat启动springboot脚本3.bat启动springboot4.常见问题4.1.解决bat控制台中文乱码问题4.2.cd %...
    99+
    2024-04-02
  • springboot配置redis项目启动时错误怎么解决
    这篇“springboot配置redis项目启动时错误怎么解决”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“springbo...
    99+
    2023-06-29
  • spring-boot项目启动迟缓异常排查解决记录
    目录问题背景问题分析假设问题小心求证问题总结问题背景 一个spring boot开发的项目,spring boot版本是1.5.7,携带的spring版本是4.1.3。开发反馈,突然...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作