可观测系统如何识别网站有多少文件命中了缓存?

本文涉及的产品
可观测监控 Prometheus 版,每月50GB免费额度
性能测试 PTS,5000VUM额度
应用实时监控服务ARMS - 应用监控,每月50GB免费额度
简介: 文章首发于掘金,属于小众的技术文,讲的是如何判断网站使用的文件是缓存,也就是disk cache ,memory cache 还有304

为了告慰良心,web developer搞了可视化、组件化、工程化、微前端、低代码。

网站平均加载时间依然客死在2s内。

文章首发于掘金,属于小众的技术文,讲的是如何判断网站使用的文件是缓存,有关使用的本地存储数据(ls、ss等)不在讨论范围。 说清楚范围后,说一下分类,这里的文件缓存有两类,第一类是:

  • disk cache
  • memory cache

这里的缓存,也就是网络所示中,标明缓存的部分:

网络异常,图片无法展示
|
上图中,红框内就是缓存的文件。 如果服务器发版了,但是客户端依旧使用了缓存的文件,就可能会出现功能不一致、报错等情况。当然使用缓存文件,能够极大的提高网站的性能,至于定量分析,也不在本文章的技术讨论范畴。

在进入主题前,需要需要补充两方面的内容:

  • Performance.getEntries()
  • performanceObserver 因为根据上面两方面的内容上面两方面的内容我们能够看到,我们是能够获取到文件的对象的。下面是获取对象的方法代码示例:
const observer = new PerformanceObserver((list) => {
  list.getEntries().forEach((entry) => {
      console.log(entry);
  });
});
observer.observe({ type: "resource", buffered: true });
复制代码

网络异常,图片无法展示
|
下面的类型很多这里,我们只看跟文件有关的,其中包含可能的有: 来看一下这个对象都有哪些内容:

  • link
  • script
  • css
  • img
  • other

这部分只是掘金展示的内容,我们详细来看一下, 这里我们先看link这种类型,以此来了解这个对象都包含哪些内容,

网络异常,图片无法展示
|

将详细的json贴入,能看到:

{
    "name": "https://lf3-cdn-tos.bytescm.com/obj/static/xitu_juejin_web_editor/css/app.926bb8b0.css",
    "entryType": "resource",
    "startTime": 224,
    "duration": 70.5,
    "initiatorType": "link",
    "nextHopProtocol": "h2",
    "renderBlockingStatus": "non-blocking",
    "workerStart": 0,
    "redirectStart": 0,
    "redirectEnd": 0,
    "fetchStart": 224,
    "domainLookupStart": 224,
    "domainLookupEnd": 224,
    "connectStart": 224,
    "secureConnectionStart": 224,
    "connectEnd": 224,
    "requestStart": 234.5,
    "responseStart": 291.40000000596046,
    "responseEnd": 294.5,
    "transferSize": 52326,
    "encodedBodySize": 52026,
    "decodedBodySize": 309469,
    "responseStatus": 0,
    "serverTiming": [
        {
            "name": "cdn-cache",
            "duration": 0,
            "description": "HIT"
        },
        {
            "name": "edge",
            "duration": 5,
            "description": ""
        }
    ]
}
复制代码

mdn在performanceObserver的例子中,给出的有关如何判断304的代码

const observer = new PerformanceObserver((list) => {
  list.getEntries().forEach((entry) => {
    if (entry.responseStatus === 304) {
      console.log(`${entry.name} was loaded from cache`);
    }
  });
});
observer.observe({ type: "resource", buffered: true });
复制代码

上面代码即下图。

网络异常,图片无法展示
|

同时,mdn给出了api的兼容性。

网络异常,图片无法展示
|

看到上图,基本可以放心大胆的使用了。理想很丰满,然而现实却是骨感的。 因为上图掘金中,明明使用缓存的文件,我们发现responseStatus有哪些:

  • 200
  • 204
  • 0 即便明确有304的,我们也看不到。所以如何来判断304?代码如下:
entry.encodedBodySize > 0 && entry.transferSize > 0 && entry.transferSize < entry.encodedBodySize
复制代码

所以,聪明的你,应该能够根据上面的代码推测出来,如果是磁盘或者文件缓存,entry.transferSize 应该是多少呢?

有关命中缓存的好处,就不在本文赘述。下图是本地测试中有关静态文件的response status的分布。

网络异常,图片无法展示
|


作者:Yestodorrow

链接:https://juejin.cn/post/7212576051166511162

来源:稀土掘金

著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

目录
相关文章
|
1天前
|
缓存 监控 NoSQL
使用Java实现分布式缓存系统
使用Java实现分布式缓存系统
|
1天前
|
存储 缓存 NoSQL
使用Java构建高性能的分布式缓存系统
使用Java构建高性能的分布式缓存系统
|
4天前
|
缓存 运维 Devops
阿里云云效操作报错合集之在构建过程中,Docker尝试从缓存中获取某个文件(或计算缓存键)时遇到了问题,该如何处理
本合集将整理呈现用户在使用过程中遇到的报错及其对应的解决办法,包括但不限于账户权限设置错误、项目配置不正确、代码提交冲突、构建任务执行失败、测试环境异常、需求流转阻塞等问题。阿里云云效是一站式企业级研发协同和DevOps平台,为企业提供从需求规划、开发、测试、发布到运维、运营的全流程端到端服务和工具支撑,致力于提升企业的研发效能和创新能力。
|
4天前
|
监控 Python 缓存
缓存系统提升Web应用性能
【6月更文挑战第22天】
7 0
|
7天前
|
缓存 监控 NoSQL
淘客返利系统的缓存策略与实现
淘客返利系统的缓存策略与实现
|
15天前
|
缓存 监控 负载均衡
Java一分钟之-Ehcache:分布式缓存系统
【6月更文挑战第17天】**Ehcache是Java的开源缓存库,支持本地和分布式缓存,提供负载均衡、数据复制和容错能力。常见问题包括网络分区导致的数据不一致、缓存雪崩和配置不当引起的性能瓶颈。解决策略涉及选择强一致性策略、设置合理缓存过期时间和监控调整配置。使用Ehcache需添加相关依赖,并配置分布式缓存,如示例所示,通过CacheManager创建和管理缓存。实践中,持续监控和优化配置至关重要。**
36 1
|
18天前
|
存储 缓存 API
file_cache: 使用文件缓存函数结果
file_cache: 使用文件缓存函数结果
34 15
|
23天前
|
存储 消息中间件 缓存
Redis:内存数据存储与缓存系统的技术探索
**Redis 概述与最佳实践** Redis,全称Remote Dictionary Server,是流行的内存数据结构存储系统,常用于数据库、缓存和消息中介。它支持字符串、哈希、列表等数据结构,并具备持久化、主从复制、集群部署及发布/订阅功能。Redis适用于缓存系统、计数器、消息队列、分布式锁和实时系统等场景。最佳实践包括选择合适的数据结构、优化缓存策略、监控调优、主从复制与集群部署以及确保安全配置。
24 3
|
25天前
|
缓存 安全 前端开发
(转)浅谈tomcat优化(内存,并发,缓存,安全,网络,系统等)
(转)浅谈tomcat优化(内存,并发,缓存,安全,网络,系统等)
|
1天前
|
缓存 NoSQL Java
Spring Boot整合Redis缓存的最佳实践
Spring Boot整合Redis缓存的最佳实践