Service Worker自动更新流程

Service worker automatic update process

我对service worker的更新过程有疑问。 在我的项目中有2个与sw相关的文件:

"sw.js",放置在网站根目录中,不会被缓存(通过缓存 API 和 Web 浏览器)。

我的 service worker 管理所有静态文件和所有动态 url 页面的缓存。

有时我需要更新它,客户端必须检测到有更新并立即执行。

"sw_main.js" 是安装我的 sw 的脚本。此文件由 Cache API 缓存,因为我的应用程序必须离线工作。

在里面我们可以找到:

var SW_VERSION = '1.2';
navigator.serviceWorker.register("sw.js?v=" + SW_VERSION, { scope: "/" }).then(....

问题是:因为sw_main.js被缓存了,如果我改了SW_VERSION然后在线部署webapp,所有客户端都不会 更新,因为看不到该文件中的更改。

管理 SW 更新过程的最佳方式是什么?

我现在有3种触发sw更新的方法:

  1. 推送和同步事件(但我没有实现这些)
  2. 仅当 service worker URL 发生变化时才调用 .register() (但是 在我的例子中,这是不可能的,因为 sw_main.js 被缓存了,所以我 无法更改 SW url)
  3. 导航到范围内的页面(我想我们有同样的缓存问题 第 2 点的

我还读了这个:"Your service worker is considered updated if it's byte-different to the one the browser already has"。

这意味着如果我更改 sw.js 的内容(即未缓存),Service Worker 会自动检测更新吗?

谢谢

我找到了 2 个可能的解决方案。

首先我想说缓存(使用 pwa 缓存 API)和 sw.js 更好,因为当你离线时,它会被 sw_main.js 请求.

第一个解决方案:

使用 service worker 的缓存作为后备,并始终尝试通过 fetch() 进入网络优先。 这仅适用于 sw.js,也许 sw_main.js。 你失去了缓存优先策略提供的一些性能提升,但 js 文件大小非常小,所以我认为这不是一个大问题。

第二种解决方案:

如果您的缓存 sw.js 文件发生了变化? 我们可以挂钩到已注册的 Service Worker 上的 "onupdatefound" 函数。 即使您可以缓存大量文件,Service Worker 也只会检查您注册服务的哈希值-worker.js。 如果该文件只有 1 个小改动,它将被视为新版本。 所以这证实了我之前的问题!我试试看!

如果可行,第二种方案最好