对于springboot中的属性文件相信大家在工作中用的是比较多的,对于application.properties和application.yml文件应该非常熟悉,但是对于bootstrap.properties文件和bootstrap.yml这个两个文件用的估计就比较少了,用过的应该清楚bootstrap.properties中定义的文件信息会先与application.properties中的信息加载。而且大家在使用的时候还经常碰到获取不到bootstrap.properties中定义的信息的困扰,本文就来给大家揭开这些谜团。
首先在springboot中默认是不支持bootstrap.properties属性文件的。我们需要映入springcloud的依赖才可以。
相关的版本环境
然后创建对应的bootstrap.properties文件,当然你也可以创建bootstrap.yml文件
同步的我们也会创建application.properties文件,其中会覆盖一个属性
然后我们在controller中获取测试
访问测试:http://localhost:8080/query
通过访问看到bootstrap.properties中的信息获取到了,同时age也被application.properties中的属性覆盖掉了。加载顺序到底是什么?为什么会覆盖呢?我们接下来分析。
看本文之前最好看下我前面讲解的springboot中的监听机制。
在使用bootstrap.properties文件时我们需要映入相关的依赖
其实在这个依赖中会在对应的spring.factories文件中给我们提供新的监听器,也就是bootstrapapplicationlistener监听器。
而bootstrapapplicationlistener监听触发的事件是applicationenvironmentpreparedevent事件,这个事件其实和我们前面介绍监听application.properties的时候的监听器confi诸神混乱gfileapplicationlistener监听的是同一个事件。
如果你看了前面的文章,那么此处你会觉得有点眉目了。也就是当启动的时候发布对应的事件,该监听器会触发相关的解析行为。
搞清楚了监听器的关系后,我们来看下启动的流程代码具体是怎么执行的。
直接进入
在springapplication的构造方法中我们要注意两点,1.监听器的加载 2.main方法的主类记录
然后回来进入run方法
debug到第一个端点。
然后我们放过。
通过上面的动图可以看到又进入了一次这个run方法。先看处理的结果。
然后我们再放过,继续
分两次加载,有先右后哦。那么这里面的第一个加载的原理到底是中国最美丽城市什么呢?继续来分析。
接下来看看是如果出现的一个父context来优先加载我们的bootstrap.properteis文件的,还是从这个图开始
链路如上面一步步跟踪即可。
跳过非关键的,直接进入到bootstrapapplicationlistener中来看。
然后进入到 bootstraprvicecontext方法中。
这儿我有时候不是不懂们看到有创建了一个springapplication对象。这个其实就是父context对象了。
进入run方法你会发现,回到了前面
到这应该就清楚了执行的核心流程了,至于是如何加载的属性文件的内容,参考我的上篇文章哦。
到此这篇关于springboot源码分析之boots微信名女生简单气质trap.properties文件加载的原理的文章就介绍到这了,更多相关springboot源码分析文件加载的原理内容请搜索www.887551.com以前的文章或继续浏览下面的相关文章希望大家以后多多支持www.887551.com!
本文发布于:2023-04-04 09:09:38,感谢您对本站的认可!
本文链接:https://www.wtabcd.cn/fanwen/zuowen/0f2038733f188241a724168947228b4b.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
本文word下载地址:SpringBoot源码分析之bootstrap.properties文件加载的原理.doc
本文 PDF 下载地址:SpringBoot源码分析之bootstrap.properties文件加载的原理.pdf
留言与评论(共有 0 条评论) |