]> git.kaiwu.me - nginx.git/commitdiff
Threads: fixed request hang with aio_write and subrequests.
authorMaxim Dounin <mdounin@mdounin.ru>
Tue, 28 Mar 2017 15:15:41 +0000 (18:15 +0300)
committerMaxim Dounin <mdounin@mdounin.ru>
Tue, 28 Mar 2017 15:15:41 +0000 (18:15 +0300)
If the subrequest is already finalized, the handler set with aio_write
may still be used by sendfile in threads when using range requests
(see also e4c1f5b32868, and the original note in 9fd738b85fad).  Calling
already finalized subrequest's r->write_event_handler in practice
results in request hang in some cases.

Fix is to trigger connection event handler if the subrequest was already
finalized.

src/http/ngx_http_upstream.c

index 14046935f13fd68dd4779819ca6d8562990cdd85..2725984c4cdf3b7d6473a5962d144b5628a7169e 100644 (file)
@@ -3736,9 +3736,19 @@ ngx_http_upstream_thread_event_handler(ngx_event_t *ev)
     r->main->blocked--;
     r->aio = 0;
 
-    r->write_event_handler(r);
+    if (r->done) {
+        /*
+         * trigger connection event handler if the subrequest was
+         * already finalized; this can happen if the handler is used
+         * for sendfile() in threads
+         */
 
-    ngx_http_run_posted_requests(c);
+        c->write->handler(c->write);
+
+    } else {
+        r->write_event_handler(r);
+        ngx_http_run_posted_requests(c);
+    }
 }
 
 #endif