Mercurial > hg > nginx-vendor-0-5
comparison src/http/ngx_http_upstream_round_robin.c @ 328:26ff8d6b618d NGINX_0_5_34
nginx 0.5.34
*) Change: now the full request line instead of URI only is written to
error_log.
*) Feature: Cygwin compatibility.
Thanks to Vladimir Kutakov.
*) Feature: the "merge_slashes" directive.
*) Feature: the "gzip_vary" directive.
*) Feature: the "server_tokens" directive.
*) Feature: the "access_log" directive may be used inside the
"limit_except" block.
*) Bugfix: if the $server_protocol was used in FastCGI parameters and a
request line length was near to the "client_header_buffer_size"
directive value, then nginx issued an alert "fastcgi: the request
record is too big".
*) Bugfix: if a plain text HTTP/0.9 version request was made to HTTPS
server, then nginx returned usual response.
*) Bugfix: URL double escaping in a redirect of the "msie_refresh"
directive; bug appeared in 0.5.28.
*) Bugfix: a segmentation fault might occur in worker process if
subrequests were used.
*) Bugfix: the big responses may be transferred truncated if SSL and
gzip were used.
*) Bugfix: compatibility with mget.
*) Bugfix: nginx did not unescape URI in the "include" SSI command.
*) Bugfix: the segmentation fault was occurred on start or while
reconfiguration if variable was used in the "charset" or
"source_charset" directives.
*) Bugfix: nginx returned the 400 response on requests like
"GET http://www.domain.com HTTP/1.0".
Thanks to James Oakley.
*) Bugfix: a segmentation fault occurred in worker process if
$date_local and $date_gmt were used outside the
ngx_http_ssi_filter_module.
*) Bugfix: a segmentation fault might occur in worker process if debug
log was enabled.
Thanks to Andrei Nigmatulin.
*) Bugfix: ngx_http_memcached_module did not set
$upstream_response_time.
Thanks to Maxim Dounin.
*) Bugfix: a worker process may got caught in an endless loop, if the
memcached was used.
author | Igor Sysoev <http://sysoev.ru> |
---|---|
date | Thu, 13 Dec 2007 00:00:00 +0300 |
parents | 7cf404023f50 |
children |
comparison
equal
deleted
inserted
replaced
327:cb962a94cd7b | 328:26ff8d6b618d |
---|---|
71 ngx_memzero(&u, sizeof(ngx_url_t)); | 71 ngx_memzero(&u, sizeof(ngx_url_t)); |
72 | 72 |
73 u.host = us->host; | 73 u.host = us->host; |
74 u.port = (in_port_t) (us->port ? us->port : us->default_port); | 74 u.port = (in_port_t) (us->port ? us->port : us->default_port); |
75 | 75 |
76 if (ngx_inet_resolve_host(cf, &u) != NGX_OK) { | 76 if (ngx_inet_resolve_host(cf->pool, &u) != NGX_OK) { |
77 if (u.err) { | 77 if (u.err) { |
78 ngx_log_error(NGX_LOG_EMERG, cf->log, 0, | 78 ngx_log_error(NGX_LOG_EMERG, cf->log, 0, |
79 "%s in upstream \"%V\" in %s:%ui", | 79 "%s in upstream \"%V\" in %s:%ui", |
80 u.err, &us->host, us->file_name, us->line); | 80 u.err, &us->host, us->file_name, us->line); |
81 } | 81 } |
92 } | 92 } |
93 | 93 |
94 peers->number = n; | 94 peers->number = n; |
95 peers->name = &us->host; | 95 peers->name = &us->host; |
96 | 96 |
97 n = 0; | |
98 | |
99 for (i = 0; i < u.naddrs; i++) { | 97 for (i = 0; i < u.naddrs; i++) { |
100 peers->peer[n].sockaddr = u.addrs[i].sockaddr; | 98 peers->peer[i].sockaddr = u.addrs[i].sockaddr; |
101 peers->peer[n].socklen = u.addrs[i].socklen; | 99 peers->peer[i].socklen = u.addrs[i].socklen; |
102 peers->peer[n].name = u.addrs[i].name; | 100 peers->peer[i].name = u.addrs[i].name; |
103 peers->peer[n].weight = 1; | 101 peers->peer[i].weight = 1; |
104 peers->peer[n].current_weight = 1; | 102 peers->peer[i].current_weight = 1; |
105 peers->peer[n].max_fails = 1; | 103 peers->peer[i].max_fails = 1; |
106 peers->peer[n].fail_timeout = 10; | 104 peers->peer[i].fail_timeout = 10; |
107 n++; | |
108 } | 105 } |
109 | 106 |
110 us->peer.data = peers; | 107 us->peer.data = peers; |
111 | 108 |
112 return NGX_OK; | 109 return NGX_OK; |