Service|Service Worker Cache 和 HTTP Cache 联合使用的场景讨论
本文基于下列的表格进行讨论。
文章图片
场景1:Long-term caching (Cache, falling back to network)
- 当缓存资源有效时(<= 30 天):Service Worker 立即返回缓存的资源,无需访问网络。
- 当缓存资源过期(> 30 天)时:Service Worker 去网络获取资源。 浏览器在其 HTTP 缓存中没有资源的副本,因此它在服务器端获取资源。
场景2:Medium-term caching (Stale-while-revalidate)
- 当缓存资源有效时(<= 1 天):Service Worker 立即返回缓存的资源,并去网络获取资源。 浏览器在其 HTTP 缓存中有资源的副本,因此它将该副本返回给服务工作者。
- 当缓存资源过期(> 1 天):Service Worker 立即返回缓存的资源,并去网络获取资源。 浏览器在其 HTTP 缓存中没有资源的副本,因此它会在服务器端获取资源。
场景3:Short-term caching (Network falling back to cache)
- 当缓存的资源有效时(<= 10 分钟):Service Worker 去网络获取资源。 浏览器在其 HTTP 缓存中有资源的副本,因此它会将其返回给服务工作者,而无需进入服务器端。
- 当缓存资源过期(> 10 分钟):Service Worker 立即返回缓存的资源,并去网络获取资源。 浏览器在其 HTTP 缓存中没有资源的副本,因此它会在服务器端获取资源。
在所有场景下,Service Worker 缓存在网络不稳定的情况下仍然可以返回缓存的资源。 另一方面,当网络不稳定或宕机时,HTTP 缓存是不可靠的。
总之,Service Worker 缓存逻辑不需要与 HTTP 缓存到期逻辑保持一致。 如果可能,在 service worker 中使用更长的过期逻辑来授予 service worker 更多的控制权。
【Service|Service Worker Cache 和 HTTP Cache 联合使用的场景讨论】HTTP 缓存仍然发挥着重要作用,但在网络不稳定或宕机时它并不可靠。
推荐阅读
- Service|Service Worker cache 相比 HTTP cache 的一些优点
- Angular|Angular 里的 Service Worker
- Angular|Angular 应用要启用 Service Worker 所需满足的一些前提条件
- English|Pony.ai's Robotaxi Service Available on Cao Cao Travel
- (四)java版spring|(四)java版spring cloud+spring boot+redis多租户社交电子商务平台 - common-service 项目构建过程
- ServiceLoader(Java 的 SPI 加载方案)
- 项目中DAO层、Service层、Controller层、View层简介和关系
- springboot系列|【SpringBoot系列】最详细demo-- redis、EhCache、Guava做缓存
- redis|SpringBoot缓存使用Redis与@CaChe注解整合 简洁使用
- redis|springboot整合spring @Cache和Redis