background

When accessing the browser, some static resources will be cached, and the next access will not have to pull data again, reducing the server data return. Is one of the common optimization and means

So how do you cache it? What are the criteria

Strong cache

Check whether the local cache data satisfies the cache and is not expired. If yes, the data is read directly; if no, the request is sent.

Expires

Expires belongs to the HTTP1.0 protocol. Currently, most browsers use HTTP1.1 or HTTP2. Determining whether the request time is expired According to whether the request time is less than the Expires server time, the local time is inconsistent with the server time

Cache-Control

No-cache: Indicates that the browser determines whether the cached resources are up to date before using the cache. Max-age =x(s): indicates that the request is not sent x seconds after the request is cached. S-maxage =x(s): The proxy server does not send a request to the source server in x seconds. The request is valid only for CDN cache. Public: Both the client and the proxy server can cache the requestCopy the code

Negotiate the cache

Some places call it a comparison cache. Negotiated cache Requests are made to the server regardless of whether there is a local cache. According to the returned identifier, a new request is required.

Last-Modified / If-Modified-Since

Last-modified: Returns the Last time the resource was Modified

If-modified-since: Returns the last time the resource was Modified. Compared to last-modified time, large cases require the return of the latest data, and small cases require the return of the status. 304 The browser uses the cache

Etag / If-None-Match

Etag: indicates the id of the current request on the server. If-none-match: indicates the id of the current resource, and compares it with the Etag to determine whether the resource has been modified

Priority is higher than last-modified/if-modified-since

Nginx Cache configuration reference

Server {# handle media resource files, Cache for the location ~ 350 days. * \. (GIF | JPG | jpeg | PNG | BMP | SWF | FLV | mp3 | wma) ${} expires 350 d # set the js and CSS cache time to the location ~ 360 days .*\.(js|css)$ { expires 360d } }Copy the code

CDN cache

After setting the CDN cache, the domain name is equivalent to setting a transfer station. When the browser accesses the domain name, the request is sent to the CDN server closest to the browser, which either returns to the source server or returns to its cache

It can be seen that the first access is slower than without adding CND, and the advantages of distance and cache can be fully reflected if the access is multiple times. So configuring CDN caching is a good optimization for frequently visited sites. Of course there needs to be a balance between costs and benefits

The CDN also plays a significant role in disaster recovery. When we set the CDN cache, when the source server fails, the normal access within the cache time can be maintained, giving the developers a certain amount of time to buffer the recovery service

Browser Access Mode

1. Browser Jump: Enter the url, jump, forward and backward

The cache configuration takes effect

2. Refresh the browser

Ignore Expires max-age and set cache-control to max-age=0. ETag and last-Modified are in effect

3. Forcibly refresh

This is similar to refreshing the browser, except that cache-control is set to no-cache

conclusion

  1. The strong cache is judged first, then the negotiated cache is judged
  2. Proper configuration of the cache policy can achieve the purpose of optimization
  3. The current HTTP protocol is HTTP1.1 and HTTP2 more

thinking

  1. Concept question: What are the concepts of cache, strong cache and negotiated cache

  2. Nginx server or Node.js configure the cache policy

  3. The benefits of CDN

  4. Refresh the browser cache policy in different ways