【Spring面试】一、SpringBoot启动优化与最大连接数

这篇具有很好参考价值的文章主要介绍了【Spring面试】一、SpringBoot启动优化与最大连接数。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

Q1、SpringBoot可以同时处理多少请求

调试:

写一个测试接口:

@RestController
@Slf4j
public class RequestController{
	@GetMapping("/test")
	public String test(HttpServletRequest request) throws Exception{
		log.info("线程:{}",Thread.currentThread().getName());
		Thread.sleep(2000);  //睡两秒
		return "success";
	}
}

服务配置中的相关参数:

server:
  tomcat:
    threads:
      # 最少线程数
      min-spare: 10
      # 最多线程数
      max: 20
    # 最大连接数
    max-connections: 30
    # 最大等待数
    accept-count: 10

此时,JMeter模拟100QPS:

【Spring面试】一、SpringBoot启动优化与最大连接数,面试,spring,面试,spring boot

成功40个,刚好是(max-connections)+(accept-count),而这两个参数的默认值可以在Spring-boot-autoconfigure.jar的配置元数据的json文件spring-configuration-metadata.json中找到:(当然也可以直接在application.yaml中按住Ctrl去源码找)

【Spring面试】一、SpringBoot启动优化与最大连接数,面试,spring,面试,spring boot

答案:
max-connections默认值为8192,accept-count默认值100,因此默认情况下,可同时处理8192+100=8292

知识点补充:

1、关于spring-configuration-metadata.json文件

配置spring-configuration-metadata.json文件后,在IDEA中编写application.yaml等配置文件时,会有提示。

【Spring面试】一、SpringBoot启动优化与最大连接数,面试,spring,面试,spring boot

要做一个体验良好的Starter,这个文件还是非常重要的,对于使用你封装的开发者来说,写配置的时候就会方便很多。关于这个文件的生成,需要引入依赖:

<dependency>
  <groupId>org.springframework.boot</groupId>
  <artifactId>spring-boot-configuration-processor</artifactId>
  <optional>true</optional>
</dependency>

当再次编译的时候,​​spring-configuration-metadata.json​​文件就自动出现了。参考【spring-configuration-metadata.json】

2、关于各参数含义

【Spring面试】一、SpringBoot启动优化与最大连接数,面试,spring,面试,spring boot

首先把web服务器当作是一个饭店:

  • 最小工作线程数:这个饭店里正式员工的厨师
  • 最大工作线程数:当客人很多时,正式员工忙不过来,又来了兼职厨师(即最小线程数下,菜炒不完了)
  • 最大连接数:饭店里最多可容纳的客人数量
  • 最大队列数:店里坐不下了,去外面小板凳上坐下排队的人,即最多可以排队的人数。

按照上面调试代码里的配置,则:正式厨师10个,可招兼职的最多20个,店里能做30人,门口10个小板凳。某一会,来了100个客人,则只能先安排40个,另外60个不会光速走人,会先观望一下,即有自己的超时时间,等到了超时时间,还没轮到他进去吃,则走人,msg为connected timeout。(我上面代码中执行一次休眠2秒,而Jmeter中我设置的timeout时间为200ms,所以表现出来是60个人全部走人了)

【Spring面试】一、SpringBoot启动优化与最大连接数,面试,spring,面试,spring boot

Q2、SpringBoot如何优化启动速度

一般在SpringBoot项目启动中比较耗时的任务比如:数据库建立连接、初始线程池的创建等,可通过延迟这些操作的初始化来优化启动速度。

A1:开启bean的懒加载

SpringBoot 2.2版本引入spring.main.lazy-initialization属性,配置为true,开启懒加载,可将所有Bean延迟初始化。

spring:
  main:
    lazy-initialization: true

A2:创建扫描索引

Spring5之后提供了Spring-context-indexer功能,通过在编译时创建一个静态候选列表来提高大型应用程序的启动性能。首先引入依赖:

