SpringBoot的Starter工作原理
本文公众号来源:编程新说 作者:编程新说李新杰 本文已收录至我的GitHub
生产资料,优先到位
生产资料就是用于正常生产工作所需要的一切东西。
从古代战争来讲,那就是“兵马未动,粮草先行”。所以粮草就是生产资料。
从我们码农来讲,正常开发所需要的都是生产资料,这里有一块很重要的资料,就是所有依赖的第三方jar包。
我们不需要重复造轮子,也不需要从零开始,所以直接拿来就用,拿来的其实就是jar包。
jar包只是一些基础代码,而且很多原本和Spring或SpringBoot没有关系,现在要和Spring或SpringBoot整合使用,就必须按Spring或SpringBoot的Style进行。
传统的和Spring整合的方式
还以MyBatis和Spring整合为例,因为每个Java开发人员对它都非常熟悉。
要完成这个整合,需要三个方面的jar包:
一是Spring的jar包。
二是MyBatis的jar包。
三是整合时使用的jar包。
这三方面的jar包都需要自己手动一一引入。
引入Spring的jar包:
引入MyBatis的jar包:
引入整合的jar包:
还有一个问题,就是当引入的jar包足够多时,jar包之间的版本号有时会有冲突,需要自己慢慢测试,颇为麻烦。
jar包导入之后,就该自己写代码进行Bean注册了,因为Spring的Style就是Bean注册。
主要包括四方面内容:
1、注册SqlSessionFactory这个Bean
2、指定mybatis的mybatis-config.xml配置文件路径
3、指定mybatis的mapper.xml映射文件的路径
4、指定源码包路径并扫描所有@Mapper注解接口
这里面有两个问题,不是十分友好:
1、jar包版本号问题,有时确实麻烦
2、注册Bean的代码几乎都一样,而且每次都要手动注册
SpringBoot帮你解决
对于jar包的版本号问题,SpringBoot帮你搞定,它经过测试,把常用的依赖及其适合的版本号都通过依赖管理的方式包含在pom文件中。
注意,这里只是依赖管理,并不是引入依赖。如需使用的话,还需要引入,只不过不用再指定版本号了。
对于注册Bean的问题,SpringBoot也帮你搞定,它把这些注册代码都已写好,然后通过各种“条件注解”来进行自动配置,所以最终会不会被注册,还要看运行时的“条件”。
这其实就是SpringBoot的自动配置了,具体可参考前两篇文章。
Starter就是一个启用入口
汽车造好之后,就只给我们留了一个一键启动的按键,踩着刹车按一下就启动了,至于按键背后做的事情,我们无需知道,只有这样才可以大范围推广。
同理,Starter也是这样一个东西,只要引入之后,并在application.yml文件中进行一些简单的配置或根本无须配置,直接启动后就可以用了。
Starter其实就是一个jar包,在pom中引入一个starter其实就是引入了一个jar包。
而且很多时候,这个starter对应的jar包是个空的,里面并没有任何类和接口。
那这个空的jar包有何意义呢?它的意义就在于为了引入有意义的其它jar包,因为这些jar包都是基于Maven的,因此jar包的pom文件中包含了其它依赖。
我们可以看到这个MyBatis的Starter就引入了正好需要的四类jar包:
1、Spring或SpringBoot相关的jar包
2、MyBatis的jar包
3、MyBatis和Spring整合的jar包
4、自动配置(也就是自动注册Bean)的jar包
这样一来,要完成MyBatis和Spring整合的所有jar包都凑齐了。而且自动注册Bean这些模板代码也已经有了。
这里面也就自动配置jar包稍微特殊一点,它里面包含一些带有“条件注解”的Bean注册。所以这些代码需要在SpringBoot中运行。
由于很多自动配置jar包都是第三方提供的,所以一定要告诉SpringBoot一声,让SpringBoot来执行它,这样才可以。
就像一键启动按钮一样,你至少要按一下吧,不能通过意念控制的。
下面是MyBatis的自动配置jar包:
这个jar包里包含了一个特殊约定的文件,就是spring.factories,它位于jar包里的META-INF目录下:
首先注释已经告诉我们了,这是自动配置。
具体内容是一个key/value类型的内容,key是固定的,就是SpringBoot自动配置的注解EnableAutoConfiguration的全名。
value就是第三方提供的自动配置类MybatisAutoConfiguration的全名。
这其实就是一个挂接,通过这种方式,第三方提供的自动配置就可以被SpringBoot执行了,然后Bean就会被注册了。
总结一下:
Starter使用Maven规则引入所有需要的依赖jar包,和自动配置jar包。
自动配置jar包使用spring.factories文件把自己挂接到SpringBoot以便被执行。
带来的简便:
原来所有的问题,现在都变为仅仅在pom中引入一个starter而已。
各类知识点总结
下面的文章都有对应的原创精美PDF,在持续更新中,可以来找我催更~
扫码或者微信搜Java3y 免费领取原创思维导图、精美PDF。在公众号回复「888」领取,PDF内容纯手打有任何不懂欢迎来问我。
原创电子书
原创思维导图
评论