通过前面这么多讲解,springboot原理应该也大概有个轮廓了,一些基本的配置,从客户端url到controller(配置一些要用的组件,servlet三大组件,处理器映射器,拦截器,视图解析器这些都说过了),然后通过Dao和数据库打交道(配置数据源、Druid监控都说了,其实我后面要写的就是springboot和mybatis、springdata jpa的整合运用了),顺便还说了一下spring中ioc容器的创建原理。

  今天就来一点更好玩的东西,大家还记得最开始的那个主配置类吧(就是有main方法的那个)。对了,ioc容器创建还有不了解的出门左转,可以看我前面几次写的文章。

  温馨提醒:这次原理涉及到ioc容器创建原理以及监听器原理,我会跳过,因为前几篇说过了,只说springboot有关的;而且不会使用调试的小伙伴要先学会调试哦~

  随便创建一个springboot应用(要包括web模块)

  首先,我们就在这里打个断点

  调试,run方法里面可以看到还是啥事没做,继续调用run方法,step into进入

  可以看到,先根据主配置类创建一个spring应用(SpringApplication),然后调用run方法

  

  我们看看是怎么创建spring应用的

  

  那我们来看看这两个类似的方法做了一些什么

  

  是累路径下所有的jar包下的META-INF/spring.factories文件,我只是举个例子,还有很多个这样的xxxInitializer

  同理,那两个类似的的方法下面一个,就是加载所有类路径下META-INF/spring.factories,键为ApplicationListener的所有类,然后保存起来。

  到这里。spring应用就创建出来了,无非是加载所有的ApplicationContextInitializer对应的xxxInitializer   和  ApplicationRunListener对应的监听器,都保存起来

-------------------------------------------------------------------------------------------------------------------------------------------------------------------

  下面就开始运行run方法,看run方法里面是怎么运行的

  主要来看看这七个步骤是干了什么

第一步

  

  拿到所有监听器,创建对象,然后保存起来,再看第一步的start()方法,有关监听器的原理在我的spring ioc原理我就说了(这里的所有监听器,在之前已经加载好了,都存起来了)

第二步

  

  后面的就是监听器的原理了,都一样(贴一下监听器接口里面的方法)

第三步(创建ioc容器)

  

第四步

  每个具体的xxxApplicationContextInitializer类的initialize()方法都不一样,可以自己去看看,估计肯定是设置一些参数,往ioc容器里导入一些组件

第五步(刷新容器,具体的我之前spring ioc源码那里详细的讲解了,这里就略过)

  记住哦,这里的获取ioc容器由于在上面已经创建过了,所以会直接从上面获取的

  先到这里,下一节继续说一下后面一点内容

