​  这两年随着微服务的盛行,SpringBoot框架水到渠成的得到了高曝光,作为程序猿的我们,现在要是不知道一点SpringBoot相关的东西,貌似出去找工作都会被深深地鄙视,不过在我们开始SpringBoot之旅前,我们先回顾和探索一下Spring框架的本质,然后一点点的很自然的过渡到SpringBoot,这样对于我们深刻理解SpringBoot也是非常有帮助的。

二、Spring框架的起源

​  在“黑暗”的EJB1的时代,开发人员非常痛快,这时候解放开发人员的高性能Spring框架千呼万唤始出来。那是一个J2EE规范统治的时代,基于各种容器和J2EE规范的软件解决方案是唯一的“正道”,臃肿的生态和沉重的开发模式让当时的每一个开发都痛不欲生。这时候技术大牛Rod Johnson在自己的经典巨作《Expert One-on-One J2EE Design and Development》中描绘了轻量级框架的研发理念,抨击了原有的笨重的规范,然后基于这本书中的研发理念开发出了最初版的Spring框架,然后火的一塌糊涂,一直延续至今,已10多年之久仍旧没有衰败之势。

​   Spring框架是构建高性能Java研发体系的最佳实践之一,通过一系列简洁而统一的设计,为广大Java开发人员劈开了一条光明之路。

​   Spring对Java开发中常用的技术做了合理的封装和设计,包括我们所熟知的Spring IoC和AOP等,可以让Java开发者避免往日因为API和系统设计不合适而出现的错误,还能高效高质量的完成相应问题领域中的开发工作,此乃Java开发必备神器也~

三、没想到Spring IoC 竟如此简单

​  我相信很多Java开发者对IoC(Inversion Of Control) 和DI(Dependency Injection)的概念都傻傻分不清楚,认为这两者是同一个东西。其实它俩是包含和被包含关系,IoC有两种方式:DI和DL(Dependency Lookup 依赖查找),DI是当前软件实体被动接受它所依赖的其他组件被IoC容器注入,而DL是当前实体主动去某个服务注册中心去查找其依赖的那些组件,概念之间的关系如下图:

​  我们经常说的Spring IoC其实是指Spring框架给我们提供的IoC容器实现(IoC Container)。下面我们看一个Spring IoC容器使用的一个经典案例:


public class Demo {public static void main(String[] args) {ApplicationContext context = new FileSystemXmlApplicationContext("config-file-path")DemoService service = context.getBean(DemoService.class);service.doSomething();}} 

我相信每一个使用Spring框架构建的独立的Java应用,通常都会存在类似context.getBean(...)的代码,其实这行代码做的事情就是DL,而且构建每一种IoC容器背后发生的事情,更多的是DI的过程,当前也可能会有部分DL的逻辑用来对接旧的遗留系统。

Spring的IoC容器的依赖注入工作分为两步走:

阶段一、收集和注册Bean

这个阶段中,开发者通过XML或者Java代码的方式来定义bean,然后以手动组装或让容器基于特定的机制自动扫描的形式,将这些定义好的bean收集到IoC容器中。

假如我们以XML配置的方式来收集和注册如下一个单一bean,一般来说形式如下:


<bean id="DemoService" class="x.x.DemoService">...</bean> 

随着我们项目中bean越来越多,这样逐个手动配置比较麻烦,我们还可以使用如下方式配置来批量扫描并采集和注册一批bean:


<context:component-scan base-package="x.x"/> 

阶段二、分析和组装

第一个阶段完成以后,我们可以先暂时认为IoC容器中保存着一个个相互独立的bean,它们之间还没有任何关系,但是实际项目中它们之间是有着不可或缺的关系的,所以呢,Ioc容器第二个阶段需要做的工作就是分析这些已经在IoC容器中bean,根据它们的依赖关系先后按顺序组装它们,工作原来是这样的:IoC发现一个bean依赖另外一个bean,那么它会将另一个bean注入给依赖它的那个bean,一直到所有的bean的依赖都完成注入。这个时候容器中所有的bean都已经准备好待使用,也就标志着整个IoC容器的工作完成。