<dependency>
  <groupId>org.springframework</groupId>
  <artifactId>spring-context-indexer</artifactId>
  <optional>true</optional>
</dependency>

然后在启动类上加一个@Indexed注解,这样编译打包时会在项目中生成META-INF/spring.components文件。这个索引文件里,是提前将@ComponentScan需要扫描的bean全部建立好索引并排好顺序,然后项目启动时就根据这个文件来加载我们所有的Bean

A3:其余思路整理:

  • 减少@ComponentScan @SpringBootApplication扫描类时候的范围
  • 关闭 Spring Boot 的JMX监控,设置spring.jmx.enabled=false
  • 设置JVM参数-noverify ,不对类进行验证
  • 对非必要启动时加载的Bean,延迟加载
  • 使用SpringBoot的全局懒加载
  • AOPQ切面尽量不使用注解方式,这会导致启动时扫描全部方法
  • 关闭endpoint的一些监控功能
  • 排除项目多余的依赖
  • swagger扫描接口时,指定只扫描某个路径下的类
  • Feign客户端接口的扫描缩小包扫描范围

A4:还可尝试一些新特性:

  • JDK12后支持G1、JDK13后支持ZGC,可将未使用的内存及时归还给操作系统
  • SpringBoot3的新特性spring-graalvm-native,可将SpringBoot应用程序编译成本地可执行的镜像文件(显著优化!)

Q3、谈谈对Spring的理解

答案:

Spring是一个生态,可以构建java应用所需的一切基础设施,比如SpringCloud、SpringData、SpringSecurity…通常Spring指的就是Spring Framework。另外:

  • Spring是一个轻量级的开源容器框架
  • Spring是为了解决企业级应用开发的业务逻辑层和其他各层对象和对象直接的耦合问题
  • Spring是一个IOC和AOP的容器框架:IOC控制反转、面向切面编程AOP、包含并管理应用对象的生命周期的容器

Q4、Spring的优缺点

A1:方便解耦,简化开发

通过Spring提供的IoC容器,集中管理对象,使得对象和对象之间的耦合度降低,避免硬编码造成的程序过度耦合,方便维护对象。

A2:AOP的支持:

在不修改原代码的情况下,对业务代码进行增强,减少重复代码,方便维护。

A3:声明事务的支持:

使用@Transactional注解进行声明式的事务管理,不再关注烦闷的事务管理代码,提高开发效率。

A4:程序测试方便:

Spring对Junit4的支持,可以通过注解方便的测试Spring程序。

A5:方便集成各种优秀框架:

集成能力非常强,只需要做简单配置就可以集成第三方框架。(Spring底层源码提供了非常多的可扩展接口)

A6:降低了Java EE中API的使用难度

Spring对Java EE中很多步骤繁琐的API,如JDBC、JavaMail、远程调用等提供了封装

A7:学习的范例

Spring源码底层的实现,比如大量的反射、设计模式、扩展接口等值得学习。但上层使用越简单,下层封装和实现就越复杂,想阅读源码后做扩展也就不容易了。

Q5、Spring IoC容器是什么?作用与优点?

答案:

Ioc,Inversion of Controller,即控制反转。

UserService service = new UserService();

以上这种写法耦合度太高,后期发生修改时维护不方便,引入IoC容器即将创建对象的控制权交给Spring的IoC,在需要某对象的时候直接通过DI(依赖注入)@Autowired自动注入就可以使用对象。简言之,优点就是:

  • 集中管理对象,方便维护
  • 降低耦合度

【Spring面试】一、SpringBoot启动优化与最大连接数,面试,spring,面试,spring boot

Q6、Spring IoC的实现机制是什么

答案:

简言之是工厂+反射。以下以基于xml文件为例来说明:

【Spring面试】一、SpringBoot启动优化与最大连接数,面试,spring,面试,spring boot
核心代码:

//反射
return Class.forName("全类名").newInstance();

