SpringBoot的Starter工作原理

Java3y

共 2495字,需浏览 5分钟

 · 2020-08-08


本文公众号来源:编程新说
作者:编程新说李新杰
本文已收录至我的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内容纯手打有任何不懂欢迎来问我。


原创电子书

原创思维导图


我是三歪,一个想要变强的男人,感谢大家的点赞收藏和转发,下期见。
浏览 17
点赞
评论
收藏
分享

手机扫一扫分享

举报
评论
图片
表情
推荐
点赞
评论
收藏
分享

手机扫一扫分享

举报