20年架构师用一文带你彻底搞懂SpringBoot嵌入式Web容器原理

总结

总的来说,面试是有套路的,一面基础,二面架构,三面个人。

最后,小编这里收集整理了一些资料,其中包括面试题(含答案)、书籍、视频等。希望也能帮助想进大厂的朋友

三面蚂蚁金服成功拿到offer后,他说他累了

三面蚂蚁金服成功拿到offer后,他说他累了

本文已被CODING开源项目:【一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码】收录

需要这份系统化的资料的朋友,可以点击这里获取

Spring Boot的目标是构建“非常容易创建、独立、产品级别的基于Spring的应用”。这些应用是“立即可运行的”。在这个过程中,完全没有代码生成,不需要配置任何特殊的XML配置,为了这个目标,Spring Boot在Spring 4.0框架之上提供了很多特性,帮助应用以“约定优于配置”“开箱即用”的方式来启动应用并运行上下文。

Spring Boot同样改变了一个传统的Web应用服务的启动流程和部署方式。通过自动配置机制,Spring Boot提供了一个嵌入式的运行时容器环境,并使用代码注解的方式在代码中将URL服务地址映射到Controller的方法完成服务映射。开发者不再需要关心传统容器(如Tomcat)中web.xml的配置,同时实现容器的具体技术都是可替换及可更改的,这些技术以插件化的Starter组件方式在运行时加载到Spring容器中。

20年架构师用一文带你彻底搞懂SpringBoot嵌入式Web容器原理

ContainerLess理念

微服务把应用和它所依赖的组件包、配置文件及附带的运行脚本打包成一个单一、独立、可执行的jar包文件。

在实现Web服务器时,几乎不需要任何配置就可以启动Tomcat。你只需要使用java-jar命令就可以让Tomcat成为Spring Boot的一个自包含的可运行组件和单元。同时,这种自带容器的运行部署方式对云开发环境天然友好。在Spring Boot启动流程和容器配置中,其实我们已经介绍了一点内嵌Tomcat容器的原理,下面具体看一下Spring Boot加载Tomcat的具体执行步骤。

1.Spring Boot引入Tomcat依赖

当我们在项目中加入org.springframework.boot、spring-bootstarter-web等依赖后,Maven会把Tomcat依赖的一些jar包组件也加载进来。

20年架构师用一文带你彻底搞懂SpringBoot嵌入式Web容器原理

2.创建Web容器的Context

在Spring Boot的run方法中,我们发现其中Web容器加载很重要的一步就是下面的代码:创建、加载、刷新、运行Spring容器的

ConfigurableApplicationContext模块。

20年架构师用一文带你彻底搞懂SpringBoot嵌入式Web容器原理

20年架构师用一文带你彻底搞懂SpringBoot嵌入式Web容器原理

在经历过Context的创建及Context的一系列初始化步骤之后,调用Context的refresh方法。

它最终会调用

AnnotationConfigEmbeddedWebApplicationContext 类 的 refresh 方法,并由其父类EmbeddedWebApplicationContext执行刷新,源码如下:

20年架构师用一文带你彻底搞懂SpringBoot嵌入式Web容器原理

3.创建Tomcat实例

这里我们继续跟进

createEmbeddedServletContainer方法,获得一个嵌入式的容器工厂类:EmbeddedServletContainerFactory。它是一个抽象工厂类,你可以根据不同的容器类型选择不同的容器加载实现。Spring Boot的默认容器是Tomcat,其工厂类实现了Tomcat实例的加载,代码如下:

20年架构师用一文带你彻底搞懂SpringBoot嵌入式Web容器原理

20年架构师用一文带你彻底搞懂SpringBoot嵌入式Web容器原理

在prepareContext方法中,可以将默认的JSP和Servlet Bean组件加载到Spring容器,并对所有ServletContextInitializer进行合并,然后利用合并后的初始化类对Context进行配置,代码如下:

总结:绘上一张Kakfa架构思维大纲脑图(xmind)

image

其实关于Kafka,能问的问题实在是太多了,扒了几天,最终筛选出44问:基础篇17问、进阶篇15问、高级篇12问,个个直戳痛点,不知道如果你不着急看答案,又能答出几个呢?

若是对Kafka的知识还回忆不起来,不妨先看我手绘的知识总结脑图(xmind不能上传,文章里用的是图片版)进行整体架构的梳理

梳理了知识,刷完了面试,如若你还想进一步的深入学习解读kafka以及源码,那么接下来的这份《手写“kafka”》将会是个不错的选择。

  • Kafka入门

  • 为什么选择Kafka

  • Kafka的安装、管理和配置

  • Kafka的集群

  • 第一个Kafka程序

  • Kafka的生产者

  • Kafka的消费者

  • 深入理解Kafka

  • 可靠的数据传递

  • Spring和Kafka的整合

  • SpringBoot和Kafka的整合

  • Kafka实战之削峰填谷

  • 数据管道和流式处理(了解即可)

image

image

本文已被CODING开源项目:【一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码】收录

需要这份系统化的资料的朋友,可以点击这里获取

一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码】](https://bbs.csdn.net/topics/618154847)收录**

需要这份系统化的资料的朋友,可以点击这里获取

  • 26
    点赞
  • 18
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值