SpringBoot的Starter工作原理介绍

2020/06/29 11:59
阅读数 6.8K

本文是应一位读者的要求而撰写。先告诉大家,这个原理很好理解。


生产资料,优先到位


生产资料就是用于正常生产工作所需要的一切东西。

从古代战争来讲,那就是“兵马未动,粮草先行”。所以粮草就是生产资料。

从我们码农来讲,正常开发所需要的都是生产资料,这里有一块很重要的资料,就是所有依赖的第三方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而已。



       
       
       
— 【 THE END 】—
本公众号全部博文已整理成一个目录,请在公众号里回复「 m 」获取!

卧槽,又来一个Windows神器!!!


震惊!ConcurrentHashMap里面也有死循环,作者留下的“彩蛋”了解一下?


985 大学老师的工资并没有很高,为什么大家都挤破头想进高校?


3T技术资源大放送!包括但不限于:Java、C/C++,Linux,Python,大数据,人工智能等等。在公众号内回复「1024」,即可免费获取!!




本文分享自微信公众号 - 程序员书单(CoderBooklist)。
如有侵权,请联系 support@oschina.cn 删除。
本文参与“OSC源创计划”,欢迎正在阅读的你也加入,一起分享。

展开阅读全文
打赏
1
1 收藏
分享
加载中
写的很棒,赞一个
06/04 04:47
回复
举报
更多评论
打赏
1 评论
1 收藏
1
分享
返回顶部
顶部