Nginx-ru mailing list archive (nginx-ru@sysoev.ru)
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
Re: остаются файлы в proxy_temp_path
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
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,
|