一、面试题
很多同学的简历都写着熟悉 SpringBoot, 而 Starter 的实现原理被当作的考题的的情况越来越多。
来源牛客网关于 starter 的一些面试题
情景一、路虎一面
情景二、蔚来
情景三、同花顺
Starter 频频出现,因此在面试准备时,这道题是必不可少的。
二、题目精简
- SpringBoot 自动装配原理介绍
- SpringBoot Starter 装配原理,或者 Starter 的流程
- 如何自定义一个 Starter
三、作答细节
3.1 作答技巧
- 金字塔答题法,从顶层到细节。先粗后细。能让面试官理解你的思路
- 作答有条理,由粗到细,让面试官不一头雾水,同时也是加分项
3.2 作答方式
第一步:Starter 的原理有几个要素:
- 自动装配原理
- importSelector 扩展机制
- spi 机制
- 条件装配 (不是必须,但非常具有灵活性)
tips: 从粗粒度抛出三个要素。 让对方能够明白你是懂的,明确做了提炼。
第二步:什么是自动装配、什么是 spi、什么是条件装配
什么是自动装配:
答:自动装配是相对于手动编写配置代码,减少这类代码的编写过程; 它是 SpringBoot 一套独特的机制,通过xxxAutoConfiguration注解等,并基于类路径、bean 等存在,能够将一系列 bean 注入到 Spring 应用中。实现约定大于配置。
什么是 importSelector 扩展机制(核心)
扩展机制是 Springframwork 中的核心接口。 SpringBoot#AutoConfigurationImportSelector 实现了这个类。 ConfigurationParser 中,会处理延迟的 importSelector。 在这一步,实现了将 Starter 配置在 spring.factories 中的全路径名,变成 ConfigurationClass。 从而实现 jar 的扩展加载。
什么是 spi:
答:在 springBoot 中自定义了一套 spi 机制,它依赖于 spring.factories 文件,通过在这里面能够将 xxxAutoConfiguration 引入,从而将此包下面所有相关类都注入到容器中。
什么是条件装配
答:基于条件来判断是否加载 bean。提供了丰富的注解,注入 ClassOnBean 等。通过条件装配提供了灵活性、扩展性。
知道三个问题后,再来说 Starter 的流程。
第三步:一个 Starter 被加载的流程是什么
- 首先:springBoot 启动后,会加载启动所有的后置处理器
- 其中最关键的后置处理器。 即解析 Configuration 的后置处理器。在这个后置处理器中会调用 ConfigurationParser,它是 spring framework core 中的核心类,解析 configuration 类,把 bean、import、autowired 等注解进行一一解析,然后把所有符合的bean都加载到spring容器中。 ConfigurationParser 是一个递归解析的过程。
- 在 ConfigurationParser 中会执行 import 等延迟资源类。
- 其中 AutoConfigurationImportSelector 等 importSelector 会被加载。 (@SpringBootApplication 引入)
- 在这个过程中,就会将 spring.facotoreis 中 的 xxxAutoConfiguration 类等进行加载。 (spi机制,被加载到 cache map 中,一种特殊的 map,能够通过全路径名反射加载)
- 只要能够扫描到这个 xxxAutoConfiguration 类,就能利用 ConfigurationParser 解析整个过程,将所有相关的 bean 进行加载。
抓住关键特性进行组织回答:
1. ConfigurationParserProcessor 后置处理器触发;
2. AutoConfigurationImportSelector 等导入。 importSelector 接口,是特殊的扩展机制接口。刚好 springBoot 扩展这个能力。
3. spring.facotoreis 筛选加载 xxxAutoConfiguration 类;
4. 通过 ConfigurationParser 解析。
围绕这几个核心要点进行回答。然后可以继续追加一些细节。
第四步:说一些使用经验
比如场景题目,可以结合一个案例,比如分布式锁等进行描述。谈一谈你的使用经验
第五步:扩展说一下使用经验
- 注意版本维护
- 注意 maven 管理
- 注意条件装配,留有足够的扩展
- auto-configuration,一般会控制相关 bean 的加载
四、技术之外
在面试环节,表达能力非常重要;对于大多数技术人来讲,能够把自己所知道的完美的呈现给面试官并不是一件轻松的事情。 表达能力需要我们刻意练习。输在表达上是一件非常不值得的事情。
五、最后
虽然学了这么多,流程也十分清楚,但是能够将自己知道的表达出来,还需自己总结,然后内化成自己的,不然还是会在面试的时候出现卡壳。这样就得不偿失了。
希望通过本教程,能够深入理解 SpringBoot Starter 的原理,能够总结回答好这个问题。最终拿下 offer。
掘金账号:第十一节 SpringBoot Starter 面试题 - 掘金 (juejin.cn)