-
Notifications
You must be signed in to change notification settings - Fork 312
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
allow service worker produced resources to be marked as "cachable" #962
Comments
I'm also pretty sure Chromium has similar caches for JS (parsed/compiled) |
Found that issue: https://bugs.chromium.org/p/chromium/issues/detail?id=581613 |
@wanderview I've been thinking about this in terms of |
I don't know if it helps... but I got bit by this once. The image cache in Gecko was serving images to a page even after that image was yanked from the cache API. I think we "fixed" this in gecko: |
Me too. I was implementing a load balancer fetching a picture identified by some URL but transparently served from different servers and I was not able to get the proper response from other browser due to the img cache. |
Gecko's behaviour seems correct as per spec. The additional cache for images is consulted before fetch is called. So if there's a match in the image memory cache, the service worker isn't triggered. |
This should happen within a page, but I think @marcoscaceres was running into a previous bug where we did it for new pages too. I've been told our image cache has some bugs compared to the spec, but I've been too scared to look at it further. |
FWIW, it seems chrome does not consult the service worker on stylesheets in its memory cache. If you run this in chrome 54: https://github.com/samertm/firefox-sw-perf You can see that navigating to the same page again within the same process does not fire FetchEvent's to the service worker for style sheets. Instead the style sheets are served from a higher level memory cache. |
Using the firefox-sw-perf repo, you can verify that Chrome skips the service worker for existing tabs (but not when you create a new tab) when caching headers are set correctly by replacing the event listener in sw.js with this:
For refreshes and |
So I guess the question is, is this behavior ok? Should we just let upstream stuff cache per the cache-control header, etc? Or is there some expectation from devs that if a service worker is present they will get a FetchEvent since the SW can change the resource irrespective of the headers? |
If there's a matching response found in the list of available images or whatever However, the above caches are tied to the current document. Chrome's skipping the CSS request between documents, and that does seem odd. My gut feeling is there should be a fetch event here, and whatever cache Chrome is using here should sit behind the service worker. |
So we do actually re-use our image cache across documents, but we explicitly disable that when service workers are in play. It would be nice to support these things, but perhaps the service worker shoudl explictly opt in to it? Or is the cache-control header enough? Lets discuss at the face-to-face in april |
FWIW, I think the first thing that needs to happen here is having a more concrete description of what each browser does. In particular Chrome/WebKit's cache that they also use for preloading. Then we can try to standardize something around that, then we can start thinking about exposing it. |
You mean their renderer process network memory cache? There are other caches as well, like stylesheet caches (compiled and pre-compiled). |
I think that's the one I mean, yes. Others might be good to have documented too, depending on how visible they are and whether we need to expose them somehow. And if the image cache is impacted when service workers are in play we should probably change the HTML standard somehow (it defines that cache, though somewhat badly). |
Yea, I know we had to fix the firefox image cache at one point to hit the service worker in cases it would have used the cached image before. |
I wouldn't expect the presence of a service worker to change how the image cache works (as spec'd), or are you talking about something more Firefox specific? |
My spec knowledge of image cache is rather weak. But we can test the following: Compare these steps in chrome and firefox:
In the no service worker installed case step (3) gets: Chrome: 545ms In the empty fetch SW case step (3) gets: Chrome: 570ms Firefox is doing some image caching within the process on navigation, but only if SW is not installed. |
F2F:
|
The main cache people think about in the browser is the http cache. Service worker sits on top of the http cache and all SW invoked fetch() calls go through it. This is well and good.
There are, however, additional caches within a browser. For example, both images and stylesheets have some form of memory caching spec'd within a document. These sit above the network and service worker layers.
It might be nice to provide a way for a service worker to indicate a particular Response won't change as long as the SW is in control. For example, a pre-cached asset. This would allow the browser to keep these assets in higher level memory caches. They could then be re-used without paying the cost of firing a FetchEvent or pulling the resource out of Cache API. These assets would have to be invalidated from the memory caches if the service worker became redundant (e.g. updates, unregister, etc).
You can see how effective these caches can be in #756 (comment). The benchmark loads from image cache anywhere from 35ms to 150ms. This is in comparison to the 300+ms required using a caching service worker.
The text was updated successfully, but these errors were encountered: