]> git.kaiwu.me - nginx.git/commitdiff
Upstream: setting u->header_sent before ngx_http_upstream_upgrade().
authorMaxim Dounin <mdounin@mdounin.ru>
Fri, 30 Aug 2013 17:44:16 +0000 (21:44 +0400)
committerMaxim Dounin <mdounin@mdounin.ru>
Fri, 30 Aug 2013 17:44:16 +0000 (21:44 +0400)
Without u->header_sent set a special response might be generated following
an upgraded connection.  The problem appeared in 1ccdda1f37f3 (1.5.3).
Catched by "header already sent" alerts in 1.5.4 after upstream timeouts.

src/http/ngx_http_upstream.c

index 652222f8fecea7f8174316a6652958f864df56a5..f4221eddefd511f0f2caf4b3cad43c63fa1e23e7 100644 (file)
@@ -2105,6 +2105,8 @@ ngx_http_upstream_send_response(ngx_http_request_t *r, ngx_http_upstream_t *u)
         return;
     }
 
+    u->header_sent = 1;
+
     if (u->upgrade) {
         ngx_http_upstream_upgrade(r, u);
         return;
@@ -2131,8 +2133,6 @@ ngx_http_upstream_send_response(ngx_http_request_t *r, ngx_http_upstream_t *u)
         }
     }
 
-    u->header_sent = 1;
-
     if (r->request_body && r->request_body->temp_file) {
         ngx_pool_run_cleanup_file(r->pool, r->request_body->temp_file->file.fd);
         r->request_body->temp_file->file.fd = NGX_INVALID_FILE;