diff options
author | Igor Sysoev <igor@sysoev.ru> | 2006-08-18 14:17:54 +0000 |
---|---|---|
committer | Igor Sysoev <igor@sysoev.ru> | 2006-08-18 14:17:54 +0000 |
commit | 5fede1e415ae97ee9221d60a1208d47bdaaae34d (patch) | |
tree | 22d4b4d8948e68926e1699b54b4d1bc325bfb0ec | |
parent | 51c53f9bf16804c9d8c9c55c45dc05ffeadda4b8 (diff) | |
download | nginx-release-0.3.60.tar.gz nginx-release-0.3.60.zip |
nginx-0.3.60-RELEASE importrelease-0.3.60
*) Bugfix: a worker process may got caught in an endless loop while an
error redirection; the bug had appeared in 0.3.59.
-rw-r--r-- | docs/xml/nginx/changes.xml | 17 | ||||
-rw-r--r-- | src/core/nginx.h | 2 | ||||
-rw-r--r-- | src/http/ngx_http_core_module.c | 16 | ||||
-rw-r--r-- | src/http/ngx_http_special_response.c | 3 |
4 files changed, 32 insertions, 6 deletions
diff --git a/docs/xml/nginx/changes.xml b/docs/xml/nginx/changes.xml index a2107508c..d2b792191 100644 --- a/docs/xml/nginx/changes.xml +++ b/docs/xml/nginx/changes.xml @@ -9,6 +9,23 @@ <title lang="en">nginx changelog</title> +<changes ver="0.3.60" date="18.08.2006"> + +<change type="bugfix"> +<para lang="ru"> +во время перенаправления ошибки рабочий процесс мог зациклиться; +ошибка появилась в 0.3.59. +</para> +<para lang="en"> +a worker process may got caught in an endless loop +while an error redirection; +bug appeared in 0.3.59. +</para> +</change> + +</changes> + + <changes ver="0.3.59" date="16.08.2006"> <change type="feature"> diff --git a/src/core/nginx.h b/src/core/nginx.h index 224fb70f8..1d417fed8 100644 --- a/src/core/nginx.h +++ b/src/core/nginx.h @@ -8,7 +8,7 @@ #define _NGINX_H_INCLUDED_ -#define NGINX_VER "nginx/0.3.59" +#define NGINX_VER "nginx/0.3.60" #define NGINX_VAR "NGINX" #define NGX_OLDPID_EXT ".oldbin" diff --git a/src/http/ngx_http_core_module.c b/src/http/ngx_http_core_module.c index b28931757..5c19167a9 100644 --- a/src/http/ngx_http_core_module.c +++ b/src/http/ngx_http_core_module.c @@ -507,7 +507,7 @@ ngx_http_handler(ngx_http_request_t *r) r->valid_location = 1; r->uri_changed = 1; - r->phase = (r == r->main) ? NGX_HTTP_POST_READ_PHASE: + r->phase = (!r->internal) ? NGX_HTTP_POST_READ_PHASE: NGX_HTTP_SERVER_REWRITE_PHASE; r->phase_handler = 0; @@ -1324,6 +1324,15 @@ ngx_http_internal_redirect(ngx_http_request_t *r, { ngx_http_core_srv_conf_t *cscf; + r->uri_changes--; + + if (r->uri_changes == 0) { + ngx_log_error(NGX_LOG_ERR, r->connection->log, 0, + "rewrite or internal redirection cycle"); + ngx_http_finalize_request(r, NGX_HTTP_INTERNAL_SERVER_ERROR); + return NGX_DONE; + } + r->uri = *uri; if (args) { @@ -1338,7 +1347,8 @@ ngx_http_internal_redirect(ngx_http_request_t *r, "internal redirect: \"%V?%V\"", uri, &r->args); if (ngx_http_set_exten(r) != NGX_OK) { - return NGX_HTTP_INTERNAL_SERVER_ERROR; + ngx_http_finalize_request(r, NGX_HTTP_INTERNAL_SERVER_ERROR); + return NGX_DONE; } /* clear the modules contexts */ @@ -1351,8 +1361,6 @@ ngx_http_internal_redirect(ngx_http_request_t *r, r->internal = 1; - r->uri_changes--; - ngx_http_handler(r); return NGX_DONE; diff --git a/src/http/ngx_http_special_response.c b/src/http/ngx_http_special_response.c index abdf62482..a44c51c6a 100644 --- a/src/http/ngx_http_special_response.c +++ b/src/http/ngx_http_special_response.c @@ -312,6 +312,7 @@ ngx_http_special_response_handler(ngx_http_request_t *r, ngx_int_t error) } r->headers_out.status = error; + r->err_status = error; if (r->keepalive != 0) { switch (error) { @@ -340,7 +341,7 @@ ngx_http_special_response_handler(ngx_http_request_t *r, ngx_int_t error) clcf = ngx_http_get_module_loc_conf(r, ngx_http_core_module); - if (clcf->error_pages) { + if (r->uri_changes && clcf->error_pages) { err_page = clcf->error_pages->elts; |