带着萌新看springboot源码11(springboot启动原理 源码上)的更多相关文章

  1. 带着萌新看springboot源码03

    上一节讲到了快速新建一个springboot应用,以及springboot的自动配置类起作用的时机,并且一起看了一个自动配置类的源码. 这一节我们来粗略看看当用户在浏览器输入一个url,怎么样返回一个 ...

  2. 带着萌新看springboot源码12(启动原理 下)

    先继续接上一篇,那个启动原理还有一点没说完. 6. afterRefresh(context, applicationArguments); 看这个名字就知道,应该就是ioc容器刷新之后的一些操作了, ...

  3. 带着萌新看springboot源码07

    [修改]很长时间没看这个,有点弄混淆了.bean后置处理器(BeanPostProcessor)应该是在bean创建实例并且赋值好了之后,调用初始化方法(相当于xml配置中<bean init= ...

  4. 带着萌新看springboot源码

    springboot的功能确实强悍,只需要很少的配置,就能够做出来一个简单的web应用,下面我就简要的分析一下为什么springboot能够起作用. 不觉得很奇怪吗?只需要一个主配置类(就是启动那个m ...

  5. 带着萌新看springboot源码05

    上一节走了一遍从浏览器发出请求到得到向页面的流程,基本的功能是已经实现了.但是现在啊,我想自定义一个拦截器(拦截器可以做用户登录验证,如果登录了,就让你通过,如果没有登录,就重定向登录页面),这里就不 ...

  6. 带着萌新看springboot源码8(spring ioc源码上)

    emmm.....这次先不说springboot原理,先好好回顾一下以前的注解版spring原理,先把spring原理了解清晰了,再看springboot原理更容易. 要说起spring,最重要的就是 ...

  7. 带着萌新看springboot源码10(springboot+JdbcTemplate+druid)

    上一节把springboot和jdbcTemplate大概用法说了一下,以及大概看了一下源码,还说了加载sql文件时的原理. 这一节来看看自动注入JdbcTemplate的原理,顺便用一用Druid数 ...

  8. 带着萌新看springboot源码09(springboot+JdbcTemplate)

    emmm.....常规开局,继续说一下废话,前面简单的说了一下spring的ioc容器创建原理(花了不少时间去看了别人的博客+查了不少资料+自己的理解),相信大家对ioc容器有了一个初步的认识了. s ...

  9. 带着萌新看springboot源码8(spring ioc源码 完)

    上一节说到实例化了所有的单实例Bean,后面还有一步遍历 12.完成容器刷新(finishRefresh();) 那个和生命周期有关的后置处理器类型是LifecycleProcessor:监听器原理我 ...

随机推荐

  1. BZOJ.4145.[AMPPZ2014]The Prices(状压DP)

    BZOJ 比较裸的状压DP. 刚开始写麻烦惹... \(f[i][s]\)表示考虑了前\(i\)家商店,所买物品状态为\(s\)的最小花费. 可以写求一遍一定去\(i\)商店的\(f[i]\)(\(f ...

  2. TCP 三次握手、四次挥手

    三次握手:(主要是server.client相互同步系列号) SYN:同步序列号 ACK:确认序列号 第一次握手:client 向server 发送SYN,seq=x,申请同步client端序列号,c ...

  3. golang实现障碍、转弯最少的A*寻路

    目录 目标: 要点: 源码: 目标: 优先寻找无障碍的路径 目标不可达时,寻找障碍最少的路径 路径长度相等时,优先转弯最少的路径 多个目标点时,根据以上要求到达其中一个目标点即可 要点: 最优格子的选 ...

  4. Python3 文件

    f=open('C:\\Users\\fengx\\Desktop\\sharing\\test.txt') 如果打开文件的格式不匹配,可能会报如下错: >>> open('C:\U ...

  5. typeof获取变量的数据类型 javascript

    获取变量的数据类型:typeof <!DOCTYPE html> <html lang="en"> <head> <meta charse ...

  6. 【页面置换算法】LRC算法和FIFS算法

    算法介绍 FIFO:该算法总是淘汰最先进入内存的页面,即选择在内存中驻留时间最久的页面予以淘汰.该算法实现简单,只需把一个进程已调入内存的页面,按先后次序链接成一个队列,并设置一个指针,称为替换指针, ...

  7. python语法_装饰器

    装饰器的知识点储备: 1 作用域 2 高阶函数 3 闭包 内部函数,对外部作用作用域的变量进行了引用,该内部函数就认为是闭包, def outer(): x=10 def inner(): print ...

  8. ubuntu connect to windows folder share

    在windows上给远程登录的用户设置一个账号密码.”右击计算机图标“——"管理”——“本地用户和组”——“用户”.然后右击选择“新用户”,输入账号密码,并勾选“密码永不过期”,这样,在远程 ...

  9. 谈一谈从 Delphi 2009 之后就支援的重要功能 – 泛型 (Generic)

    前言 在C++的语言基础当中,除了物件导向.事件驱动的概念之外,模版设计(Template)也是非常重要的一环.然而,C++的开发人员能够善用模版设计的并不多.模版设计这个好物,一般还有一个名称,就是 ...

  10. Data Center手册(2): 安全性

    有个安全性有下面几种概念: Threat:威胁 Vulnerability: 安全隐患 Attack: 攻击 有关Threat 常见的威胁有下面几种 DoS(Denial of Service拒绝服务 ...