mirror of
https://github.com/nginx/nginx.git
synced 2025-01-22 06:13:10 -06:00
Upstream: http_403 support in proxy_next_upstream (and friends).
The parameter is mostly identical to http_404, and is expected to be used in similar situations. The 403 code might be returned by a backend instead of 404 on initial sync of new directories with rsync. See here for feature request and additional details: http://mailman.nginx.org/pipermail/nginx-ru/2013-April/050920.html
This commit is contained in:
parent
cc3c0ce870
commit
1a983a0c05
@ -185,6 +185,7 @@ static ngx_conf_bitmask_t ngx_http_fastcgi_next_upstream_masks[] = {
|
||||
{ ngx_string("invalid_header"), NGX_HTTP_UPSTREAM_FT_INVALID_HEADER },
|
||||
{ ngx_string("http_500"), NGX_HTTP_UPSTREAM_FT_HTTP_500 },
|
||||
{ ngx_string("http_503"), NGX_HTTP_UPSTREAM_FT_HTTP_503 },
|
||||
{ ngx_string("http_403"), NGX_HTTP_UPSTREAM_FT_HTTP_403 },
|
||||
{ ngx_string("http_404"), NGX_HTTP_UPSTREAM_FT_HTTP_404 },
|
||||
{ ngx_string("updating"), NGX_HTTP_UPSTREAM_FT_UPDATING },
|
||||
{ ngx_string("off"), NGX_HTTP_UPSTREAM_FT_OFF },
|
||||
|
@ -178,6 +178,7 @@ static ngx_conf_bitmask_t ngx_http_proxy_next_upstream_masks[] = {
|
||||
{ ngx_string("http_502"), NGX_HTTP_UPSTREAM_FT_HTTP_502 },
|
||||
{ ngx_string("http_503"), NGX_HTTP_UPSTREAM_FT_HTTP_503 },
|
||||
{ ngx_string("http_504"), NGX_HTTP_UPSTREAM_FT_HTTP_504 },
|
||||
{ ngx_string("http_403"), NGX_HTTP_UPSTREAM_FT_HTTP_403 },
|
||||
{ ngx_string("http_404"), NGX_HTTP_UPSTREAM_FT_HTTP_404 },
|
||||
{ ngx_string("updating"), NGX_HTTP_UPSTREAM_FT_UPDATING },
|
||||
{ ngx_string("off"), NGX_HTTP_UPSTREAM_FT_OFF },
|
||||
|
@ -65,6 +65,7 @@ static ngx_conf_bitmask_t ngx_http_scgi_next_upstream_masks[] = {
|
||||
{ ngx_string("invalid_header"), NGX_HTTP_UPSTREAM_FT_INVALID_HEADER },
|
||||
{ ngx_string("http_500"), NGX_HTTP_UPSTREAM_FT_HTTP_500 },
|
||||
{ ngx_string("http_503"), NGX_HTTP_UPSTREAM_FT_HTTP_503 },
|
||||
{ ngx_string("http_403"), NGX_HTTP_UPSTREAM_FT_HTTP_403 },
|
||||
{ ngx_string("http_404"), NGX_HTTP_UPSTREAM_FT_HTTP_404 },
|
||||
{ ngx_string("updating"), NGX_HTTP_UPSTREAM_FT_UPDATING },
|
||||
{ ngx_string("off"), NGX_HTTP_UPSTREAM_FT_OFF },
|
||||
|
@ -78,6 +78,7 @@ static ngx_conf_bitmask_t ngx_http_uwsgi_next_upstream_masks[] = {
|
||||
{ ngx_string("invalid_header"), NGX_HTTP_UPSTREAM_FT_INVALID_HEADER },
|
||||
{ ngx_string("http_500"), NGX_HTTP_UPSTREAM_FT_HTTP_500 },
|
||||
{ ngx_string("http_503"), NGX_HTTP_UPSTREAM_FT_HTTP_503 },
|
||||
{ ngx_string("http_403"), NGX_HTTP_UPSTREAM_FT_HTTP_403 },
|
||||
{ ngx_string("http_404"), NGX_HTTP_UPSTREAM_FT_HTTP_404 },
|
||||
{ ngx_string("updating"), NGX_HTTP_UPSTREAM_FT_UPDATING },
|
||||
{ ngx_string("off"), NGX_HTTP_UPSTREAM_FT_OFF },
|
||||
|
@ -369,6 +369,7 @@ static ngx_http_upstream_next_t ngx_http_upstream_next_errors[] = {
|
||||
{ 502, NGX_HTTP_UPSTREAM_FT_HTTP_502 },
|
||||
{ 503, NGX_HTTP_UPSTREAM_FT_HTTP_503 },
|
||||
{ 504, NGX_HTTP_UPSTREAM_FT_HTTP_504 },
|
||||
{ 403, NGX_HTTP_UPSTREAM_FT_HTTP_403 },
|
||||
{ 404, NGX_HTTP_UPSTREAM_FT_HTTP_404 },
|
||||
{ 0, 0 }
|
||||
};
|
||||
@ -3156,8 +3157,11 @@ ngx_http_upstream_next(ngx_http_request_t *r, ngx_http_upstream_t *u,
|
||||
|
||||
if (u->peer.sockaddr) {
|
||||
|
||||
if (ft_type == NGX_HTTP_UPSTREAM_FT_HTTP_404) {
|
||||
if (ft_type == NGX_HTTP_UPSTREAM_FT_HTTP_403
|
||||
|| ft_type == NGX_HTTP_UPSTREAM_FT_HTTP_404)
|
||||
{
|
||||
state = NGX_PEER_NEXT;
|
||||
|
||||
} else {
|
||||
state = NGX_PEER_FAILED;
|
||||
}
|
||||
@ -3189,6 +3193,10 @@ ngx_http_upstream_next(ngx_http_request_t *r, ngx_http_upstream_t *u,
|
||||
status = NGX_HTTP_INTERNAL_SERVER_ERROR;
|
||||
break;
|
||||
|
||||
case NGX_HTTP_UPSTREAM_FT_HTTP_403:
|
||||
status = NGX_HTTP_FORBIDDEN;
|
||||
break;
|
||||
|
||||
case NGX_HTTP_UPSTREAM_FT_HTTP_404:
|
||||
status = NGX_HTTP_NOT_FOUND;
|
||||
break;
|
||||
|
@ -24,10 +24,11 @@
|
||||
#define NGX_HTTP_UPSTREAM_FT_HTTP_502 0x00000020
|
||||
#define NGX_HTTP_UPSTREAM_FT_HTTP_503 0x00000040
|
||||
#define NGX_HTTP_UPSTREAM_FT_HTTP_504 0x00000080
|
||||
#define NGX_HTTP_UPSTREAM_FT_HTTP_404 0x00000100
|
||||
#define NGX_HTTP_UPSTREAM_FT_UPDATING 0x00000200
|
||||
#define NGX_HTTP_UPSTREAM_FT_BUSY_LOCK 0x00000400
|
||||
#define NGX_HTTP_UPSTREAM_FT_MAX_WAITING 0x00000800
|
||||
#define NGX_HTTP_UPSTREAM_FT_HTTP_403 0x00000100
|
||||
#define NGX_HTTP_UPSTREAM_FT_HTTP_404 0x00000200
|
||||
#define NGX_HTTP_UPSTREAM_FT_UPDATING 0x00000400
|
||||
#define NGX_HTTP_UPSTREAM_FT_BUSY_LOCK 0x00000800
|
||||
#define NGX_HTTP_UPSTREAM_FT_MAX_WAITING 0x00001000
|
||||
#define NGX_HTTP_UPSTREAM_FT_NOLIVE 0x40000000
|
||||
#define NGX_HTTP_UPSTREAM_FT_OFF 0x80000000
|
||||
|
||||
@ -35,6 +36,7 @@
|
||||
|NGX_HTTP_UPSTREAM_FT_HTTP_502 \
|
||||
|NGX_HTTP_UPSTREAM_FT_HTTP_503 \
|
||||
|NGX_HTTP_UPSTREAM_FT_HTTP_504 \
|
||||
|NGX_HTTP_UPSTREAM_FT_HTTP_403 \
|
||||
|NGX_HTTP_UPSTREAM_FT_HTTP_404)
|
||||
|
||||
#define NGX_HTTP_UPSTREAM_INVALID_HEADER 40
|
||||
|
Loading…
Reference in New Issue
Block a user