有关 springboot 加载原理解析的一些心得
当我们创建完 一个 springboot 工程后然后加入 spring-boot-starter-web 依赖,启动打开控制台,如下
结论:
(1) springboot 封装了 springmvc,因为springboot是基于servlet , 而且 前端控制器也是 dispatcherServlet (如图可以看出)
(2) springboot 里面也有很多过滤器,如:
metricsFilter:度量过滤器(主要记录请求时长等一些记录信息)
从源码我们可以看出我们的所有方法都经过了 这个过滤器,因为最终它会把我们请求的 时间,请求响应的状态,路径,以及请求的信息放入度量 的日志里面
characterEncodingFilter:字符编码过滤器(主要检查有没有设置字符编码的问题,从图下的源码我们
可以看出)
)
hiddenHttpMethodFilter: (隐藏的方法过滤器)
查看源码:
这个过滤器 主要是对post 方法做了特殊处理(方法的大小写转换等等)
httpPutFormContentFilter (http 协议 put ,post 表单提交方法过滤器)
从源码我们可以证明 该过滤器会对put 方法 或 patch 方法的表单提交方法 进行过滤, 在请求参数不为空
的情况下,把请求转换进行包装
requestContextFilter (请求上下文过滤器)
该过滤器主要是对request 和 response 的做了一次封装表明这是一次请求(请求一进来 就通过 把request
和response 就进行了封装 ,然后初始化 上下文的Request容器,对请求完成之后,又初始化上下
文的Request容器,这样就保证这是一次请求)
webRequestLoggingFilter (web 的请求日志过滤器)
该过滤器主要是对日志进行过滤控制
applicationContextIdFilter(该项目引用加载过滤器)
该过滤器主要是对启动项目的时候对项目上下文加载做了一些过滤
对于后续的加载
其中
/health :表示对硬盘做了一个健康检查
注意点:
(1) 这里需要修改pom.xml 文件,添加依赖
<!--添加监控依赖--> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-actuator</artifactId> </dependency>
访问 http://localhost:8080/health
最终显示
status:up 表示 健康
diskspace :表示 表示的硬盘的信息
total:表示总硬盘大小
free:表示空闲的大小
threshold:表示最少的硬盘容量
其他 的 /loggers 表示的日志的信息,由于返回的都是json 格式,get请求,所以我们都可以通过浏览
器访问的方式看到日志信息。
由于时间关系,这些东西可能写的不够详细,这里写出来只是发表一下个人的想法,如果有什么不对的地
方可以希望大家能指出来,一起学习进步!