Spring提供了一个接口BeanFactory。这个接口是Spring实现IOC容器的顶级接口,这个接口是Spring内部使用的,并不是专门为框架的使用者提供的。

【Spring面试】一、SpringBoot启动优化与最大连接数,面试,spring,面试,spring boot

我们一般使用的是BeanFactory的子接口ApplicationContext接口,这个接口提供了更多并且更加强大的功能。在ApplicationContext接口中有三个常用的实现类分别是:AnnotationConfigApplicationContext、FileSystemXmlApplicationContext、ClassPathXmlApplicationContext。容器的创建需要读取配置文件或配置类,通过这些配置告诉Spring哪些bean是需要Spring来进行管理的

关于这三个类的使用注意点:

【Spring面试】一、SpringBoot启动优化与最大连接数,面试,spring,面试,spring boot

Q7、IoC和DI的区别是什么

答案:

IoC是一种设计的思想和理念,DI是实现IoC重要的一环。通过DI,IOC可以将依赖项注入到对象中。DI的实现方式主要有:

  • 构造方法注入: 被注入的对象可以通过在其构造方法中声明参数列表,让 IoC 容器知道它需要依赖哪些对象
  • setter 注入: 为其需要依赖的对象增加 setter 方法,可以通过 setter 方法将其依赖的对象注入到对象中
  • 接口注入:基本废弃

Q8、紧耦合与松耦合的区别,如何编写松耦合的代码

答案:

紧耦合即类和类之间高度依赖,如UserService中来UserMapper userMapper = new UserMapper()。编写松耦合代码可以通过以下几点:

  • 单一职责原则
  • 接口分离原则
  • 依赖倒置原则

早期电脑,很多配件集中在一起,坏掉一个组件,则整个电脑都得扔或者拆开来修。用单一职责原则,则是主机、显示屏、键盘、鼠标分开,如下图:(对比代码就是不要所有功能写一个类里,以及面向过程与面向对象)

【Spring面试】一、SpringBoot启动优化与最大连接数,面试,spring,面试,spring boot
仅靠单一职责,不能完全实现松耦合,如早期的鼠标接在主板上,此时连接处发生故障也不好修,因此再加入接口分离原则:

【Spring面试】一、SpringBoot启动优化与最大连接数,面试,spring,面试,spring boot
此时,鼠标故障,拔掉换一个就行,类比代码中,比如Dao层更换实现,或者Service调Dao的方法,Dao更改,不影响Service,但可插拔并不带表是可热插拔。不能鼠标一拔,电脑直接不能用了,那再加入依赖倒置原则DIP,而IoC则正好契合了这种原则。

【Spring面试】一、SpringBoot启动优化与最大连接数,面试,spring,面试,spring boot文章来源地址https://www.toymoban.com/news/detail-697771.html

