Welcome! Log In Create A New Profile

Advanced

[nginx] Cache: do not inherit last_modified and etag from stale ...

Roman Arutyunyan
March 02, 2015 11:50AM
details: http://hg.nginx.org/nginx/rev/174512857ccf
branches:
changeset: 5992:174512857ccf
user: Roman Arutyunyan <arut@nginx.com>
date: Mon Mar 02 19:47:13 2015 +0300
description:
Cache: do not inherit last_modified and etag from stale response.

When replacing a stale cache entry, its last_modified and etag could be
inherited from the old entry if the response code is not 200 or 206. Moreover,
etag could be inherited with any response code if it's missing in the new
response. As a result, the cache entry is left with invalid last_modified or
etag which could lead to broken revalidation.

For example, when a file is deleted from backend, its last_modified is copied to
the new 404 cache entry and is used later for revalidation. Once the old file
appears again with its original timestamp, revalidation succeeds and the cached
404 response is sent to client instead of the file.

The problem appeared with etags in 44b9ab7752e3 (1.7.3) and affected
last_modified in 1573fc7875fa (1.7.9).

diffstat:

src/http/ngx_http_file_cache.c | 2 --
src/http/ngx_http_upstream.c | 7 +++++++
2 files changed, 7 insertions(+), 2 deletions(-)

diffs (30 lines):

diff -r 435ee290c2e1 -r 174512857ccf src/http/ngx_http_file_cache.c
--- a/src/http/ngx_http_file_cache.c Mon Mar 02 18:41:29 2015 +0300
+++ b/src/http/ngx_http_file_cache.c Mon Mar 02 19:47:13 2015 +0300
@@ -181,8 +181,6 @@ ngx_http_file_cache_new(ngx_http_request
c->file.log = r->connection->log;
c->file.fd = NGX_INVALID_FILE;

- c->last_modified = -1;
-
return NGX_OK;
}

diff -r 435ee290c2e1 -r 174512857ccf src/http/ngx_http_upstream.c
--- a/src/http/ngx_http_upstream.c Mon Mar 02 18:41:29 2015 +0300
+++ b/src/http/ngx_http_upstream.c Mon Mar 02 19:47:13 2015 +0300
@@ -2635,7 +2635,14 @@ ngx_http_upstream_send_response(ngx_http

if (u->headers_in.etag) {
r->cache->etag = u->headers_in.etag->value;
+
+ } else {
+ ngx_str_null(&r->cache->etag);
}
+
+ } else {
+ r->cache->last_modified = -1;
+ ngx_str_null(&r->cache->etag);
}

if (ngx_http_file_cache_set_header(r, u->buffer.start) != NGX_OK) {

_______________________________________________
nginx-devel mailing list
nginx-devel@nginx.org
http://mailman.nginx.org/mailman/listinfo/nginx-devel
Subject Author Views Posted

[nginx] Cache: do not inherit last_modified and etag from stale ...

Roman Arutyunyan 858 March 02, 2015 11:50AM



Sorry, you do not have permission to post/reply in this forum.

Online Users

Guests: 296
Record Number of Users: 8 on April 13, 2023
Record Number of Guests: 421 on December 02, 2018
Powered by nginx      Powered by FreeBSD      PHP Powered      Powered by MariaDB      ipv6 ready