那么IoC容器分析和组装的依据是啥呢?Spring框架其实最早的时候只能通过XML配置文件来描述bean和bean之间的关系,但是随着Java生态研发技术以及理念的转变,又出现了基于Java代码和Annotation元信息的描述方式(比如@AutoWired和@Inject)。但是呢,无论使用哪一种配置方式,目的都是为了简化绑定逻辑描述的各种表象,最终也都是为本阶段的最终目的来服务。

四、JavaConfig是个什么鬼?

​  Java 5的出世,加上当时基于纯Java Annatation的依赖注入框架Guice的出现,就使得Spring框架和社区不得不顺应民意,出版并持续完善了基于Java代码和Annotation元信息的依赖关系绑定描述方式,就是JavaConfig项目。

基于JavaConfig方式的依赖关系描述基本映射了早期基于XML方式的配置,比如:

1. 表达形式

XML配置方式如下:


<?xml version="1.0" encoding="UTF-8"?><beans xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xmlns="http://www.springframework.org/schema/beans"         xmlns:context="http://www.springframework.org/schema/context"xsi:schemaLocation="http://www.springframework.org/schema/beanshttp://www.springframework.org/schema/beans/spring-beans-4.0.xsd http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context.xsd">// bean定义</beans> 

JavaConfig的配置方式如下:


@Configurationpublic class DemoConfiguration {// bean定义} 

也就是说任何一个被标注了@Configuration注解的Java类都是一个JavaConfig配置类。

2. 注册bean定义

XML配置方式:


<bean id="demoService" class="x.x.DemoServiceImpl">...</bean> 

JavaConfig配置方式:


@Configurationpublic class DemoConfiguration {@Beanpublic DemoService demoService() {return new DemoServiceImpl();}} 

也就是说任何一个标注了@Bean注解的方法,它的返回值就将作为一个bean定义注册到Spring的IoC容器,方法名将默认成为该bean在容器中的id.

3. 表达依赖注入关系

XML配置形式:


<bean id="aService" class="x.x.AServiceImpl"><bean id="bService" class="x.x.BServiceImpl"><property name="dependencyService" ref="aService"/></bean> 

JavaConfig形式:

## 最后针对最近很多人都在面试,我这边也整理了相当多的面试专题资料,也有其他大厂的面经。希望可以帮助到大家。> 下面的面试题答案都整理成文档笔记。也还整理了一些面试资料&最新2021收集的一些大厂的面试真题(都整理成文档,小部分截图),有需要的可以[戳这里免费领取](https://gitee.com/vip204888/java-p7)![在这里插入图片描述](https://img-blog.csdnimg.cn/img_convert/e360e96f2239e7937038a34dbc783235.png)> 最新整理电子书JavaConfig形式:

最后

针对最近很多人都在面试,我这边也整理了相当多的面试专题资料,也有其他大厂的面经。希望可以帮助到大家。

下面的面试题答案都整理成文档笔记。也还整理了一些面试资料&最新2021收集的一些大厂的面试真题(都整理成文档,小部分截图),有需要的可以戳这里免费领取

[外链图片转存中…(img-Mg2HjwU6-1628590068219)]

最新整理电子书

SpringBoot的幕后推手,分布式架构演进+相关笔记参考相关推荐

  1. 服务端高并发分布式架构演进之路(转载,图画的好)

    这个文章基本上从单机版到最终版,经历了加缓存,加机器,高可用,分布式,最后到云等过程,其实我一直想总结一套类似的东西,没想到有人已经先弄出来了,那就不重复造轮子了,而且我感觉这个文章也是花了功夫的. ...

  2. 服务端高并发分布式架构演进之路

    服务端高并发分布式架构演进之路 概述 基本概念 架构演进 单机架构 第一次演进:Tomcat与数据库分开部署 第二次演进:引入本地缓存和分布式缓存 第三次演进:引入反向代理实现负载均衡 第四次演进:数 ...

  3. 服务端高并发分布式架构演进之路(阿里巴巴90秒100亿)

