首页 文章详情

SpringBoot的Starter工作原理介绍

程序员书单 | 5786 2020-06-29 23:50 0 0 0
UniSMS (合一短信)


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


生产资料,优先到位


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

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

从我们码农来讲,正常开发所需要的都是生产资料,这里有一块很重要的资料,就是所有依赖的第三方jar包。

我们不需要重复造轮子,也不需要从零开始,所以直接拿来就用,拿来的其实就是jar包。

jar包只是一些基础代码,而且很多原本和Spring或SpringBoot没有关系,现在要和Spring或SpringBoot整合使用,就必须按Spring或SpringBoot的Style进行。


传统的和Spring整合的方式


还以MyBatis和Spring整合为例,因为每个Java开发人员对它都非常熟悉。

要完成这个整合,需要三个方面的jar包:

一是Spring的jar包。

二是MyBatis的jar包。

三是整合时使用的jar包。

这三方面的jar包都需要自己手动一一引入。

引入Spring的jar包:

89109005a0d83b2591155d28e761f21d.webp


引入MyBatis的jar包:

e2799fa7b0ac4e8b2586c19dfacd4d3b.webp


引入整合的jar包:

d7507ddea9ff93839269b1133036c3fb.webp


还有一个问题,就是当引入的jar包足够多时,jar包之间的版本号有时会有冲突,需要自己慢慢测试,颇为麻烦。

jar包导入之后,就该自己写代码进行Bean注册了,因为Spring的Style就是Bean注册。

712f4271476acd06d85e55b2339e9f67.webp


主要包括四方面内容:

1、注册SqlSessionFactory这个Bean

2、指定mybatis的mybatis-config.xml配置文件路径

3、指定mybatis的mapper.xml映射文件的路径

4、指定源码包路径并扫描所有@Mapper注解接口

这里面有两个问题,不是十分友好:

1、jar包版本号问题,有时确实麻烦

2、注册Bean的代码几乎都一样,而且每次都要手动注册


SpringBoot帮你解决


对于jar包的版本号问题,SpringBoot帮你搞定,它经过测试,把常用的依赖及其适合的版本号都通过依赖管理的方式包含在pom文件中。

5579261f4321d8fd370bf4402a7594f6.webp


da2732cd13caede7dcefcb7b7af5a32e.webp


注意,这里只是依赖管理,并不是引入依赖。如需使用的话,还需要引入,只不过不用再指定版本号了。

对于注册Bean的问题,SpringBoot也帮你搞定,它把这些注册代码都已写好,然后通过各种“条件注解”来进行自动配置,所以最终会不会被注册,还要看运行时的“条件”。

这其实就是SpringBoot的自动配置了,具体可参考前两篇文章。


Starter就是一个启用入口


汽车造好之后,就只给我们留了一个一键启动的按键,踩着刹车按一下就启动了,至于按键背后做的事情,我们无需知道,只有这样才可以大范围推广。

同理,Starter也是这样一个东西,只要引入之后,并在application.yml文件中进行一些简单的配置或根本无须配置,直接启动后就可以用了。

Starter其实就是一个jar包,在pom中引入一个starter其实就是引入了一个jar包。

而且很多时候,这个starter对应的jar包是个空的,里面并没有任何类和接口。

0c80e6719e1755354b3ae6f3eeeea020.webp


那这个空的jar包有何意义呢?它的意义就在于为了引入有意义的其它jar包,因为这些jar包都是基于Maven的,因此jar包的pom文件中包含了其它依赖。

bd2c5b00e5ffbb5cff1ef3d6c5f67d4e.webp


3ee20ea43be363537b39b3b63b734adc.webp


我们可以看到这个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包:

c957fede6179792e8315d6bcc838e9c3.webp


这个jar包里包含了一个特殊约定的文件,就是spring.factories,它位于jar包里的META-INF目录下:

7044d6d1ad319624c7c03293ec2b095a.webp

这个文件的内容如下:

2894725cb824b37b8f2e8b6d9beb6841.webp


首先注释已经告诉我们了,这是自动配置。

具体内容是一个key/value类型的内容,key是固定的,就是SpringBoot自动配置的注解EnableAutoConfiguration的全名。

value就是第三方提供的自动配置类MybatisAutoConfiguration的全名。

这其实就是一个挂接,通过这种方式,第三方提供的自动配置就可以被SpringBoot执行了,然后Bean就会被注册了。

总结一下:

Starter使用Maven规则引入所有需要的依赖jar包,和自动配置jar包。

自动配置jar包使用spring.factories文件把自己挂接到SpringBoot以便被执行。

带来的简便:

原来所有的问题,现在都变为仅仅在pom中引入一个starter而已。


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

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


274c97bc4206b2620962b176a4cc58ca.webp

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


26472e6660e6951dc7936cf3ce509354.webp

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


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



ca607e39915ee29a383ade16819c3f61.webp

good-icon 0
favorite-icon 0
收藏
回复数量: 0
    暂无评论~~
    Ctrl+Enter