остаются файлы в proxy_temp_path

Igor Sysoev is at rambler-co.ru
Thu Dec 25 12:58:31 MSK 2008


On Thu, Dec 25, 2008 at 12:36:01PM +0300, Igor Sysoev wrote:

> On Thu, Dec 25, 2008 at 11:21:50AM +0300, Igor Sysoev wrote:
> 
> > On Thu, Dec 25, 2008 at 12:05:21AM +0300, Михаил Монашёв wrote:
> > 
> > > Здравствуйте, Михаил.
> > > 
> > > Скажите хоть, то, что файлы остаются - это нормально или нет?
> > 
> > Нет, это не нормально. Патч.
> 
> Нет, это нерпавильный патч. Проблему он, возможно, решает, но, на
> самом деле, есть специальный код, который должен удалять файл.
> Буду смотреть, почему он не работает.

Правильный патч. Файл не удалялся, если он был получен не полностью.


-- 
Игорь Сысоев
http://sysoev.ru
-------------- next part --------------
Index: src/http/ngx_http_upstream.c
===================================================================
--- src/http/ngx_http_upstream.c	(revision 1752)
+++ src/http/ngx_http_upstream.c	(working copy)
@@ -2201,6 +2201,7 @@
 static void
 ngx_http_upstream_process_request(ngx_http_request_t *r)
 {
+    ngx_uint_t            del;
     ngx_temp_file_t      *tf;
     ngx_event_pipe_t     *p;
     ngx_http_upstream_t  *u;
@@ -2212,20 +2213,25 @@
 
         if (u->store) {
 
+            del = p->upstream_error;
+
             tf = u->pipe->temp_file;
 
-            if (p->upstream_eof
-                && u->headers_in.status_n == NGX_HTTP_OK
-                && (u->headers_in.content_length_n == -1
-                    || (u->headers_in.content_length_n == tf->offset)))
-            {
-                ngx_http_upstream_store(r, u);
+            if (p->upstream_eof) {
 
-            } else if ((p->upstream_error
-                        || (p->upstream_eof
-                            && u->headers_in.status_n != NGX_HTTP_OK))
-                       && tf->file.fd != NGX_INVALID_FILE)
-            {
+                if (u->headers_in.status_n == NGX_HTTP_OK
+                    && (u->headers_in.content_length_n == -1
+                        || (u->headers_in.content_length_n == tf->offset)))
+                {
+                    ngx_http_upstream_store(r, u);
+
+                } else {
+                    del = 1;
+                }
+            }
+
+            if (del && tf->file.fd != NGX_INVALID_FILE) {
+
                 if (ngx_delete_file(tf->file.name.data) == NGX_FILE_ERROR) {
 
                     ngx_log_error(NGX_LOG_CRIT, r->connection->log, ngx_errno,


More information about the nginx-ru mailing list