    服务端高并发分布式架构演进之路 阿里巴巴为什么能抗住90秒100亿? 1. 概述 本文以淘宝作为例子,介绍从一百个到千万级并发情况下服务端的架构的演进过程,同时列举出每个演进阶段会遇到的相关技术,让大 ...

  4. 阿里巴巴服务端高并发分布式架构演进之路

    文章目录 1 概述 2 基本概念 2.1 什么是分布式 2.2 什么是高可用 2.3 什么是集群 2.4 什么是负载均衡 2.5 什么是正向代理和反向代理 3 架构演进 3.1 单机架构 3.2 第一 ...

  5. 淘宝高并发分布式架构演进之路

    点击上方"开发者技术前线",选择"星标" 16:35 在看 真爱 作者:huashiou. segmentfault.com/a/119000001862616 ...

  6. 淘宝服务端高并发分布式架构演进之路

    点击上方"方志朋",选择"置顶公众号" 技术文章第一时间送达! 1. 概述 本文以淘宝作为例子,介绍从一百个并发到千万级并发情况下服务端的架构的演进过程,同时列 ...

  7. 淘宝服务端并发分布式架构演进之路

    -     前言    - 本文以淘宝作为例子,介绍从一百个到千万级并发情况下服务端的架构的演进过程,同时列举出每个演进阶段会遇到的相关技术,让大家对架构的演进有一个整体的认知,文章最后汇总了一些架构 ...

  8. 大型互联网大型分布式架构演进之路

    来自:网络 编注: 架构决定的系统的稳定性,扩展性和并发性,架构的演进是从简单到复杂,从单一到复合持续改进的过程,也是经验的积累和技术的结晶. 初始阶段架构 初始阶段的小型系统.应用程序.数据库.文件 ...

  9. 淘宝亿级高并发分布式架构演进之路

    https://segmentfault.com/a/1190000018626163 1. 概述 本文以淘宝作为例子,介绍从一百个并发到千万级并发情况下服务端的架构的演进过程,同时列举出每个演进阶段 ...

最新文章

  1. 如何保证缓存和数据库的双写的一致性
  2. 代数系统思维导图_线性代数思维导图专题
  3. 云计算管理三利器:Nagios、Ganglia和Splunk
  4. CF思维联系–CodeForces - 222 C Reducing Fractions(数学+有技巧的枚举)
  5. 云计算:容器技术变革云计算,SaaS带动CaaS市场
  6. [渝粤教育] 西南科技大学 投资经济学 在线考试复习资料(2)
  7. 神话人物的现代版简历
  8. 《spring-boot学习》-12-@controller和@RestController的区别?
  9. 设备驱动基础学习--字符驱动实现
  10. 学习nodejs之hello world
  11. redis介绍以及使用 ppt_茶具一对一介绍,以及使用方法
  12. 75.国旗问题:颜色分类(力扣leetcode) 博主可答疑该问题
  13. 编写c高级语言程序步骤,高级语言程序设计知识点总结一
  14. 中国石油大学《机械基础(设计与制造)》第二阶段在线作业
  15. 移动开发者必须了解的10大跨平台工具
  16. FPGA Verilog进阶开发教程:WM8978音频回环实验
  17. 如何通过外包平台承接IT项目
  18. CodeForces 32C Flea
  19. [文献阅读]——BERT: Pre-training of Deep Bidirectional Transformers for Language Understanding
  20. 支付宝小程 rich-text标签不显示问题解决

热门文章

  1. deepinV20 显卡驱动 cuda10.2+cudnn配置
  2. Mac 系统升级ssh报错
  3. 华为手机里的“麦田守望者”
  4. [转载]iOS开发之第三方登录QQ
  5. (转载)SPSS之聚类分析(图文+数据集)
  6. 使用Stream流时报java.lang.IllegalStateException: stream has already been operated upon or closed错误
  7. hyper-v与Docker for windows和VMBox的冲突
  8. 编写应用程序,计算两个非零正整数的最大公约数和最小公倍数,要求两个非零正整数从键盘输入。
  9. 打开GitHub官网缓慢
  10. 唯物史观在高中历史教学中的具体运用