]> git.kaiwu.me - nginx.git/commitdiff
refactor log_subrequest
authorIgor Sysoev <igor@sysoev.ru>
Mon, 29 Sep 2008 13:18:41 +0000 (13:18 +0000)
committerIgor Sysoev <igor@sysoev.ru>
Mon, 29 Sep 2008 13:18:41 +0000 (13:18 +0000)
src/http/ngx_http_request.c
src/http/ngx_http_request.h

index 2be20aa0d8052ed43990292b27e72a1fae4d4c9a..e1f0ae7931e047d96489aa83a6c9541b005f0962 100644 (file)
@@ -1760,6 +1760,17 @@ ngx_http_finalize_request(ngx_http_request_t *r, ngx_int_t rc)
         return;
     }
 
+    clcf = ngx_http_get_module_loc_conf(r, ngx_http_core_module);
+
+    if (r != r->main && !r->logged) {
+
+        if (clcf->log_subrequest) {
+            ngx_http_log_request(r);
+        }
+
+        r->logged = 1;
+    }
+
     if (r != r->main || rc == NGX_AGAIN) {
         if (ngx_http_set_write_handler(r) != NGX_OK) {
             return;
@@ -1775,8 +1786,6 @@ ngx_http_finalize_request(ngx_http_request_t *r, ngx_int_t rc)
         return;
     }
 
-    clcf = ngx_http_get_module_loc_conf(r, ngx_http_core_module);
-
     if (r != r->main) {
 
         pr = r->parent;
@@ -1810,11 +1819,6 @@ ngx_http_finalize_request(ngx_http_request_t *r, ngx_int_t rc)
                 ngx_log_debug2(NGX_LOG_DEBUG_HTTP, c->log, 0,
                                "http fast subrequest: \"%V?%V\" done",
                                &r->uri, &r->args);
-
-                if (clcf->log_subrequest) {
-                    ngx_http_log_request(r);
-                }
-
                 return;
             }
 
@@ -1823,18 +1827,8 @@ ngx_http_finalize_request(ngx_http_request_t *r, ngx_int_t rc)
                                "http wake parent request: \"%V?%V\"",
                                &pr->uri, &pr->args);
 
-                if (clcf->log_subrequest) {
-                    ngx_http_log_request(r);
-                }
-
                 pr->write_event_handler(pr);
             }
-
-            return;
-        }
-
-        if (clcf->log_subrequest) {
-            ngx_http_log_request(r);
         }
 
         return;
index 636839805426dc021039196f5543691ae256ac45..2486ca5c0095b790d9e2779dbd616b1d6539a9dd 100644 (file)
@@ -464,6 +464,7 @@ struct ngx_http_request_s {
     unsigned                          expect_tested:1;
     unsigned                          root_tested:1;
     unsigned                          done:1;
+    unsigned                          logged:1;
     unsigned                          utf8:1;
 
     unsigned                          buffered:4;