vary-header: Emit a single vary header in the IPRO flow

The report from some time ago mentioned three Vary: headers,
but I can now only reproduce two using trunk-tracking plus the
original repro-configuration.

This fix unflags r->gzip_vary as set by the gzip module when PSOL
hands us Vary: Accept-Encoding, to make sure that nginx's core
header filter doesn't append another one.

Fixes https://github.com/pagespeed/ngx_pagespeed/issues/1064
This commit is contained in:
Otto van der Schaaf
2016-01-27 23:07:25 +01:00
committed by Jeff Kaufman
parent 181875e80b
commit 2b4c097d48
4 changed files with 38 additions and 0 deletions
+13
View File
@@ -576,6 +576,10 @@ ngx_int_t copy_response_headers_to_ngx(
continue; continue;
} else if (STR_EQ_LITERAL(name, "Transfer-Encoding")) { } else if (STR_EQ_LITERAL(name, "Transfer-Encoding")) {
continue; continue;
} else if (STR_EQ_LITERAL(name, "Vary") && value.len
&& STR_EQ_LITERAL(value, "Accept-Encoding")) {
ps_request_ctx_t* ctx = ps_get_request_context(r);
ctx->psol_vary_accept_only = true;
} }
ngx_table_elt_t* header = static_cast<ngx_table_elt_t*>( ngx_table_elt_t* header = static_cast<ngx_table_elt_t*>(
@@ -1270,6 +1274,7 @@ ngx_int_t ps_decline_request(ngx_http_request_t* r) {
ctx->driver->Cleanup(); ctx->driver->Cleanup();
ctx->driver = NULL; ctx->driver = NULL;
ctx->location_field_set = false; ctx->location_field_set = false;
ctx->psol_vary_accept_only = false;
// re init ctx // re init ctx
ctx->html_rewrite = true; ctx->html_rewrite = true;
@@ -1840,6 +1845,7 @@ ngx_int_t ps_resource_handler(ngx_http_request_t* r,
ctx->recorder = NULL; ctx->recorder = NULL;
ctx->url_string = url_string; ctx->url_string = url_string;
ctx->location_field_set = false; ctx->location_field_set = false;
ctx->psol_vary_accept_only = false;
// Set up a cleanup handler on the request. // Set up a cleanup handler on the request.
ngx_http_cleanup_t* cleanup = ngx_http_cleanup_add(r, 0); ngx_http_cleanup_t* cleanup = ngx_http_cleanup_add(r, 0);
@@ -2157,6 +2163,13 @@ ngx_int_t ps_etag_header_filter(ngx_http_request_t* r) {
break; break;
} }
} }
ps_request_ctx_t* ctx = ps_get_request_context(r);
#if (NGX_HTTP_GZIP)
if (ctx && ctx->psol_vary_accept_only) {
r->gzip_vary = 0;
}
#endif
return ngx_http_ef_next_header_filter(r); return ngx_http_ef_next_header_filter(r);
} }
+1
View File
@@ -108,6 +108,7 @@ typedef struct {
// we should mirror that when we write it back. nginx may absolutify // we should mirror that when we write it back. nginx may absolutify
// Location: headers that start with '/' without regarding X-Forwarded-Proto. // Location: headers that start with '/' without regarding X-Forwarded-Proto.
bool location_field_set; bool location_field_set;
bool psol_vary_accept_only;
} ps_request_ctx_t; } ps_request_ctx_t;
ps_request_ctx_t* ps_get_request_context(ngx_http_request_t* r); ps_request_ctx_t* ps_get_request_context(ngx_http_request_t* r);
+16
View File
@@ -1249,6 +1249,22 @@ OUT=$(http_proxy=$SECONDARY_HOSTNAME $WGET_DUMP -O /dev/null -S $URL 2>&1) || tr
# We ignored the exit code, check if we got a 404 response. # We ignored the exit code, check if we got a 404 response.
check_from "$OUT" fgrep -qi '404' check_from "$OUT" fgrep -qi '404'
start_test Single Vary: Accept-Encoding header in IPRO flow
URL=http://psol-vary.example.com/mod_pagespeed_example/styles/index_style.css
OUT=$(http_proxy=$SECONDARY_HOSTNAME $WGET_DUMP -O /dev/null -S $URL 2>&1)
# First hit will be recorded and passed on untouched
MATCHES=$(echo "$OUT" | grep -c "Vary: Accept-Encoding") || true
check [ $MATCHES -eq 1 ]
# Fetch until we get a fully optimized response
http_proxy=$SECONDARY_HOSTNAME \
fetch_until $URL "fgrep -c W/\"PSA" 1 --save-headers
# Test the optimized response.
OUT=$(http_proxy=$SECONDARY_HOSTNAME $WGET_DUMP -O /dev/null -S $URL 2>&1)
MATCHES=$(echo "$OUT" | grep -c "Vary: Accept-Encoding") || true
check [ $MATCHES -eq 1 ]
start_test Shutting down. start_test Shutting down.
# Fire up some heavy load if ab is available to test a stressed shutdown # Fire up some heavy load if ab is available to test a stressed shutdown
+8
View File
@@ -1471,6 +1471,14 @@ http {
pagespeed GlobalAdminDomains pagespeed GlobalAdminDomains
Allow everything-explicitly-allowed.example.com; Allow everything-explicitly-allowed.example.com;
} }
server {
listen @@SECONDARY_PORT@@;
listen [::]:@@SECONDARY_PORT@@;
server_name psol-vary.example.com;
pagespeed on;
pagespeed InPlaceResourceOptimization on;
pagespeed FileCachePath "@@FILE_CACHE@@";
}
server { server {
listen @@PRIMARY_PORT@@; listen @@PRIMARY_PORT@@;