<font face="黑体" color=green size=2> 版权声明:本文为博主原创文章,遵循 CC 4.0 by-sa
版权协议,转载请附上原文出处链接和本声明。
本文链接: http://blog.shiyi.online/articles/2019/09/06/1567738669800.html
首发地址:https://mp.weixin.qq.com/s/ye1u4b_eWjpO5etwp60hVg
前言
上一篇文章 【Nacos 源码之配置管理 四】DumpService 如何将配置文件全部 Dump 到磁盘中 分析了 Nacos 将配置文件 Dump 的磁盘中,那我为什么要 Dump 到磁盘中呢?这样做有什么好处?哪些地方读取了磁盘中的文件?带着这些问题,我们去源码中一探究竟;
1.快速启动,将数据库中的数据与磁盘对比 MD5 判断是否修改
// Dump 修改过的配置文件
static public boolean dumpChange(String dataId, String group, String tenant, String content, long lastModifiedTs) {
//省略....
final String md5 = MD5.getInstance().getMD5String(content);
if (!STANDALONE_MODE || PropertyUtil.isStandaloneUseMysql()) {
/**读取本地磁盘文件的MD5**/
String loacalMd5 = DiskUtil.getLocalConfigMd5(dataId, group, tenant);
if (md5.equals(loacalMd5)) {
dumpLog.warn(
"[dump-ignore] ignore to save cache file. groupKey={}, md5={}, lastModifiedOld={}, "
+ "lastModifiedNew={}",
groupKey, md5, ConfigService.getLastModifiedTs(groupKey), lastModifiedTs);
} else {
DiskUtil.saveToDisk(dataId, group, tenant, content);
}
}
}
2. 同步配置获取接口 ConfigServletInner.doGetConfig
这是一个 Http 请求调用的接口,这是获取配置数据的接口,最终是调用了 DiskUtil.targetFile(dataId, group, tenant);
方法得到配置文件; 然后把文件中的信息返回到 Response 中给请求方;
注意: 配置中心的内存是没有保存配置信息 content 的;因为 content 一般数据都不小;全部存放到内存中,对 Jvm 的内存占用比较大,所以内存只保存了基本信息;content 具体内容保存在磁盘中; 等客户端发起 Http 请求获取对应配置信息的时候,再去磁盘中读取返回给客户端; 读取磁盘文件肯定是比读取数据库效率要高高的;
为什么要把配置文件 Dump 到磁盘中
Dump 配置文件到磁盘中可以提高性能; 客户端想要请求配置数据的时候,发起 Http 请求给服务端; 服务端会去磁盘中读取对应文件返回; 读取磁盘文件比直接读取数据库效率要高;
然后服务端会跟最新的数据会保持一致,如果修改了配置,不仅 Jvm 内存数据会更新,也会把最新的 content 内容及时保存到磁盘文件中;
欢迎来到这里!
我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。
注册 关于