到了这里,关于【Spring面试】一、SpringBoot启动优化与最大连接数的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • Spring Boot中内置Tomcat最大连接数、线程数与等待数 实践调优

    在 Spring Boot 框架中,我们使用最多的是Tomcat,这是 Spring Boot 默认的容器技术,而且是内嵌式的 Tomcat。Tomcat 是 Apache 基金下的一个轻量级的Servlet 容 器 , 支 持 Servlet 和 JSP 。Tomcat服务器本身具有Web服务器的功能,可以作为独立的Web服务器来使用。 Spring Boot 能支持的最大并发

    2024年02月12日
    浏览(30)
  • springboot 项目启动不打印spring 启动日志

    今天项目遇到一个很奇怪的问题,服务在启动时,不打印spring 的启动日志。经过排查发现是因为其他的依赖引入了 log4j 的依赖,因为我们的项目用的是logback,所以项目中没有log4j 的相关配置,所以干扰到了日志的打印 下面是log4j缺失配置文件的告警日志: log4j:WARN No append

    2024年02月11日
    浏览(41)
  • spring(15) SpringBoot启动过程

    最好的学习方式就是带着问题学习,在分析 SpringBoot 的启动过程前,先问大家 两个问题: 在启动过程中,SpringBoot 是在哪一步实例化 Bean 的? 答案: 在 SpringApplicatio 的 refresh() 方法刷新上下文的时候实例化的,对应本文的第 16 节。 ApplicationContext 作为一个 IOC 容器,底层是通

    2024年02月12日
    浏览(24)
  • 提升Spring Boot程序启动速度的七大优化技巧

    在开发Spring Boot应用程序时,快速的启动速度是至关重要的。一个快速启动的应用程序可以提高用户体验并提高系统的可用性。本文将介绍七个有效的优化技巧,帮助您提升Spring Boot程序的启动速度。 1、减少依赖项 :Spring Boot应用程序通常使用许多依赖项,但不一定每个依赖

    2024年02月16日
    浏览(23)
  • 面试官:说一说 Spring 与 SpringBoot 的区别?

    Spring 为开发 Java 应用程序提供了全面的基础架构支持,它将 Java 对象交由容器统一管理,从而实现控制反转(IOC)和依赖注入(DI),并提供了一些常用模块如 SpringAOP、SpringJDBC、SpringMVC 等等 SpringBoot 继承了 Spring 的核心思想,并进一步简化应用开发 Spring 和 SpringBoot 的区别主

    2024年03月25日
    浏览(31)
  • SpringBoot 底层机制分析【Tomcat 启动+Spring 容器初始化+Tomcat 如何关联Spring 容器】【下】

    😀前言 本篇博文是关于SpringBoot 底层机制分析实现,希望能够帮助你更好的了解SpringBoot 😊 🏠个人主页:晨犀主页 🧑个人简介:大家好,我是晨犀,希望我的文章可以帮助到大家,您的满意是我的动力😉😉 💕欢迎大家:这里是CSDN,我总结知识的地方,欢迎来到我的博客

    2024年02月13日
    浏览(32)
  • 面试题:Spring 与 Springboot 的区别以及优缺点

    Spring是一个开源的Java开发框架,旨在简化企业级Java应用程序的开发。它提供了一套完整的基础设施,包括依赖注入、面向切面编程、声明式事务管理等。 Spring Boot是一个用于创建独立的、生产级别的基于Spring的应用程序的框架。它将各种Spring组件和第三方库整合到一个能够

    2024年02月13日
    浏览(28)
  • SpringBoot面试题2:SpringBoot与SpringCloud 区别?SpringBoot和Spring、SpringMVC的区别

    该文章专注于面试,面试只要回答关键点即可,不需要对框架有非常深入的回答,如果你想应付面试,是足够了,抓住关键点 Spring Boot 和 Spring Cloud 是 Spring 生态系统中的两个关键组件,它们有以下区别: 定位:Spring Boot 用于简化 Spring 应用程序的开发和部署,提供了一种快

    2024年02月07日
    浏览(30)
  • 二十、微服务之-Spring Cloud使用、打包、启动与整合springboot

    根据 Spring Cloud 的官方网站,Spring Cloud 为开发人员提供了一些快速构建分布式系统常见模式的工具(例如 配置管理、服务发现、断路器、智能路由、领导选举、分布式会话、集群状态 )。 安装 IntelliJ IDEA:从 JetBrains 官方网站下载适用于您操作系统的 IntelliJ IDEA 版本,并按照

    2024年04月29日
    浏览(29)
  • Spring Native 实现 0.059s 启动一个SpringBoot项目!

    最近自己用Spring Cloud Alibaba做了一个微服务架构的项目,部署的时候遇到了难题:内存不够。目前该项目有7个微服务,因为我只有一台阿里云的服务器(2C 4G),所以我只能把所有的微服务部署在一台服务器上,部署方式是使用docker制作springboot的fat jar镜像,每个微服务在不加任

    2024年02月12日
    浏览(49)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包