Mercurial > hg > nginx-site
changeset 19:ed706d84e29c
nginx-1.0.6
author | Igor Sysoev <igor@sysoev.ru> |
---|---|
date | Mon, 29 Aug 2011 14:38:04 +0000 |
parents | 74438c570949 |
children | c1e6b2b4a758 |
files | text/en/CHANGES-1.0 text/ru/CHANGES.ru-1.0 xml/en/download.xml xml/index.xml xml/ru/download.xml xml/versions.xml |
diffstat | 6 files changed, 3025 insertions(+), 2971 deletions(-) [+] |
line wrap: on
line diff
--- a/text/en/CHANGES-1.0 Mon Aug 29 13:27:52 2011 +0000 +++ b/text/en/CHANGES-1.0 Mon Aug 29 14:38:04 2011 +0000 @@ -1,21 +1,62 @@ +Changes with nginx 1.0.6 29 Jul 2011 + + *) Feature: cache loader run time decrease. + + *) Feature: loading time decrease of configuration with large number of + HTTPS sites. + + *) Feature: now nginx supports ECDHE key exchange ciphers. + Thanks to Adrian Kotelba. + + *) Feature: the "lingering_close" directive. + + *) Feature: now shared zones and caches use POSIX semaphores on Solaris. + Thanks to Den Ivanov. + + *) Bugfix: nginx could not be built on Linux 3.0. + + *) Bugfix: a segmentation fault might occur in a worker process if + "fastcgi/scgi/uwsgi_param" directives were used with values starting + with "HTTP_"; the bug had appeared in 0.8.40. + + *) Bugfix: in closing connection for pipelined requests. + + *) Bugfix: nginx did not disable gzipping if client sent "gzip;q=0" in + "Accept-Encoding" request header line. + + *) Bugfix: in timeout in unbuffered proxied mode. + + *) Bugfix: memory leaks when a "proxy_pass" directive contains variables + and proxies to an HTTPS backend. + + *) Bugfix: in parameter validaiton of a "proxy_pass" directive with + variables. + Thanks to Lanshun Zhou. + + *) Bugfix: SSL did not work on QNX. + + *) Bugfix: SSL modules could not be built by gcc 4.6 without + --with-debug option. + + Changes with nginx 1.0.5 19 Jul 2011 *) Change: now default SSL ciphers are "HIGH:!aNULL:!MD5". Thanks to Rob Stradling. - *) Feature: the "referer_hash_max_size" and "referer_hash_bucket_size" + *) Feature: the "referer_hash_max_size" and "referer_hash_bucket_size" directives. Thanks to Witold Filipczyk. *) Feature: $uid_reset variable. - *) Bugfix: a segmentation fault might occur in a worker process, if a + *) Bugfix: a segmentation fault might occur in a worker process, if a caching was used. Thanks to Lanshun Zhou. - *) Bugfix: worker processes may got caught in an endless loop during - reconfiguration, if a caching was used; the bug had appeared in + *) Bugfix: worker processes may got caught in an endless loop during + reconfiguration, if a caching was used; the bug had appeared in 0.8.48. Thanks to Maxim Dounin. @@ -25,81 +66,81 @@ Changes with nginx 1.0.4 01 Jun 2011 - *) Change: now regular expressions case sensitivity in the "map" + *) Change: now regular expressions case sensitivity in the "map" directive is given by prefixes "~" or "~*". - *) Feature: now shared zones and caches use POSIX semaphores on Linux. + *) Feature: now shared zones and caches use POSIX semaphores on Linux. Thanks to Denis F. Latypoff. *) Bugfix: "stalled cache updating" alert. - *) Bugfix: nginx could not be built --without-http_auth_basic_module; + *) Bugfix: nginx could not be built --without-http_auth_basic_module; the bug had appeared in 1.0.3. Changes with nginx 1.0.3 25 May 2011 - *) Feature: the "auth_basic_user_file" directive supports "$apr1", + *) Feature: the "auth_basic_user_file" directive supports "$apr1", "{PLAIN}", and "{SSHA}" password encryption methods. Thanks to Maxim Dounin. *) Feature: the "geoip_org" directive and $geoip_org variable. Thanks to Alexander Uskov, Arnaud Granal, and Denis F. Latypoff. - *) Feature: ngx_http_geo_module and ngx_http_geoip_module support IPv4 + *) Feature: ngx_http_geo_module and ngx_http_geoip_module support IPv4 addresses mapped to IPv6 addresses. - *) Bugfix: a segmentation fault occurred in a worker process during - testing IPv4 address mapped to IPv6 address, if access or deny rules + *) Bugfix: a segmentation fault occurred in a worker process during + testing IPv4 address mapped to IPv6 address, if access or deny rules were defined only for IPv6; the bug had appeared in 0.8.22. - *) Bugfix: a cached response may be broken if "proxy/fastcgi/scgi/ - uwsgi_cache_bypass" and "proxy/fastcgi/scgi/uwsgi_no_cache" - directive values were different; the bug had appeared in 0.8.46. + *) Bugfix: a cached response may be broken if proxy/fastcgi/scgi/ + uwsgi_cache_bypass and proxy/fastcgi/scgi/uwsgi_no_cache directive + values were different; the bug had appeared in 0.8.46. Changes with nginx 1.0.2 10 May 2011 *) Feature: now shared zones and caches use POSIX semaphores. - *) Bugfix: in the "rotate" parameter of the "image_filter" directive. + *) Bugfix: in the "rotate" parameter of the "image_filter" directive. Thanks to Adam Bocim. - *) Bugfix: nginx could not be built on Solaris; the bug had appeared in + *) Bugfix: nginx could not be built on Solaris; the bug had appeared in 1.0.1. Changes with nginx 1.0.1 03 May 2011 - *) Change: now the "split_clients" directive uses MurmurHash2 algorithm + *) Change: now the "split_clients" directive uses MurmurHash2 algorithm because of better distribution. Thanks to Oleg Mamontov. - *) Change: now long strings starting with zero are not considered as + *) Change: now long strings starting with zero are not considered as false values. Thanks to Maxim Dounin. *) Change: now nginx uses a default listen backlog value 511 on Linux. - *) Feature: the $upstream_... variables may be used in the SSI and perl + *) Feature: the $upstream_... variables may be used in the SSI and perl modules. *) Bugfix: now nginx limits better disk cache size. Thanks to Oleg Mamontov. - *) Bugfix: a segmentation fault might occur while parsing incorrect - IPv4 address; the bug had appeared in 0.9.3. + *) Bugfix: a segmentation fault might occur while parsing incorrect IPv4 + address; the bug had appeared in 0.9.3. Thanks to Maxim Dounin. - *) Bugfix: nginx could not be built by gcc 4.6 without --with-debug + *) Bugfix: nginx could not be built by gcc 4.6 without --with-debug option. - *) Bugfix: nginx could not be built on Solaris 9 and earlier; the bug + *) Bugfix: nginx could not be built on Solaris 9 and earlier; the bug had appeared in 0.9.3. Thanks to Dagobert Michelsen. - *) Bugfix: $request_time variable had invalid values if subrequests - were used; the bug had appeared in 0.8.47. + *) Bugfix: $request_time variable had invalid values if subrequests were + used; the bug had appeared in 0.8.47. Thanks to Igor A. Valcov. @@ -108,7 +149,7 @@ *) Bugfix: a cache manager might hog CPU after reload. Thanks to Maxim Dounin. - *) Bugfix: an "image_filter crop" directive worked incorrectly coupled + *) Bugfix: an "image_filter crop" directive worked incorrectly coupled with an "image_filter rotate 180" directive. *) Bugfix: a "satisfy any" directive disabled custom 401 error page. @@ -116,22 +157,22 @@ Changes with nginx 0.9.7 04 Apr 2011 - *) Feature: now keepalive connections may be closed premature, if there + *) Feature: now keepalive connections may be closed premature, if there are no free worker connections. Thanks to Maxim Dounin. *) Feature: the "rotate" parameter of the "image_filter" directive. Thanks to Adam Bocim. - *) Bugfix: a case when a backend in "fastcgi_pass", "scgi_pass", or - "uwsgi_pass" directives is given by expression and refers to a + *) Bugfix: a case when a backend in "fastcgi_pass", "scgi_pass", or + "uwsgi_pass" directives is given by expression and refers to a defined upstream. Changes with nginx 0.9.6 21 Mar 2011 - *) Feature: the "map" directive supports regular expressions as value - of the first parameter. + *) Feature: the "map" directive supports regular expressions as value of + the first parameter. *) Feature: $time_iso8601 access_log variable. Thanks to Michael Lustfield. @@ -139,19 +180,19 @@ Changes with nginx 0.9.5 21 Feb 2011 - *) Change: now nginx uses a default listen backlog value -1 on Linux. + *) Change: now nginx uses a default listen backlog value -1 on Linux. Thanks to Andrei Nigmatulin. - *) Feature: the "utf8" parameter of "geoip_country" and "geoip_city" + *) Feature: the "utf8" parameter of "geoip_country" and "geoip_city" directives. Thanks to Denis F. Latypoff. - *) Bugfix: in a default "proxy_redirect" directive if "proxy_pass" + *) Bugfix: in a default "proxy_redirect" directive if "proxy_pass" directive has no URI part. Thanks to Maxim Dounin. - *) Bugfix: an "error_page" directive did not work with nonstandard - error codes; the bug had appeared in 0.8.53. + *) Bugfix: an "error_page" directive did not work with nonstandard error + codes; the bug had appeared in 0.8.53. Thanks to Maxim Dounin. @@ -164,23 +205,23 @@ Changes with nginx 0.9.3 13 Dec 2010 - *) Bugfix: if there was a single server for given IPv6 address:port - pair, then captures in regular expressions in a "server_name" + *) Bugfix: if there was a single server for given IPv6 address:port + pair, then captures in regular expressions in a "server_name" directive did not work. - *) Bugfix: nginx could not be built on Solaris; the bug had appeared in + *) Bugfix: nginx could not be built on Solaris; the bug had appeared in 0.9.0. Changes with nginx 0.9.2 06 Dec 2010 - *) Feature: the "If-Unmodified-Since" client request header line + *) Feature: the "If-Unmodified-Since" client request header line support. - *) Workaround: fallback to accept() syscall if accept4() was not + *) Workaround: fallback to accept() syscall if accept4() was not implemented; the issue had appeared in 0.9.0. - *) Bugfix: nginx could not be built on Cygwin; the bug had appeared in + *) Bugfix: nginx could not be built on Cygwin; the bug had appeared in 0.9.0. *) Bugfix: for OpenSSL vulnerability CVE-2010-4180. @@ -189,7 +230,7 @@ Changes with nginx 0.9.1 30 Nov 2010 - *) Bugfix: "return CODE message" directives did not work; the bug had + *) Bugfix: "return CODE message" directives did not work; the bug had appeared in 0.9.0. @@ -197,13 +238,13 @@ *) Feature: the "keepalive_disable" directive. - *) Feature: the "map" directive supports variables as value of a - defined variable. - - *) Feature: the "map" directive supports empty strings as value of the + *) Feature: the "map" directive supports variables as value of a defined + variable. + + *) Feature: the "map" directive supports empty strings as value of the first parameter. - *) Feature: the "map" directive supports expressions as the first + *) Feature: the "map" directive supports expressions as the first parameter. *) Feature: nginx(8) manual page. @@ -212,36 +253,36 @@ *) Feature: Linux accept4() support. Thanks to Simon Liu. - *) Workaround: elimination of Linux linker warning about "sys_errlist" + *) Workaround: elimination of Linux linker warning about "sys_errlist" and "sys_nerr"; the warning had appeared in 0.8.35. - *) Bugfix: a segmentation fault might occur in a worker process, if the + *) Bugfix: a segmentation fault might occur in a worker process, if the "auth_basic" directive was used. Thanks to Michail Laletin. - *) Bugfix: compatibility with ngx_http_eval_module; the bug had - appeared in 0.8.42. + *) Bugfix: compatibility with ngx_http_eval_module; the bug had appeared + in 0.8.42. Changes with nginx 0.8.53 18 Oct 2010 - *) Feature: now the "error_page" directive allows to change a status + *) Feature: now the "error_page" directive allows to change a status code in a redirect. - *) Feature: the "gzip_disable" directive supports special "degradation" + *) Feature: the "gzip_disable" directive supports special "degradation" mask. *) Bugfix: a socket leak might occurred if file AIO was used. Thanks to Maxim Dounin. - *) Bugfix: if the first server had no "listen" directive and there was - no explicit default server, then a next server with a "listen" + *) Bugfix: if the first server had no "listen" directive and there was + no explicit default server, then a next server with a "listen" directive became the default server; the bug had appeared in 0.8.21. Changes with nginx 0.8.52 28 Sep 2010 - *) Bugfix: nginx used SSL mode for a listen socket if any listen option + *) Bugfix: nginx used SSL mode for a listen socket if any listen option was set; the bug had appeared in 0.8.51. @@ -249,75 +290,75 @@ *) Change: the "secure_link_expires" directive has been canceled. - *) Change: a logging level of resolver errors has been lowered from + *) Change: a logging level of resolver errors has been lowered from "alert" to "error". - *) Feature: now a listen socket "ssl" parameter may be set several + *) Feature: now a listen socket "ssl" parameter may be set several times. Changes with nginx 0.8.50 02 Sep 2010 - *) Feature: the "secure_link", "secure_link_md5", and + *) Feature: the "secure_link", "secure_link_md5", and "secure_link_expires" directives of the ngx_http_secure_link_module. *) Feature: the -q switch. Thanks to Gena Makhomed. - *) Bugfix: worker processes may got caught in an endless loop during - reconfiguration, if a caching was used; the bug had appeared in + *) Bugfix: worker processes may got caught in an endless loop during + reconfiguration, if a caching was used; the bug had appeared in 0.8.48. *) Bugfix: in the "gzip_disable" directive. Thanks to Derrick Petzold. - *) Bugfix: nginx/Windows could not send stop, quit, reopen, and reload + *) Bugfix: nginx/Windows could not send stop, quit, reopen, and reload signals to a process run in other session. Changes with nginx 0.8.49 09 Aug 2010 - *) Feature: the "image_filter_jpeg_quality" directive supports + *) Feature: the "image_filter_jpeg_quality" directive supports variables. - *) Bugfix: a segmentation fault might occur in a worker process, if the - $geoip_region_name variables was used; the bug had appeared in + *) Bugfix: a segmentation fault might occur in a worker process, if the + $geoip_region_name variables was used; the bug had appeared in 0.8.48. - *) Bugfix: errors intercepted by error_page were cached only for next + *) Bugfix: errors intercepted by error_page were cached only for next request; the bug had appeared in 0.8.48. Changes with nginx 0.8.48 03 Aug 2010 - *) Change: now the "server_name" directive default value is an empty + *) Change: now the "server_name" directive default value is an empty name "". Thanks to Gena Makhomed. - *) Change: now the "server_name_in_redirect" directive default value is + *) Change: now the "server_name_in_redirect" directive default value is "off". - *) Feature: the $geoip_dma_code, $geoip_area_code, and + *) Feature: the $geoip_dma_code, $geoip_area_code, and $geoip_region_name variables. Thanks to Christine McGonagle. - *) Bugfix: the "proxy_pass", "fastcgi_pass", "uwsgi_pass", and - "scgi_pass" directives were not inherited inside "limit_except" + *) Bugfix: the "proxy_pass", "fastcgi_pass", "uwsgi_pass", and + "scgi_pass" directives were not inherited inside "limit_except" blocks. - *) Bugfix: the "proxy_cache_min_uses", "fastcgi_cache_min_uses" - "uwsgi_cache_min_uses", and "scgi_cache_min_uses" directives did not + *) Bugfix: the "proxy_cache_min_uses", "fastcgi_cache_min_uses" + "uwsgi_cache_min_uses", and "scgi_cache_min_uses" directives did not work; the bug had appeared in 0.8.46. - *) Bugfix: the "fastcgi_split_path_info" directive used incorrectly + *) Bugfix: the "fastcgi_split_path_info" directive used incorrectly captures, if only parts of an URI were captured. Thanks to Yuriy Taraday and Frank Enderle. - *) Bugfix: the "rewrite" directive did not escape a ";" character - during copying from URI to query string. + *) Bugfix: the "rewrite" directive did not escape a ";" character during + copying from URI to query string. Thanks to Daisuke Murase. - *) Bugfix: the ngx_http_image_filter_module closed a connection, if an + *) Bugfix: the ngx_http_image_filter_module closed a connection, if an image was larger than "image_filter_buffer" size. @@ -327,22 +368,22 @@ *) Bugfix: errors intercepted by error_page could not be cached. - *) Bugfix: a cache manager process may got caught in an endless loop, - if max_size parameter was used; the bug had appeared in 0.8.46. + *) Bugfix: a cache manager process may got caught in an endless loop, if + max_size parameter was used; the bug had appeared in 0.8.46. Changes with nginx 0.8.46 19 Jul 2010 - *) Change: now the "proxy_no_cache", "fastcgi_no_cache", - "uwsgi_no_cache", and "scgi_no_cache" directives affect on a cached + *) Change: now the "proxy_no_cache", "fastcgi_no_cache", + "uwsgi_no_cache", and "scgi_no_cache" directives affect on a cached response saving only. - *) Feature: the "proxy_cache_bypass", "fastcgi_cache_bypass", + *) Feature: the "proxy_cache_bypass", "fastcgi_cache_bypass", "uwsgi_cache_bypass", and "scgi_cache_bypass" directives. - *) Bugfix: nginx did not free memory in cache keys zones if there was - an error during working with backend: the memory was freed only - after inactivity time or on memory low condition. + *) Bugfix: nginx did not free memory in cache keys zones if there was an + error during working with backend: the memory was freed only after + inactivity time or on memory low condition. Changes with nginx 0.8.45 13 Jul 2010 @@ -350,23 +391,23 @@ *) Feature: ngx_http_xslt_filter improvements. Thanks to Laurence Rowe. - *) Bugfix: SSI response might be truncated after include with + *) Bugfix: SSI response might be truncated after include with wait="yes"; the bug had appeared in 0.7.25. Thanks to Maxim Dounin. - *) Bugfix: the "listen" directive did not support the "setfib=0" + *) Bugfix: the "listen" directive did not support the "setfib=0" parameter. Changes with nginx 0.8.44 05 Jul 2010 - *) Change: now nginx does not cache by default backend responses, if + *) Change: now nginx does not cache by default backend responses, if they have a "Set-Cookie" header line. *) Feature: the "listen" directive supports the "setfib" parameter. Thanks to Andrew Filonov. - *) Bugfix: the "sub_filter" directive might change character case on + *) Bugfix: the "sub_filter" directive might change character case on partial match. *) Bugfix: compatibility with HP/UX. @@ -381,22 +422,21 @@ *) Feature: large geo ranges base loading speed-up. - *) Bugfix: an error_page redirection to "location /zero {return 204;}" - without changing status code kept the error body; the bug had + *) Bugfix: an error_page redirection to "location /zero {return 204;}" + without changing status code kept the error body; the bug had appeared in 0.8.42. - *) Bugfix: nginx might close IPv6 listen socket during - reconfiguration. + *) Bugfix: nginx might close IPv6 listen socket during reconfiguration. Thanks to Maxim Dounin. - *) Bugfix: the $uid_set variable may be used at any request processing + *) Bugfix: the $uid_set variable may be used at any request processing stage. Changes with nginx 0.8.42 21 Jun 2010 - *) Change: now nginx tests locations given by regular expressions, if - request was matched exactly by a location given by a prefix string. + *) Change: now nginx tests locations given by regular expressions, if + request was matched exactly by a location given by a prefix string. The previous behavior has been introduced in 0.7.1. *) Feature: the ngx_http_scgi_module. @@ -407,17 +447,17 @@ Changes with nginx 0.8.41 15 Jun 2010 - *) Security: nginx/Windows worker might be terminated abnormally if a + *) Security: nginx/Windows worker might be terminated abnormally if a requested file name has invalid UTF-8 encoding. *) Change: now nginx allows to use spaces in a request line. - *) Bugfix: the "proxy_redirect" directive changed incorrectly a backend + *) Bugfix: the "proxy_redirect" directive changed incorrectly a backend "Refresh" response header line. Thanks to Andrey Andreew and Max Sogin. - *) Bugfix: nginx did not support path without host name in - "Destination" request header line. + *) Bugfix: nginx did not support path without host name in "Destination" + request header line. Changes with nginx 0.8.40 07 Jun 2010 @@ -428,26 +468,26 @@ *) Feature: the ngx_http_uwsgi_module. Thanks to Roberto De Ioris. - *) Feature: a "fastcgi_param" directive with value starting with - "HTTP_" overrides a client request header line. - - *) Bugfix: the "If-Modified-Since", "If-Range", etc. client request + *) Feature: a "fastcgi_param" directive with value starting with "HTTP_" + overrides a client request header line. + + *) Bugfix: the "If-Modified-Since", "If-Range", etc. client request header lines were passed to FastCGI-server while caching. - *) Bugfix: listen unix domain socket could not be changed during + *) Bugfix: listen unix domain socket could not be changed during reconfiguration. Thanks to Maxim Dounin. Changes with nginx 0.8.39 31 May 2010 - *) Bugfix: an inherited "alias" directive worked incorrectly in + *) Bugfix: an inherited "alias" directive worked incorrectly in inclusive location. - *) Bugfix: in "alias" with variables and "try_files" directives + *) Bugfix: in "alias" with variables and "try_files" directives combination. - *) Bugfix: listen unix domain and IPv6 sockets did not inherit while + *) Bugfix: listen unix domain and IPv6 sockets did not inherit while online upgrade. Thanks to Maxim Dounin. @@ -456,15 +496,15 @@ *) Feature: the "proxy_no_cache" and "fastcgi_no_cache" directives. - *) Feature: now the "rewrite" directive does a redirect automatically - if the $scheme variable is used. + *) Feature: now the "rewrite" directive does a redirect automatically if + the $scheme variable is used. Thanks to Piotr Sikora. - *) Bugfix: now "limit_req" delay directive conforms to the described + *) Bugfix: now "limit_req" delay directive conforms to the described algorithm. Thanks to Maxim Dounin. - *) Bugfix: the $uid_got variable might not be used in the SSI and perl + *) Bugfix: the $uid_got variable might not be used in the SSI and perl modules. @@ -474,31 +514,31 @@ *) Feature: the "map" directive supports keys more than 255 characters. - *) Bugfix: nginx ignored the "private" and "no-store" values in the + *) Bugfix: nginx ignored the "private" and "no-store" values in the "Cache-Control" backend response header line. - *) Bugfix: a "stub" parameter of an "include" SSI directive was not + *) Bugfix: a "stub" parameter of an "include" SSI directive was not used, if empty response has 200 status code. - *) Bugfix: if a proxied or FastCGI request was internally redirected to - another proxied or FastCGI location, then a segmentation fault might + *) Bugfix: if a proxied or FastCGI request was internally redirected to + another proxied or FastCGI location, then a segmentation fault might occur in a worker process; the bug had appeared in 0.8.33. Thanks to Yichun Zhang. - *) Bugfix: IMAP connections may hang until they timed out while talking + *) Bugfix: IMAP connections may hang until they timed out while talking to Zimbra server. Thanks to Alan Batie. Changes with nginx 0.8.36 22 Apr 2010 - *) Bugfix: the ngx_http_dav_module handled incorrectly the DELETE, - COPY, and MOVE methods for symlinks. - - *) Bugfix: values of the $query_string, $arg_..., etc. variables cached + *) Bugfix: the ngx_http_dav_module handled incorrectly the DELETE, COPY, + and MOVE methods for symlinks. + + *) Bugfix: values of the $query_string, $arg_..., etc. variables cached in main request were used by the SSI module in subrequests. - *) Bugfix: a variable value was repeatedly encoded after each an "echo" + *) Bugfix: a variable value was repeatedly encoded after each an "echo" SSI-command output; the bug had appeared in 0.6.14. *) Bugfix: a worker process hung if a FIFO file was requested. @@ -507,7 +547,7 @@ *) Bugfix: OpenSSL-1.0.0 compatibility on 64-bit Linux. Thanks to Maxim Dounin. - *) Bugfix: nginx could not be built --without-http-cache; the bug had + *) Bugfix: nginx could not be built --without-http-cache; the bug had appeared in 0.8.35. @@ -517,60 +557,60 @@ *) Feature: the "chunked_transfer_encoding" directive. - *) Bugfix: an "&" character was not escaped when it was copied in + *) Bugfix: an "&" character was not escaped when it was copied in arguments part in a rewrite rule. - *) Bugfix: nginx might be terminated abnormally while a signal - processing or if the directive "timer_resolution" was used on - platforms which do not support kqueue or eventport notification + *) Bugfix: nginx might be terminated abnormally while a signal + processing or if the directive "timer_resolution" was used on + platforms which do not support kqueue or eventport notification methods. Thanks to George Xie and Maxim Dounin. - *) Bugfix: if temporary files and permanent storage area resided at - different file systems, then permanent file modification times were + *) Bugfix: if temporary files and permanent storage area resided at + different file systems, then permanent file modification times were incorrect. Thanks to Maxim Dounin. - *) Bugfix: ngx_http_memcached_module might issue the error message + *) Bugfix: ngx_http_memcached_module might issue the error message "memcached sent invalid trailer". Thanks to Maxim Dounin. - *) Bugfix: nginx could not built zlib-1.2.4 library using the library + *) Bugfix: nginx could not built zlib-1.2.4 library using the library sources. Thanks to Maxim Dounin. - *) Bugfix: a segmentation fault occurred in a worker process, if there - was large stderr output before FastCGI response; the bug had - appeared in 0.8.34. + *) Bugfix: a segmentation fault occurred in a worker process, if there + was large stderr output before FastCGI response; the bug had appeared + in 0.8.34. Thanks to Maxim Dounin. Changes with nginx 0.8.34 03 Mar 2010 - *) Bugfix: nginx did not support all ciphers and digests used in client + *) Bugfix: nginx did not support all ciphers and digests used in client certificates. Thanks to Innocenty Enikeew. - *) Bugfix: nginx cached incorrectly FastCGI responses if there was - large stderr output before response. + *) Bugfix: nginx cached incorrectly FastCGI responses if there was large + stderr output before response. *) Bugfix: nginx did not support HTTPS referrers. - *) Bugfix: nginx/Windows might not find file if path in configuration + *) Bugfix: nginx/Windows might not find file if path in configuration was given in other character case; the bug had appeared in 0.8.33. - *) Bugfix: the $date_local variable has an incorrect value, if the "%s" + *) Bugfix: the $date_local variable has an incorrect value, if the "%s" format was used. Thanks to Maxim Dounin. - *) Bugfix: if ssl_session_cache was not set or was set to "none", then - during client certificate verify the error "session id context + *) Bugfix: if ssl_session_cache was not set or was set to "none", then + during client certificate verify the error "session id context uninitialized" might occur; the bug had appeared in 0.7.1. - *) Bugfix: a geo range returned default value if the range included two + *) Bugfix: a geo range returned default value if the range included two or more /16 networks and did not begin at /16 network boundary. - *) Bugfix: a block used in a "stub" parameter of an "include" SSI + *) Bugfix: a block used in a "stub" parameter of an "include" SSI directive was output with "text/plain" MIME type. *) Bugfix: $r->sleep() did not work; the bug had appeared in 0.8.11. @@ -584,19 +624,19 @@ *) Security: now nginx/Windows ignores short files names. Thanks to Dan Crowley, Core Security Technologies. - *) Change: now keepalive connections after POST requests are not + *) Change: now keepalive connections after POST requests are not disabled for MSIE 7.0+. Thanks to Adam Lounds. *) Workaround: now keepalive connections are disabled for Safari. Thanks to Joshua Sierles. - *) Bugfix: if a proxied or FastCGI request was internally redirected to - another proxied or FastCGI location, then $upstream_response_time - variable may have abnormally large value; the bug had appeared in + *) Bugfix: if a proxied or FastCGI request was internally redirected to + another proxied or FastCGI location, then $upstream_response_time + variable may have abnormally large value; the bug had appeared in 0.8.7. - *) Bugfix: a segmentation fault might occur in a worker process, while + *) Bugfix: a segmentation fault might occur in a worker process, while discarding a request body; the bug had appeared in 0.8.11. @@ -605,68 +645,68 @@ *) Bugfix: UTF-8 encoding usage in the ngx_http_autoindex_module. Thanks to Maxim Dounin. - *) Bugfix: regular expression named captures worked for two names only. + *) Bugfix: regular expression named captures worked for two names only. Thanks to Maxim Dounin. - *) Bugfix: now the "localhost" name is used in the "Host" request - header line, if an unix domain socket is defined in the "auth_http" + *) Bugfix: now the "localhost" name is used in the "Host" request header + line, if an unix domain socket is defined in the "auth_http" directive. Thanks to Maxim Dounin. - *) Bugfix: nginx did not support chunked transfer encoding for 201 + *) Bugfix: nginx did not support chunked transfer encoding for 201 responses. Thanks to Julian Reich. - *) Bugfix: if the "expires modified" set date in the past, then a - negative number was set in the "Cache-Control" response header line. + *) Bugfix: if the "expires modified" set date in the past, then a + negative number was set in the "Cache-Control" response header line. Thanks to Alex Kapranoff. Changes with nginx 0.8.31 23 Dec 2009 - *) Feature: now the "error_page" directive may redirect the 301 and 302 + *) Feature: now the "error_page" directive may redirect the 301 and 302 responses. - *) Feature: the $geoip_city_continent_code, $geoip_latitude, and + *) Feature: the $geoip_city_continent_code, $geoip_latitude, and $geoip_longitude variables. Thanks to Arvind Sundararajan. - *) Feature: now the ngx_http_image_filter_module deletes always EXIF - and other application specific data if the data consume more than 5% - of a JPEG file. - - *) Bugfix: nginx closed a connection if a cached response had an empty + *) Feature: now the ngx_http_image_filter_module deletes always EXIF and + other application specific data if the data consume more than 5% of a + JPEG file. + + *) Bugfix: nginx closed a connection if a cached response had an empty body. Thanks to Piotr Sikora. - *) Bugfix: nginx might not be built by gcc 4.x if the -O2 or higher + *) Bugfix: nginx might not be built by gcc 4.x if the -O2 or higher optimization option was used. Thanks to Maxim Dounin and Denis F. Latypoff. - *) Bugfix: regular expressions in location were always tested in + *) Bugfix: regular expressions in location were always tested in case-sensitive mode; the bug had appeared in 0.8.25. - *) Bugfix: nginx cached a 304 response if there was the "If-None-Match" + *) Bugfix: nginx cached a 304 response if there was the "If-None-Match" header line in a proxied request. Thanks to Tim Dettrick and David Kostal. - *) Bugfix: nginx/Windows tried to delete a temporary file twice if the + *) Bugfix: nginx/Windows tried to delete a temporary file twice if the file should replace an already existent file. Changes with nginx 0.8.30 15 Dec 2009 - *) Change: now the default buffer size of the + *) Change: now the default buffer size of the "large_client_header_buffers" directive is 8K. Thanks to Andrew Cholakian. *) Feature: the conf/fastcgi.conf for simple FastCGI configurations. - *) Bugfix: nginx/Windows tried to rename a temporary file twice if the + *) Bugfix: nginx/Windows tried to rename a temporary file twice if the file should replace an already existent file. - *) Bugfix: of "double free or corruption" error issued if host could - not be resolved; the bug had appeared in 0.8.22. + *) Bugfix: of "double free or corruption" error issued if host could not + be resolved; the bug had appeared in 0.8.22. Thanks to Konstantin Svist. *) Bugfix: in libatomic usage on some platforms. @@ -675,11 +715,11 @@ Changes with nginx 0.8.29 30 Nov 2009 - *) Change: now the "009" status code is written to an access log for + *) Change: now the "009" status code is written to an access log for proxied HTTP/0.9 responses. - *) Feature: the "addition_types", "charset_types", "gzip_types", - "ssi_types", "sub_filter_types", and "xslt_types" directives support + *) Feature: the "addition_types", "charset_types", "gzip_types", + "ssi_types", "sub_filter_types", and "xslt_types" directives support an "*" parameter. *) Feature: GCC 4.1+ built-in atomic operations usage. @@ -692,63 +732,63 @@ *) Bugfix: cached HTTP/0.9 responses were handled incorrectly. - *) Bugfix: regular expression named captures given by "?P<...>" did not + *) Bugfix: regular expression named captures given by "?P<...>" did not work in a "server_name" directive. Thanks to Maxim Dounin. Changes with nginx 0.8.28 23 Nov 2009 - *) Bugfix: nginx could not be built with the --without-pcre parameter; + *) Bugfix: nginx could not be built with the --without-pcre parameter; the bug had appeared in 0.8.25. Changes with nginx 0.8.27 17 Nov 2009 - *) Bugfix: regular expressions did not work in nginx/Windows; the bug + *) Bugfix: regular expressions did not work in nginx/Windows; the bug had appeared in 0.8.25. Changes with nginx 0.8.26 16 Nov 2009 - *) Bugfix: in captures usage in "rewrite" directive; the bug had + *) Bugfix: in captures usage in "rewrite" directive; the bug had appeared in 0.8.25. - *) Bugfix: nginx could not be built without the --with-debug option; - the bug had appeared in 0.8.25. + *) Bugfix: nginx could not be built without the --with-debug option; the + bug had appeared in 0.8.25. Changes with nginx 0.8.25 16 Nov 2009 - *) Change: now no message is written in an error log if a variable is + *) Change: now no message is written in an error log if a variable is not found by $r->variable() method. *) Feature: the ngx_http_degradation_module. *) Feature: regular expression named captures. - *) Feature: now URI part is not required a "proxy_pass" directive if + *) Feature: now URI part is not required a "proxy_pass" directive if variables are used. *) Feature: now the "msie_padding" directive works for Chrome too. - *) Bugfix: a segmentation fault occurred in a worker process on low + *) Bugfix: a segmentation fault occurred in a worker process on low memory condition; the bug had appeared in 0.8.18. - *) Bugfix: nginx sent gzipped responses to clients those do not support - gzip, if "gzip_static on" and "gzip_vary off"; the bug had appeared + *) Bugfix: nginx sent gzipped responses to clients those do not support + gzip, if "gzip_static on" and "gzip_vary off"; the bug had appeared in 0.8.16. Changes with nginx 0.8.24 11 Nov 2009 - *) Bugfix: nginx always added "Content-Encoding: gzip" response header + *) Bugfix: nginx always added "Content-Encoding: gzip" response header line in 304 responses sent by ngx_http_gzip_static_module. - *) Bugfix: nginx could not be built without the --with-debug option; - the bug had appeared in 0.8.23. - - *) Bugfix: the "unix:" parameter of the "set_real_ip_from" directive + *) Bugfix: nginx could not be built without the --with-debug option; the + bug had appeared in 0.8.23. + + *) Bugfix: the "unix:" parameter of the "set_real_ip_from" directive inherited incorrectly from previous level. *) Bugfix: in resolving empty name. @@ -759,11 +799,11 @@ *) Security: now SSL/TLS renegotiation is disabled. Thanks to Maxim Dounin. - *) Bugfix: listen unix domain socket did not inherit while online + *) Bugfix: listen unix domain socket did not inherit while online upgrade. - *) Bugfix: the "unix:" parameter of the "set_real_ip_from" directive - did not without yet another directive with any IP address. + *) Bugfix: the "unix:" parameter of the "set_real_ip_from" directive did + not without yet another directive with any IP address. *) Bugfix: segmentation fault and infinite looping in resolver. @@ -773,17 +813,17 @@ Changes with nginx 0.8.22 03 Nov 2009 - *) Feature: the "proxy_bind", "fastcgi_bind", and "memcached_bind" + *) Feature: the "proxy_bind", "fastcgi_bind", and "memcached_bind" directives. *) Feature: the "access" and the "deny" directives support IPv6. - *) Feature: the "set_real_ip_from" directive supports IPv6 addresses in + *) Feature: the "set_real_ip_from" directive supports IPv6 addresses in request headers. *) Feature: the "unix:" parameter of the "set_real_ip_from" directive. - *) Bugfix: nginx did not delete unix domain socket after configuration + *) Bugfix: nginx did not delete unix domain socket after configuration testing. *) Bugfix: nginx deleted unix domain socket while online upgrade. @@ -791,16 +831,16 @@ *) Bugfix: the "!-x" operator did not work. Thanks to Maxim Dounin. - *) Bugfix: a segmentation fault might occur in a worker process, if + *) Bugfix: a segmentation fault might occur in a worker process, if limit_rate was used in HTTPS server. Thanks to Maxim Dounin. - *) Bugfix: a segmentation fault might occur in a worker process while + *) Bugfix: a segmentation fault might occur in a worker process while $limit_rate logging. Thanks to Maxim Dounin. - *) Bugfix: a segmentation fault might occur in a worker process, if - there was no "listen" directive in "server" block; the bug had + *) Bugfix: a segmentation fault might occur in a worker process, if + there was no "listen" directive in "server" block; the bug had appeared in 0.8.21. @@ -808,13 +848,13 @@ *) Feature: now the "-V" switch shows TLS SNI support. - *) Feature: the "listen" directive of the HTTP module supports unix + *) Feature: the "listen" directive of the HTTP module supports unix domain sockets. Thanks to Hongli Lai. *) Feature: the "default_server" parameter of the "listen" directive. - *) Feature: now a "default" parameter is not required to set listen + *) Feature: now a "default" parameter is not required to set listen socket options. *) Bugfix: nginx did not support dates in 2038 year on 32-bit platforms; @@ -826,22 +866,22 @@ *) Change: now default SSL ciphers are "HIGH:!ADH:!MD5". - *) Bugfix: the ngx_http_autoindex_module did not show the trailing - slash in links to a directory; the bug had appeared in 0.7.15. - - *) Bugfix: nginx did not close a log file set by the --error-log-path + *) Bugfix: the ngx_http_autoindex_module did not show the trailing slash + in links to a directory; the bug had appeared in 0.7.15. + + *) Bugfix: nginx did not close a log file set by the --error-log-path configuration option; the bug had appeared in 0.7.53. - *) Bugfix: nginx did not treat a comma as separator in the + *) Bugfix: nginx did not treat a comma as separator in the "Cache-Control" backend response header line. - *) Bugfix: nginx/Windows might not create temporary file, a cache file, - or "proxy/fastcgi_store"d file if a worker had no enough access + *) Bugfix: nginx/Windows might not create temporary file, a cache file, + or "proxy/fastcgi_store"d file if a worker had no enough access rights for top level directories. - *) Bugfix: the "Set-Cookie" and "P3P" FastCGI response header lines - were not hidden while caching if no "fastcgi_hide_header" directives - were used with any parameters. + *) Bugfix: the "Set-Cookie" and "P3P" FastCGI response header lines were + not hidden while caching if no "fastcgi_hide_header" directives were + used with any parameters. *) Bugfix: nginx counted incorrectly disk cache size. @@ -852,8 +892,8 @@ *) Change: now default SSL ciphers are "ALL:!ADH:RC4+RSA:+HIGH:+MEDIUM". - *) Bugfix: a "limit_req" directive did not work; the bug had appeared - in 0.8.18. + *) Bugfix: a "limit_req" directive did not work; the bug had appeared in + 0.8.18. Changes with nginx 0.8.18 06 Oct 2009 @@ -862,21 +902,21 @@ *) Feature: now several "perl_modules" directives may be used. - *) Feature: the "limit_req_log_level" and "limit_conn_log_level" + *) Feature: the "limit_req_log_level" and "limit_conn_log_level" directives. - *) Bugfix: now "limit_req" directive conforms to the leaky bucket + *) Bugfix: now "limit_req" directive conforms to the leaky bucket algorithm. Thanks to Maxim Dounin. *) Bugfix: nginx did not work on Linux/sparc. Thanks to Marcus Ramberg. - *) Bugfix: nginx sent '\0' in a "Location" response header line on - MKCOL request. + *) Bugfix: nginx sent '\0' in a "Location" response header line on MKCOL + request. Thanks to Xie Zhenye. - *) Bugfix: zero status code was logged instead of 499 status code; the + *) Bugfix: zero status code was logged instead of 499 status code; the bug had appeared in 0.8.11. *) Bugfix: socket leak; the bug had appeared in 0.8.11. @@ -884,7 +924,7 @@ Changes with nginx 0.8.17 28 Sep 2009 - *) Security: now "/../" are disabled in "Destination" request header + *) Security: now "/../" are disabled in "Destination" request header line. *) Change: now $host variable value is always low case. @@ -898,7 +938,7 @@ *) Feature: the "image_filter_transparency" directive. - *) Bugfix: "addition_types" directive was incorrectly named + *) Bugfix: "addition_types" directive was incorrectly named "addtion_types". *) Bugfix: resolver cache poisoning. @@ -907,31 +947,31 @@ *) Bugfix: memory leak in resolver. Thanks to Matthew Dempsky. - *) Bugfix: invalid request line in $request variable was written in + *) Bugfix: invalid request line in $request variable was written in access_log only if error_log was set to "info" or "debug" level. - *) Bugfix: in PNG alpha-channel support in the + *) Bugfix: in PNG alpha-channel support in the ngx_http_image_filter_module. - *) Bugfix: nginx always added "Vary: Accept-Encoding" response header + *) Bugfix: nginx always added "Vary: Accept-Encoding" response header line, if both "gzip_static" and "gzip_vary" were on. - *) Bugfix: in UTF-8 encoding support by "try_files" directive in + *) Bugfix: in UTF-8 encoding support by "try_files" directive in nginx/Windows. - *) Bugfix: in "post_action" directive usage; the bug had appeared in + *) Bugfix: in "post_action" directive usage; the bug had appeared in 0.8.11. Thanks to Igor Artemiev. Changes with nginx 0.8.15 14 Sep 2009 - *) Security: a segmentation fault might occur in worker process while + *) Security: a segmentation fault might occur in worker process while specially crafted request handling. Thanks to Chris Ries. - *) Bugfix: if names .domain.tld, .sub.domain.tld, and .domain-some.tld - were defined, then the name .sub.domain.tld was matched by + *) Bugfix: if names .domain.tld, .sub.domain.tld, and .domain-some.tld + were defined, then the name .sub.domain.tld was matched by .domain.tld. *) Bugfix: in transparency support in the ngx_http_image_filter_module. @@ -945,25 +985,25 @@ Changes with nginx 0.8.14 07 Sep 2009 - *) Bugfix: an expired cached response might stick in the "UPDATING" + *) Bugfix: an expired cached response might stick in the "UPDATING" state. - *) Bugfix: a segmentation fault might occur in worker process, if + *) Bugfix: a segmentation fault might occur in worker process, if error_log was set to info or debug level. Thanks to Sergey Bochenkov. *) Bugfix: in embedded perl module; the bug had appeared in 0.8.11. - *) Bugfix: an "error_page" directive did not redirect a 413 error; the + *) Bugfix: an "error_page" directive did not redirect a 413 error; the bug had appeared in 0.6.10. Changes with nginx 0.8.13 31 Aug 2009 - *) Bugfix: in the "aio sendfile" directive; the bug had appeared in + *) Bugfix: in the "aio sendfile" directive; the bug had appeared in 0.8.12. - *) Bugfix: nginx could not be built without the --with-file-aio option + *) Bugfix: nginx could not be built without the --with-file-aio option on FreeBSD; the bug had appeared in 0.8.12. @@ -978,7 +1018,7 @@ Changes with nginx 0.8.11 28 Aug 2009 - *) Change: now directive "gzip_disable msie6" does not disable gzipping + *) Change: now directive "gzip_disable msie6" does not disable gzipping for MSIE 6.0 SV1. *) Feature: file AIO support on FreeBSD and Linux. @@ -990,35 +1030,34 @@ *) Bugfix: memory leaks if GeoIP City database was used. - *) Bugfix: in copying temporary files to permanent storage area; the - bug had appeared in 0.8.9. + *) Bugfix: in copying temporary files to permanent storage area; the bug + had appeared in 0.8.9. Changes with nginx 0.8.9 17 Aug 2009 - *) Feature: now the start cache loader runs in a separate process; this + *) Feature: now the start cache loader runs in a separate process; this should improve large caches handling. - *) Feature: now temporary files and permanent storage area may reside - at different file systems. + *) Feature: now temporary files and permanent storage area may reside at + different file systems. Changes with nginx 0.8.8 10 Aug 2009 *) Bugfix: in handling FastCGI headers split in records. - *) Bugfix: a segmentation fault occurred in worker process, if a - request was handled in two proxied or FastCGIed locations and a - caching was enabled in the first location; the bug had appeared in - 0.8.7. + *) Bugfix: a segmentation fault occurred in worker process, if a request + was handled in two proxied or FastCGIed locations and a caching was + enabled in the first location; the bug had appeared in 0.8.7. Changes with nginx 0.8.7 27 Jul 2009 *) Change: minimum supported OpenSSL version is 0.9.7. - *) Change: the "ask" parameter of the "ssl_verify_client" directive was - changed to the "optional" parameter and now it checks a client + *) Change: the "ask" parameter of the "ssl_verify_client" directive was + changed to the "optional" parameter and now it checks a client certificate if it was offered. Thanks to Brice Figureau. @@ -1030,24 +1069,24 @@ *) Feature: the "proxy" parameter of the "geo" directive. - *) Feature: the "image_filter" directive supports variables for setting + *) Feature: the "image_filter" directive supports variables for setting size. - *) Bugfix: the $ssl_client_cert variable usage corrupted memory; the - bug had appeared in 0.7.7. + *) Bugfix: the $ssl_client_cert variable usage corrupted memory; the bug + had appeared in 0.7.7. Thanks to Sergey Zhuravlev. - *) Bugfix: "proxy_pass_header" and "fastcgi_pass_header" directives did - not pass to a client the "X-Accel-Redirect", "X-Accel-Limit-Rate", - "X-Accel-Buffering", and "X-Accel-Charset" lines from backend + *) Bugfix: "proxy_pass_header" and "fastcgi_pass_header" directives did + not pass to a client the "X-Accel-Redirect", "X-Accel-Limit-Rate", + "X-Accel-Buffering", and "X-Accel-Charset" lines from backend response header. Thanks to Maxim Dounin. - *) Bugfix: in handling "Last-Modified" and "Accept-Ranges" backend + *) Bugfix: in handling "Last-Modified" and "Accept-Ranges" backend response header lines; the bug had appeared in 0.7.44. Thanks to Maxim Dounin. - *) Bugfix: the "[alert] zero size buf" error if subrequest returns an + *) Bugfix: the "[alert] zero size buf" error if subrequest returns an empty response; the bug had appeared in 0.8.5. @@ -1055,17 +1094,17 @@ *) Feature: the ngx_http_geoip_module. - *) Bugfix: XSLT filter may fail with message "not well formed XML + *) Bugfix: XSLT filter may fail with message "not well formed XML document" for valid XML document. Thanks to Kuramoto Eiji. - *) Bugfix: now in MacOSX, Cygwin, and nginx/Windows locations given by - a regular expression are always tested in case insensitive mode. + *) Bugfix: now in MacOSX, Cygwin, and nginx/Windows locations given by a + regular expression are always tested in case insensitive mode. *) Bugfix: now nginx/Windows ignores trailing dots in URI. Thanks to Hugo Leisink. - *) Bugfix: name of file specified in --conf-path was not honored during + *) Bugfix: name of file specified in --conf-path was not honored during installation; the bug had appeared in 0.6.6. Thanks to Maxim Dounin. @@ -1074,7 +1113,7 @@ *) Bugfix: now nginx allows underscores in a request method. - *) Bugfix: a 500 error code was returned for invalid login/password + *) Bugfix: a 500 error code was returned for invalid login/password while HTTP Basic authentication on Windows. *) Bugfix: ngx_http_perl_module responses did not work in subrequests. @@ -1085,7 +1124,7 @@ Changes with nginx 0.8.4 22 Jun 2009 - *) Bugfix: nginx could not be built --without-http-cache; the bug had + *) Bugfix: nginx could not be built --without-http-cache; the bug had appeared in 0.8.3. @@ -1095,43 +1134,43 @@ *) Bugfix: nginx could not be built on MacOSX 10.6. - *) Bugfix: nginx could not be built --without-http-cache; the bug had + *) Bugfix: nginx could not be built --without-http-cache; the bug had appeared in 0.8.2. - *) Bugfix: a segmentation fault occurred in worker process, if a - backend 401 error was intercepted and the backend did not set the + *) Bugfix: a segmentation fault occurred in worker process, if a backend + 401 error was intercepted and the backend did not set the "WWW-Authenticate" response header line. Thanks to Eugene Mychlo. Changes with nginx 0.8.2 15 Jun 2009 - *) Bugfix: in open_file_cache and proxy/fastcgi cache interaction on + *) Bugfix: in open_file_cache and proxy/fastcgi cache interaction on start up. - *) Bugfix: open_file_cache might cache open file descriptors too long; + *) Bugfix: open_file_cache might cache open file descriptors too long; the bug had appeared in 0.7.4. Changes with nginx 0.8.1 08 Jun 2009 - *) Feature: the "updating" parameter in "proxy_cache_use_stale" and + *) Feature: the "updating" parameter in "proxy_cache_use_stale" and "fastcgi_cache_use_stale" directives. - *) Bugfix: the "If-Modified-Since", "If-Range", etc. client request - header lines were passed to backend while caching if no + *) Bugfix: the "If-Modified-Since", "If-Range", etc. client request + header lines were passed to backend while caching if no "proxy_set_header" directive was used with any parameters. - *) Bugfix: the "Set-Cookie" and "P3P" response header lines were not - hidden while caching if no "proxy_hide_header/fastcgi_hide_header" + *) Bugfix: the "Set-Cookie" and "P3P" response header lines were not + hidden while caching if no "proxy_hide_header/fastcgi_hide_header" directives were used with any parameters. - *) Bugfix: the ngx_http_image_filter_module did not support GIF87a + *) Bugfix: the ngx_http_image_filter_module did not support GIF87a format. Thanks to Denis Ilyinyh. - *) Bugfix: nginx could not be built modules on Solaris 10 and early; - the bug had appeared in 0.7.56. + *) Bugfix: nginx could not be built modules on Solaris 10 and early; the + bug had appeared in 0.7.56. Changes with nginx 0.8.0 02 Jun 2009 @@ -1145,8 +1184,8 @@ *) Bugfix: in relative paths handling in nginx/Windows. - *) Bugfix: in proxy_store, fastcgi_store, proxy_cache, and - fastcgi_cache in nginx/Windows. + *) Bugfix: in proxy_store, fastcgi_store, proxy_cache, and fastcgi_cache + in nginx/Windows. *) Bugfix: in memory allocation error handling. Thanks to Maxim Dounin and Kirill A. Korinskiy. @@ -1154,23 +1193,23 @@ Changes with nginx 0.7.59 25 May 2009 - *) Feature: the "proxy_cache_methods" and "fastcgi_cache_methods" + *) Feature: the "proxy_cache_methods" and "fastcgi_cache_methods" directives. *) Bugfix: socket leak; the bug had appeared in 0.7.25. Thanks to Maxim Dounin. - *) Bugfix: a segmentation fault occurred in worker process, - if a request had no body and the $request_body variable was used; + *) Bugfix: a segmentation fault occurred in worker process, if a request + had no body and the $request_body variable was used; the bug had appeared in 0.7.58. *) Bugfix: the SSL modules might not built on Solaris and Linux; the bug had appeared in 0.7.56. - *) Bugfix: ngx_http_xslt_filter_module responses were not handled by + *) Bugfix: ngx_http_xslt_filter_module responses were not handled by SSI, charset, and gzip filters. - *) Bugfix: a "charset" directive did not set a charset to + *) Bugfix: a "charset" directive did not set a charset to ngx_http_gzip_static_module responses. @@ -1184,24 +1223,24 @@ *) Feature: the $request_body variable. - *) Bugfix: in ngx_http_autoindex_module in file name links having a ":" + *) Bugfix: in ngx_http_autoindex_module in file name links having a ":" symbol in the name. - *) Bugfix: "make upgrade" procedure did not work; the bug had appeared + *) Bugfix: "make upgrade" procedure did not work; the bug had appeared in 0.7.53. Thanks to Denis F. Latypoff. Changes with nginx 0.7.57 12 May 2009 - *) Bugfix: a floating-point fault occurred in worker process, if the - ngx_http_image_filter_module errors were redirected to named + *) Bugfix: a floating-point fault occurred in worker process, if the + ngx_http_image_filter_module errors were redirected to named location; the bug had appeared in 0.7.56. Changes with nginx 0.7.56 11 May 2009 - *) Feature: nginx/Windows supports IPv6 in a "listen" directive of the + *) Feature: nginx/Windows supports IPv6 in a "listen" directive of the HTTP module. *) Bugfix: in ngx_http_image_filter_module. @@ -1209,21 +1248,21 @@ Changes with nginx 0.7.55 06 May 2009 - *) Bugfix: the http_XXX parameters in "proxy_cache_use_stale" and + *) Bugfix: the http_XXX parameters in "proxy_cache_use_stale" and "fastcgi_cache_use_stale" directives did not work. *) Bugfix: fastcgi cache did not cache header only responses. - *) Bugfix: of "select() failed (9: Bad file descriptor)" error in + *) Bugfix: of "select() failed (9: Bad file descriptor)" error in nginx/Unix and "select() failed (10038: ...)" error in nginx/Windows. - *) Bugfix: a segmentation fault might occur in worker process, if an - "debug_connection" directive was used; the bug had appeared in + *) Bugfix: a segmentation fault might occur in worker process, if an + "debug_connection" directive was used; the bug had appeared in 0.7.54. *) Bugfix: fix ngx_http_image_filter_module building errors. - *) Bugfix: the files bigger than 2G could not be transferred using + *) Bugfix: the files bigger than 2G could not be transferred using $r->sendfile. Thanks to Maxim Dounin. @@ -1232,33 +1271,33 @@ *) Feature: the ngx_http_image_filter_module. - *) Feature: the "proxy_ignore_headers" and "fastcgi_ignore_headers" + *) Feature: the "proxy_ignore_headers" and "fastcgi_ignore_headers" directives. - *) Bugfix: a segmentation fault might occur in worker process, if an - "open_file_cache_errors off" directive was used; the bug had - appeared in 0.7.53. - - *) Bugfix: the "port_in_redirect off" directive did not work; the bug + *) Bugfix: a segmentation fault might occur in worker process, if an + "open_file_cache_errors off" directive was used; the bug had appeared + in 0.7.53. + + *) Bugfix: the "port_in_redirect off" directive did not work; the bug had appeared in 0.7.39. *) Bugfix: improve handling of "select" method errors. *) Bugfix: of "select() failed (10022: ...)" error in nginx/Windows. - *) Bugfix: in error text descriptions in nginx/Windows; the bug had + *) Bugfix: in error text descriptions in nginx/Windows; the bug had appeared in 0.7.53. Changes with nginx 0.7.53 27 Apr 2009 - *) Change: now a log set by --error-log-path is created from the very + *) Change: now a log set by --error-log-path is created from the very start-up. - *) Feature: now the start up errors and warnings are outputted to an + *) Feature: now the start up errors and warnings are outputted to an error_log and stderr. - *) Feature: the empty --prefix= configure parameter forces nginx to use + *) Feature: the empty --prefix= configure parameter forces nginx to use a directory where it was run as prefix. *) Feature: the -p switch. @@ -1270,14 +1309,14 @@ *) Feature: now switches may be set in condensed form. - *) Bugfix: nginx/Windows did not work if configuration file was given - by the -c switch. - - *) Bugfix: temporary files might be not removed if the "proxy_store", + *) Bugfix: nginx/Windows did not work if configuration file was given by + the -c switch. + + *) Bugfix: temporary files might be not removed if the "proxy_store", "fastcgi_store", "proxy_cache", or "fastcgi_cache" were used. Thanks to Maxim Dounin. - *) Bugfix: an incorrect value was passed to mail proxy authentication + *) Bugfix: an incorrect value was passed to mail proxy authentication server in "Auth-Method" header line; the bug had appeared in 0.7.34. Thanks to Simon Lecaille. @@ -1295,46 +1334,46 @@ *) Bugfix: in processing HEAD method while caching. - *) Bugfix: in processing the "If-Modified-Since", "If-Range", etc. + *) Bugfix: in processing the "If-Modified-Since", "If-Range", etc. client request header lines while caching. - *) Bugfix: now the "Set-Cookie" and "P3P" header lines are hidden in + *) Bugfix: now the "Set-Cookie" and "P3P" header lines are hidden in cacheable responses. - *) Bugfix: if nginx was built with the ngx_http_perl_module and with a - perl which supports threads, then during a master process exit the + *) Bugfix: if nginx was built with the ngx_http_perl_module and with a + perl which supports threads, then during a master process exit the message "panic: MUTEX_LOCK" might be issued. - *) Bugfix: nginx could not be built --without-http-cache; the bug had + *) Bugfix: nginx could not be built --without-http-cache; the bug had appeared in 0.7.48. - *) Bugfix: nginx could not be built on platforms different from i386, + *) Bugfix: nginx could not be built on platforms different from i386, amd64, sparc, and ppc; the bug had appeared in 0.7.42. Changes with nginx 0.7.51 12 Apr 2009 - *) Feature: the "try_files" directive supports a response code in the + *) Feature: the "try_files" directive supports a response code in the fallback parameter. *) Feature: now any response code can be used in the "return" directive. - *) Bugfix: the "error_page" directive made an external redirect without + *) Bugfix: the "error_page" directive made an external redirect without query string; the bug had appeared in 0.7.44. - *) Bugfix: if servers listened on several defined explicitly addresses, + *) Bugfix: if servers listened on several defined explicitly addresses, then virtual servers might not work; the bug had appeared in 0.7.39. Changes with nginx 0.7.50 06 Apr 2009 - *) Bugfix: the $arg_... variables did not work; the bug had appeared in + *) Bugfix: the $arg_... variables did not work; the bug had appeared in 0.7.49. Changes with nginx 0.7.49 06 Apr 2009 - *) Bugfix: a segmentation fault might occur in worker process, if the + *) Bugfix: a segmentation fault might occur in worker process, if the $arg_... variables were used; the bug had appeared in 0.7.48. @@ -1342,7 +1381,7 @@ *) Feature: the "proxy_cache_key" directive. - *) Bugfix: now nginx takes into account the "X-Accel-Expires", + *) Bugfix: now nginx takes into account the "X-Accel-Expires", "Expires", and "Cache-Control" header lines in a backend response. *) Bugfix: now nginx caches responses for the GET requests only. @@ -1355,28 +1394,28 @@ *) Bugfix: nginx could not be built with uclibc library. Thanks to Timothy Redaelli. - *) Bugfix: nginx could not be built on OpenBSD; the bug had + *) Bugfix: nginx could not be built on OpenBSD; the bug had appeared in 0.7.46. Changes with nginx 0.7.47 01 Apr 2009 - *) Bugfix: nginx could not be built on FreeBSD 6 and early versions; - the bug had appeared in 0.7.46. - - *) Bugfix: nginx could not be built on MacOSX; the bug had + *) Bugfix: nginx could not be built on FreeBSD 6 and early versions; the + bug had appeared in 0.7.46. + + *) Bugfix: nginx could not be built on MacOSX; the bug had appeared in 0.7.46. - *) Bugfix: if the "max_size" parameter was set, then the cache manager + *) Bugfix: if the "max_size" parameter was set, then the cache manager might purge a whole cache; the bug had appeared in 0.7.46. - *) Change: a segmentation fault might occur in worker process, if the - "proxy_cache"/"fastcgi_cache" and the "proxy_cache_valid"/ - "fastcgi_cache_valid" were set on different levels; the bug had + *) Change: a segmentation fault might occur in worker process, if the + "proxy_cache"/"fastcgi_cache" and the "proxy_cache_valid"/ + "fastcgi_cache_valid" were set on different levels; the bug had appeared in 0.7.46. - *) Bugfix: a segmentation fault might occur in worker process, if a - request was redirected to a proxied or FastCGI server via error_page + *) Bugfix: a segmentation fault might occur in worker process, if a + request was redirected to a proxied or FastCGI server via error_page or try_files; the bug had appeared in 0.7.44. @@ -1387,30 +1426,29 @@ Changes with nginx 0.7.45 30 Mar 2009 - *) Change: now the "proxy_cache" and the "proxy_cache_valid" directives + *) Change: now the "proxy_cache" and the "proxy_cache_valid" directives can be set on different levels. - *) Change: the "clean_time" parameter of the "proxy_cache_path" + *) Change: the "clean_time" parameter of the "proxy_cache_path" directive is canceled. - *) Feature: the "max_size" parameter of the "proxy_cache_path" + *) Feature: the "max_size" parameter of the "proxy_cache_path" directive. *) Feature: the ngx_http_fastcgi_module preliminary cache support. - *) Feature: now on shared memory allocation errors directive and zone + *) Feature: now on shared memory allocation errors directive and zone names are logged. - *) Bugfix: the directive "add_header last-modified ''" did not delete a + *) Bugfix: the directive "add_header last-modified ''" did not delete a "Last-Modified" response header line; the bug had appeared in 0.7.44. - *) Bugfix: a relative path in the "auth_basic_user_file" directive - given without variables did not work; the bug had appeared in - 0.7.44. + *) Bugfix: a relative path in the "auth_basic_user_file" directive given + without variables did not work; the bug had appeared in 0.7.44. Thanks to Jerome Loyet. - *) Bugfix: in an "alias" directive given using variables without - references to captures of regular expressions; the bug had appeared + *) Bugfix: in an "alias" directive given using variables without + references to captures of regular expressions; the bug had appeared in 0.7.42. @@ -1420,86 +1458,85 @@ *) Feature: the --with-pcre option in the configure. - *) Feature: the "try_files" directive is now allowed on the server - block level. - - *) Bugfix: the "try_files" directive handled incorrectly a query string + *) Feature: the "try_files" directive is now allowed on the server block + level. + + *) Bugfix: the "try_files" directive handled incorrectly a query string in a fallback parameter. *) Bugfix: the "try_files" directive might test incorrectly directories. - *) Bugfix: if there was a single server for given address:port pair, - then captures in regular expressions in a "server_name" directive - did not work. + *) Bugfix: if there was a single server for given address:port pair, + then captures in regular expressions in a "server_name" directive did + not work. Changes with nginx 0.7.43 18 Mar 2009 - *) Bugfix: a request was handled incorrectly, if a "root" directive - used variables; the bug had appeared in 0.7.42. - - *) Bugfix: if a server listened on wildcard address, then the - $server_addr variable value was "0.0.0.0"; the bug had appeared in + *) Bugfix: a request was handled incorrectly, if a "root" directive used + variables; the bug had appeared in 0.7.42. + + *) Bugfix: if a server listened on wildcard address, then the + $server_addr variable value was "0.0.0.0"; the bug had appeared in 0.7.36. Changes with nginx 0.7.42 16 Mar 2009 - *) Change: now the "Invalid argument" error returned by + *) Change: now the "Invalid argument" error returned by setsockopt(TCP_NODELAY) on Solaris, is ignored. - *) Change: now if a file specified in a "auth_basic_user_file" - directive is absent, then the 403 error is returned instead of the - 500 one. + *) Change: now if a file specified in a "auth_basic_user_file" directive + is absent, then the 403 error is returned instead of the 500 one. *) Feature: the "auth_basic_user_file" directive supports variables. Thanks to Kirill A. Korinskiy. - *) Feature: the "listen" directive supports the "ipv6only" parameter. + *) Feature: the "listen" directive supports the "ipv6only" parameter. Thanks to Zhang Hua. - *) Bugfix: in an "alias" directive with references to captures of + *) Bugfix: in an "alias" directive with references to captures of regular expressions; the bug had appeared in 0.7.40. *) Bugfix: compatibility with Tru64 UNIX. Thanks to Dustin Marquess. - *) Bugfix: nginx could not be built without PCRE library; the bug had + *) Bugfix: nginx could not be built without PCRE library; the bug had appeared in 0.7.41. Changes with nginx 0.7.41 11 Mar 2009 - *) Bugfix: a segmentation fault might occur in worker process, if a - "server_name" or a "location" directives had captures in regular + *) Bugfix: a segmentation fault might occur in worker process, if a + "server_name" or a "location" directives had captures in regular expressions; the issue had appeared in 0.7.40. Thanks to Vladimir Sopot. Changes with nginx 0.7.40 09 Mar 2009 - *) Feature: the "location" directive supports captures in regular + *) Feature: the "location" directive supports captures in regular expressions. - *) Feature: an "alias" directive with capture references may be used + *) Feature: an "alias" directive with capture references may be used inside a location given by a regular expression with captures. - *) Feature: the "server_name" directive supports captures in regular + *) Feature: the "server_name" directive supports captures in regular expressions. - *) Workaround: the ngx_http_autoindex_module did not show the trailing - slash in directories on XFS filesystem; the issue had appeared in + *) Workaround: the ngx_http_autoindex_module did not show the trailing + slash in directories on XFS filesystem; the issue had appeared in 0.7.15. Thanks to Dmitry Kuzmenko. Changes with nginx 0.7.39 02 Mar 2009 - *) Bugfix: large response with SSI might hang, if gzipping was enabled; + *) Bugfix: large response with SSI might hang, if gzipping was enabled; the bug had appeared in 0.7.28. Thanks to Artem Bokhan. - *) Bugfix: a segmentation fault might occur in worker process, if short + *) Bugfix: a segmentation fault might occur in worker process, if short static variants are used in a "try_files" directive. @@ -1507,41 +1544,41 @@ *) Feature: authentication failures logging. - *) Bugfix: name/password in auth_basic_user_file were ignored after odd + *) Bugfix: name/password in auth_basic_user_file were ignored after odd number of empty lines. Thanks to Alexander Zagrebin. - *) Bugfix: a segmentation fault occurred in a master process, if long + *) Bugfix: a segmentation fault occurred in a master process, if long path was used in unix domain socket; the bug had appeared in 0.7.36. Changes with nginx 0.7.37 21 Feb 2009 - *) Bugfix: directives using upstreams did not work; the bug had - appeared in 0.7.36. + *) Bugfix: directives using upstreams did not work; the bug had appeared + in 0.7.36. Changes with nginx 0.7.36 21 Feb 2009 - *) Feature: a preliminary IPv6 support; the "listen" directive of the + *) Feature: a preliminary IPv6 support; the "listen" directive of the HTTP module supports IPv6. - *) Bugfix: the $ancient_browser variable did not work for browsers + *) Bugfix: the $ancient_browser variable did not work for browsers preset by a "modern_browser" directives. Changes with nginx 0.7.35 16 Feb 2009 - *) Bugfix: a "ssl_engine" directive did not use a SSL-accelerator for + *) Bugfix: a "ssl_engine" directive did not use a SSL-accelerator for asymmetric ciphers. Thanks to Marcin Gozdalik. - *) Bugfix: a "try_files" directive set MIME type depending on an + *) Bugfix: a "try_files" directive set MIME type depending on an original request extension. - *) Bugfix: "*domain.tld" names were handled incorrectly in - "server_name", "valid_referers", and "map" directives, if - ".domain.tld" and ".subdomain.domain.tld" wildcards were used; + *) Bugfix: "*domain.tld" names were handled incorrectly in + "server_name", "valid_referers", and "map" directives, if + ".domain.tld" and ".subdomain.domain.tld" wildcards were used; the bug had appeared in 0.7.9. @@ -1549,15 +1586,15 @@ *) Feature: the "off" parameter of the "if_modified_since" directive. - *) Feature: now nginx sends an HELO/EHLO command after a XCLIENT + *) Feature: now nginx sends an HELO/EHLO command after a XCLIENT command. Thanks to Maxim Dounin. - *) Feature: Microsoft specific "AUTH LOGIN with User Name" mode support + *) Feature: Microsoft specific "AUTH LOGIN with User Name" mode support in mail proxy server. Thanks to Maxim Dounin. - *) Bugfix: in a redirect rewrite directive original arguments were + *) Bugfix: in a redirect rewrite directive original arguments were concatenated with new arguments by a "?" rather than an "&"; the bug had appeared in 0.1.18. Thanks to Maxim Dounin. @@ -1567,35 +1604,34 @@ Changes with nginx 0.7.33 02 Feb 2009 - *) Bugfix: a double response might be returned if the epoll or rtsig - methods are used and a redirect was returned to a request with - body. + *) Bugfix: a double response might be returned if the epoll or rtsig + methods are used and a redirect was returned to a request with body. Thanks to Eden Li. - *) Bugfix: the $sent_http_location variable was empty for some - redirects types. - - *) Bugfix: a segmentation fault might occur in worker process if + *) Bugfix: the $sent_http_location variable was empty for some redirects + types. + + *) Bugfix: a segmentation fault might occur in worker process if "resolver" directive was used in SMTP proxy. Changes with nginx 0.7.32 26 Jan 2009 - *) Feature: now a directory existence testing can be set explicitly in + *) Feature: now a directory existence testing can be set explicitly in the "try_files" directive. *) Bugfix: fastcgi_store stored files not always. *) Bugfix: in geo ranges. - *) Bugfix: in shared memory allocations if nginx was built without + *) Bugfix: in shared memory allocations if nginx was built without debugging. Thanks to Andrey Kvasov. Changes with nginx 0.7.31 19 Jan 2009 - *) Change: now the "try_files" directive tests files only and ignores + *) Change: now the "try_files" directive tests files only and ignores directories. *) Feature: the "fastcgi_split_path_info" directive. @@ -1604,35 +1640,34 @@ *) Bugfixes in geo ranges. - *) Bugfix: in a miss case ngx_http_memcached_module returned the "END" - line as response body instead of default 404 page body; the bug had + *) Bugfix: in a miss case ngx_http_memcached_module returned the "END" + line as response body instead of default 404 page body; the bug had appeared in 0.7.18. Thanks to Maxim Dounin. - *) Bugfix: while SMTP proxying nginx issued message "250 2.0.0 OK" + *) Bugfix: while SMTP proxying nginx issued message "250 2.0.0 OK" instead of "235 2.0.0 OK"; the bug had appeared in 0.7.22. Thanks to Maxim Dounin. Changes with nginx 0.7.30 24 Dec 2008 - *) Bugfix: a segmentation fault occurred in worker process, if - variables were used in the "fastcgi_pass" or "proxy_pass" directives - and host name must be resolved; the bug had appeared in 0.7.29. + *) Bugfix: a segmentation fault occurred in worker process, if variables + were used in the "fastcgi_pass" or "proxy_pass" directives and host + name must be resolved; the bug had appeared in 0.7.29. Changes with nginx 0.7.29 24 Dec 2008 - *) Bugfix: the "fastcgi_pass" and "proxy_pass" directives did not + *) Bugfix: the "fastcgi_pass" and "proxy_pass" directives did not support variables if unix domain sockets were used. *) Bugfixes in subrequest processing; the bugs had appeared in 0.7.25. - *) Bugfix: a "100 Continue" response was issued for HTTP/1.0 - requests; + *) Bugfix: a "100 Continue" response was issued for HTTP/1.0 requests; Thanks to Maxim Dounin. - *) Bugfix: in memory allocation in the ngx_http_gzip_filter_module on + *) Bugfix: in memory allocation in the ngx_http_gzip_filter_module on Cygwin. @@ -1640,8 +1675,8 @@ *) Change: in memory allocation in the ngx_http_gzip_filter_module. - *) Change: the default "gzip_buffers" directive values have been - changed to 32 4k or 16 8k from 4 4k/8k. + *) Change: the default "gzip_buffers" directive values have been changed + to 32 4k or 16 8k from 4 4k/8k. Changes with nginx 0.7.27 15 Dec 2008 @@ -1650,24 +1685,23 @@ *) Feature: variables support in the "fastcgi_pass" directive. - *) Feature: now the $geo variable may get an address from a - variable. + *) Feature: now the $geo variable may get an address from a variable. Thanks to Andrei Nigmatulin. - *) Feature: now a location's modifier may be used without space before + *) Feature: now a location's modifier may be used without space before name. *) Feature: the $upstream_response_length variable. *) Bugfix: now a "add_header" directive does not add an empty value. - *) Bugfix: if zero length static file was requested, then nginx just + *) Bugfix: if zero length static file was requested, then nginx just closed connection; the bug had appeared in 0.7.25. *) Bugfix: a MOVE method could not move file in non-existent directory. - *) Bugfix: a segmentation fault occurred in worker process, if no one - named location was defined in server, but some one was used in an + *) Bugfix: a segmentation fault occurred in worker process, if no one + named location was defined in server, but some one was used in an error_page directive. Thanks to Sergey Bochenkov. @@ -1683,7 +1717,7 @@ *) Change: now POSTs without "Content-Length" header line are allowed. - *) Bugfix: now the "limit_req" and "limit_conn" directives log a + *) Bugfix: now the "limit_req" and "limit_conn" directives log a prohibition reason. *) Bugfix: in the "delete" parameter of the "geo" directive. @@ -1693,10 +1727,10 @@ *) Feature: the "if_modified_since" directive. - *) Bugfix: nginx did not process a FastCGI server response, if the + *) Bugfix: nginx did not process a FastCGI server response, if the server send too many messages to stderr before response. - *) Bugfix: the "$cookie_..." variables did not work in the SSI and the + *) Bugfix: the "$cookie_..." variables did not work in the SSI and the perl module. @@ -1732,7 +1766,7 @@ *) Workaround: compatibility with glibc 2.3. Thanks to Eric Benson and Maxim Dounin. - *) Bugfix: nginx could not run on MacOSX 10.4 and earlier; the bug had + *) Bugfix: nginx could not run on MacOSX 10.4 and earlier; the bug had appeared in 0.7.6. @@ -1742,17 +1776,17 @@ *) Feature: the ngx_http_limit_req_module. - *) Bugfix: worker processes might exit on a SIGBUS signal on sparc and + *) Bugfix: worker processes might exit on a SIGBUS signal on sparc and ppc platforms; the bug had appeared in 0.7.3. Thanks to Maxim Dounin. - *) Bugfix: the "proxy_pass http://host/some:uri" directives did not + *) Bugfix: the "proxy_pass http://host/some:uri" directives did not work; the bug had appeared in 0.7.12. - *) Bugfix: in HTTPS mode requests might fail with the "bad write retry" + *) Bugfix: in HTTPS mode requests might fail with the "bad write retry" error. - *) Bugfix: the ngx_http_secure_link_module did not work inside + *) Bugfix: the ngx_http_secure_link_module did not work inside locations, whose names are less than 3 characters. *) Bugfix: $server_addr variable might have no value. @@ -1765,7 +1799,7 @@ Changes with nginx 0.7.18 13 Oct 2008 - *) Change: the "underscores_in_headers" directive; now nginx does not + *) Change: the "underscores_in_headers" directive; now nginx does not allows underscores in a client request header line names. *) Feature: the ngx_http_secure_link_module. @@ -1776,13 +1810,13 @@ *) Feature: the $realpath_root variable. - *) Feature: the "http_502" and "http_504" parameters of the + *) Feature: the "http_502" and "http_504" parameters of the "proxy_next_upstream" directive. - *) Bugfix: the "http_503" parameter of the "proxy_next_upstream" or + *) Bugfix: the "http_503" parameter of the "proxy_next_upstream" or "fastcgi_next_upstream" directives did not work. - *) Bugfix: nginx might send a "Transfer-Encoding: chunked" header line + *) Bugfix: nginx might send a "Transfer-Encoding: chunked" header line for HEAD requests. *) Bugfix: now accept threshold depends on worker_connections. @@ -1794,19 +1828,19 @@ *) Feature: the $pid variable. - *) Bugfix: the "directio" optimization that had appeared in 0.7.15 did + *) Bugfix: the "directio" optimization that had appeared in 0.7.15 did not work with open_file_cache. - *) Bugfix: the "access_log" with variables did not work on Linux; the + *) Bugfix: the "access_log" with variables did not work on Linux; the bug had appeared in 0.7.7. - *) Bugfix: the ngx_http_charset_module did not understand quoted - charset name received from backend. + *) Bugfix: the ngx_http_charset_module did not understand quoted charset + name received from backend. Changes with nginx 0.7.16 08 Sep 2008 - *) Bugfix: nginx could not be built on 64-bit platforms; the bug had + *) Bugfix: nginx could not be built on 64-bit platforms; the bug had appeared in 0.7.15. @@ -1814,31 +1848,31 @@ *) Feature: the ngx_http_random_index_module. - *) Feature: the "directio" directive has been optimized for file + *) Feature: the "directio" directive has been optimized for file requests starting from arbitrary position. - *) Feature: the "directio" directive turns off sendfile if it is + *) Feature: the "directio" directive turns off sendfile if it is necessary. - *) Feature: now nginx allows underscores in a client request header - line names. + *) Feature: now nginx allows underscores in a client request header line + names. Changes with nginx 0.7.14 01 Sep 2008 - *) Change: now the ssl_certificate and ssl_certificate_key directives + *) Change: now the ssl_certificate and ssl_certificate_key directives have not default values. *) Feature: the "listen" directive supports the "ssl" parameter. - *) Feature: now nginx takes into account a time zone change while + *) Feature: now nginx takes into account a time zone change while reconfiguration on FreeBSD and Linux. - *) Bugfix: the "listen" directive parameters such as "backlog", - "rcvbuf", etc. were not set, if a default server was not the first + *) Bugfix: the "listen" directive parameters such as "backlog", + "rcvbuf", etc. were not set, if a default server was not the first one. - *) Bugfix: if URI part captured by a "rewrite" directive was used as a + *) Bugfix: if URI part captured by a "rewrite" directive was used as a query string, then the query string was not escaped. *) Bugfix: configuration file validity test improvements. @@ -1846,7 +1880,7 @@ Changes with nginx 0.7.13 26 Aug 2008 - *) Bugfix: nginx could not be built on Linux and Solaris; the bug had + *) Bugfix: nginx could not be built on Linux and Solaris; the bug had appeared in 0.7.12. @@ -1856,35 +1890,35 @@ *) Feature: the "gzip_disable" directive supports special "msie6" mask. - *) Bugfix: if the "max_fails=0" parameter was used in upstream with + *) Bugfix: if the "max_fails=0" parameter was used in upstream with several servers, then a worker process exited on a SIGFPE signal. Thanks to Maxim Dounin. - *) Bugfix: a request body was dropped while redirection via an + *) Bugfix: a request body was dropped while redirection via an "error_page" directive. - *) Bugfix: a full response was returned for request method HEAD while + *) Bugfix: a full response was returned for request method HEAD while redirection via an "error_page" directive. - *) Bugfix: the $r->header_in() method did not return value of the - "Host", "User-Agent", and "Connection" request header lines; the bug + *) Bugfix: the $r->header_in() method did not return value of the + "Host", "User-Agent", and "Connection" request header lines; the bug had appeared in 0.7.0. Changes with nginx 0.7.11 18 Aug 2008 - *) Change: now ngx_http_charset_module does not work by default with + *) Change: now ngx_http_charset_module does not work by default with text/css MIME type. - *) Feature: now nginx returns the 405 status code for POST method + *) Feature: now nginx returns the 405 status code for POST method requesting a static file only if the file exists. *) Feature: the "proxy_ssl_session_reuse" directive. - *) Bugfix: a "proxy_pass" directive without URI part might use original + *) Bugfix: a "proxy_pass" directive without URI part might use original request after the "X-Accel-Redirect" redirection was used; - *) Bugfix: if a directory has search only rights and the first index + *) Bugfix: if a directory has search only rights and the first index file was absent, then nginx returned the 500 status code. *) Bugfix: in inclusive locations; the bugs had appeared in 0.7.1. @@ -1892,25 +1926,25 @@ Changes with nginx 0.7.10 13 Aug 2008 - *) Bugfix: in the "addition_types", "charset_types", "gzip_types", - "ssi_types", "sub_filter_types", and "xslt_types" directives; the + *) Bugfix: in the "addition_types", "charset_types", "gzip_types", + "ssi_types", "sub_filter_types", and "xslt_types" directives; the bugs had appeared in 0.7.9. *) Bugfix: of recursive error_page for 500 status code. - *) Bugfix: now the ngx_http_realip_module sets address not for whole + *) Bugfix: now the ngx_http_realip_module sets address not for whole keepalive connection, but for each request passed via the connection. Changes with nginx 0.7.9 12 Aug 2008 - *) Change: now ngx_http_charset_module works by default with following - MIME types: text/html, text/css, text/xml, text/plain, + *) Change: now ngx_http_charset_module works by default with following + MIME types: text/html, text/css, text/xml, text/plain, text/vnd.wap.wml, application/x-javascript, and application/rss+xml. *) Feature: the "charset_types" and "addition_types" directives. - *) Feature: now the "gzip_types", "ssi_types", and "sub_filter_types" + *) Feature: now the "gzip_types", "ssi_types", and "sub_filter_types" directives use hash. *) Feature: the ngx_cpp_test_module. @@ -1920,15 +1954,15 @@ *) Feature: the ngx_http_xslt_module improvements and bug fixing. Thanks to Denis F. Latypoff and Maxim Dounin. - *) Bugfix: the "log_not_found" directive did not work for index files + *) Bugfix: the "log_not_found" directive did not work for index files tests. - *) Bugfix: HTTPS connections might hang, if kqueue, epoll, rtsig, or + *) Bugfix: HTTPS connections might hang, if kqueue, epoll, rtsig, or eventport methods were used; the bug had appeared in 0.7.7. - *) Bugfix: if the "server_name", "valid_referers", and "map" directives - used an "*.domain.tld" wildcard and exact name "domain.tld" was not - set, then the exact name was matched by the wildcard; the bug had + *) Bugfix: if the "server_name", "valid_referers", and "map" directives + used an "*.domain.tld" wildcard and exact name "domain.tld" was not + set, then the exact name was matched by the wildcard; the bug had appeared in 0.3.18. @@ -1941,19 +1975,19 @@ *) Feature: Solaris directio support. Thanks to Ivan Debnar. - *) Bugfix: now if FastCGI server sends a "Location" header line without + *) Bugfix: now if FastCGI server sends a "Location" header line without status line, then nginx uses 302 status code. Thanks to Maxim Dounin. Changes with nginx 0.7.7 30 Jul 2008 - *) Change: now the EAGAIN error returned by connect() is not considered + *) Change: now the EAGAIN error returned by connect() is not considered as temporary error. - *) Change: now the $ssl_client_cert variable value is a certificate - with TAB character intended before each line except first one; an - unchanged certificate is available in the $ssl_client_raw_cert + *) Change: now the $ssl_client_cert variable value is a certificate with + TAB character intended before each line except first one; an + unchanged certificate is available in the $ssl_client_raw_cert variable. *) Feature: the "ask" parameter in the "ssl_verify_client" directive. @@ -1966,11 +2000,11 @@ *) Feature: MacOSX 10.5 sendfile() support. - *) Bugfix: now in MacOSX and Cygwin locations are tested in case - insensitive mode; however, the compare is provided by single-byte + *) Bugfix: now in MacOSX and Cygwin locations are tested in case + insensitive mode; however, the compare is provided by single-byte locales only. - *) Bugfix: mail proxy SSL connections hanged, if select, poll, or + *) Bugfix: mail proxy SSL connections hanged, if select, poll, or /dev/poll methods were used. *) Bugfix: UTF-8 encoding usage in the ngx_http_autoindex_module. @@ -1978,23 +2012,23 @@ Changes with nginx 0.7.6 07 Jul 2008 - *) Bugfix: now if variables are used in the "access_log" directive a + *) Bugfix: now if variables are used in the "access_log" directive a request root existence is always tested. - *) Bugfix: the ngx_http_flv_module did not support several values in a + *) Bugfix: the ngx_http_flv_module did not support several values in a query string. Changes with nginx 0.7.5 01 Jul 2008 - *) Bugfixes in variables support in the "access_log" directive; the - bugs had appeared in 0.7.4. - - *) Bugfix: nginx could not be built --without-http_gzip_module; the bug + *) Bugfixes in variables support in the "access_log" directive; the bugs + had appeared in 0.7.4. + + *) Bugfix: nginx could not be built --without-http_gzip_module; the bug had appeared in 0.7.3. Thanks to Kirill A. Korinskiy. - *) Bugfix: if sub_filter and SSI were used together, then responses + *) Bugfix: if sub_filter and SSI were used together, then responses might were transferred incorrectly. @@ -2013,16 +2047,16 @@ Changes with nginx 0.7.3 23 Jun 2008 - *) Change: the "rss" extension MIME type has been changed to + *) Change: the "rss" extension MIME type has been changed to "application/rss+xml". - *) Change: now the "gzip_vary" directive turned on issues a + *) Change: now the "gzip_vary" directive turned on issues a "Vary: Accept-Encoding" header line for uncompressed responses too. - *) Feature: now the "rewrite" directive does a redirect automatically - if the "https://" protocol is used. - - *) Bugfix: the "proxy_pass" directive did not work with the HTTPS + *) Feature: now the "rewrite" directive does a redirect automatically if + the "https://" protocol is used. + + *) Bugfix: the "proxy_pass" directive did not work with the HTTPS protocol; the bug had appeared in 0.6.9. @@ -2035,14 +2069,14 @@ *) Feature: the $ssl_client_cert variable. Thanks to Manlio Perillo. - *) Bugfix: after changing URI via a "rewrite" directive nginx did not + *) Bugfix: after changing URI via a "rewrite" directive nginx did not search a new location; the bug had appeared in 0.7.1. Thanks to Maxim Dounin. - *) Bugfix: nginx could not be built without PCRE library; the bug had + *) Bugfix: nginx could not be built without PCRE library; the bug had appeared in 0.7.1. - *) Bugfix: when a request to a directory was redirected with the slash + *) Bugfix: when a request to a directory was redirected with the slash added, nginx dropped a query string from the original request. @@ -2050,16 +2084,16 @@ *) Change: now locations are searched in a tree. - *) Change: the "optimize_server_names" directive was canceled due to - the "server_name_in_redirect" directive introduction. + *) Change: the "optimize_server_names" directive was canceled due to the + "server_name_in_redirect" directive introduction. *) Change: some long deprecated directives are not supported anymore. - *) Change: the "none" parameter in the "ssl_session_cache" directive; + *) Change: the "none" parameter in the "ssl_session_cache" directive; now this is default parameter. Thanks to Rob Mueller. - *) Bugfix: worker processes might not catch reconfiguration and log + *) Bugfix: worker processes might not catch reconfiguration and log rotation signals. *) Bugfix: nginx could not be built on latest Fedora 9 Linux. @@ -2068,15 +2102,15 @@ Changes with nginx 0.7.0 19 May 2008 - *) Change: now the 0x00-0x1F, '"' and '\' characters are escaped as - \xXX in an access_log. + *) Change: now the 0x00-0x1F, '"' and '\' characters are escaped as \xXX + in an access_log. Thanks to Maxim Dounin. *) Change: now nginx allows several "Host" request header line. *) Feature: the "modified" flag in the "expires" directive. - *) Feature: the $uid_got and $uid_set variables may be used at any + *) Feature: the $uid_got and $uid_set variables may be used at any request processing stage. *) Feature: the $hostname variable. @@ -2085,40 +2119,40 @@ *) Feature: DESTDIR support. Thanks to Todd A. Fisher and Andras Voroskoi. - *) Bugfix: a segmentation fault might occur in worker process on Linux, + *) Bugfix: a segmentation fault might occur in worker process on Linux, if keepalive was enabled. Changes with nginx 0.6.31 12 May 2008 - *) Bugfix: nginx did not process FastCGI response if header was at the + *) Bugfix: nginx did not process FastCGI response if header was at the end of FastCGI record; the bug had appeared in 0.6.2. Thanks to Sergey Serov. - *) Bugfix: a segmentation fault might occur in worker process if a file + *) Bugfix: a segmentation fault might occur in worker process if a file was deleted and the "open_file_cache_errors" directive was off. Changes with nginx 0.6.30 29 Apr 2008 - *) Change: now if an "include" directive pattern does not match any + *) Change: now if an "include" directive pattern does not match any file, then nginx does not issue an error. - *) Feature: now the time in directives may be specified without spaces, + *) Feature: now the time in directives may be specified without spaces, for example, "1h50m". *) Bugfix: memory leaks if the "ssl_verify_client" directive was on. Thanks to Chavelle Vincent. - *) Bugfix: the "sub_filter" directive might set text to change into + *) Bugfix: the "sub_filter" directive might set text to change into output. - *) Bugfix: the "error_page" directive did not take into account + *) Bugfix: the "error_page" directive did not take into account arguments in redirected URI. *) Bugfix: now nginx always opens files in binary mode under Cygwin. - *) Bugfix: nginx could not be built on OpenBSD; the bug had appeared in + *) Bugfix: nginx could not be built on OpenBSD; the bug had appeared in 0.6.15. @@ -2126,61 +2160,61 @@ *) Feature: the ngx_google_perftools_module. - *) Bugfix: the ngx_http_perl_module could not be built on 64-bit + *) Bugfix: the ngx_http_perl_module could not be built on 64-bit platforms; the bug had appeared in 0.6.27. Changes with nginx 0.6.28 13 Mar 2008 - *) Bugfix: the rtsig method could not be built; the bug had appeared in + *) Bugfix: the rtsig method could not be built; the bug had appeared in 0.6.27. Changes with nginx 0.6.27 12 Mar 2008 - *) Change: now by default the rtsig method is not built on + *) Change: now by default the rtsig method is not built on Linux 2.6.18+. - *) Change: now a request method is not changed while redirection to a + *) Change: now a request method is not changed while redirection to a named location via an "error_page" directive. - *) Feature: the "resolver" and "resolver_timeout" directives in SMTP + *) Feature: the "resolver" and "resolver_timeout" directives in SMTP proxy. *) Feature: the "post_action" directive supports named locations. - *) Bugfix: a segmentation fault occurred in worker process, if a - request was redirected from proxy, FastCGI, or memcached location to - static named locations. - - *) Bugfix: browsers did not repeat SSL handshake if there is no valid - client certificate in first handshake. + *) Bugfix: a segmentation fault occurred in worker process, if a request + was redirected from proxy, FastCGI, or memcached location to static + named locations. + + *) Bugfix: browsers did not repeat SSL handshake if there is no valid + client certificate in first handshake. Thanks to Alexander V. Inyukhin. - *) Bugfix: if response code 495-497 was redirected via an "error_page" - directive without code change, then nginx tried to allocate too many + *) Bugfix: if response code 495-497 was redirected via an "error_page" + directive without code change, then nginx tried to allocate too many memory. *) Bugfix: memory leak in long-lived non buffered connections. *) Bugfix: memory leak in resolver. - *) Bugfix: a segmentation fault occurred in worker process, if a - request was redirected from proxy, FastCGI, or memcached location to - static named locations. + *) Bugfix: a segmentation fault occurred in worker process, if a request + was redirected from proxy, FastCGI, or memcached location to static + named locations. *) Bugfix: in the $proxy_host and $proxy_port variables caching. Thanks to Sergey Bochenkov. - *) Bugfix: a "proxy_pass" directive with variables used incorrectly the - same port as in another "proxy_pass" directive with the same host + *) Bugfix: a "proxy_pass" directive with variables used incorrectly the + same port as in another "proxy_pass" directive with the same host name and without variables. Thanks to Sergey Bochenkov. - *) Bugfix: an alert "sendmsg() failed (9: Bad file descriptor)" on some + *) Bugfix: an alert "sendmsg() failed (9: Bad file descriptor)" on some 64-bit platforms while reconfiguration. - *) Bugfix: a segmentation fault occurred in worker process, if empty + *) Bugfix: a segmentation fault occurred in worker process, if empty stub block was used second time in SSI. *) Bugfix: in copying URI part contained escaped symbols into arguments. @@ -2188,69 +2222,69 @@ Changes with nginx 0.6.26 11 Feb 2008 - *) Bugfix: the "proxy_store" and "fastcgi_store" directives did not + *) Bugfix: the "proxy_store" and "fastcgi_store" directives did not check a response length. - *) Bugfix: a segmentation fault occurred in worker process, if big - value was used in a "expires" directive. + *) Bugfix: a segmentation fault occurred in worker process, if big value + was used in a "expires" directive. Thanks to Joaquin Cuenca Abela. *) Bugfix: nginx incorrectly detected cache line size on Pentium 4. Thanks to Gena Makhomed. - *) Bugfix: in proxied or FastCGI subrequests a client original method + *) Bugfix: in proxied or FastCGI subrequests a client original method was used instead of the GET method. *) Bugfix: socket leak in HTTPS mode if deferred accept was used. Thanks to Ben Maurer. - *) Bugfix: nginx issued the bogus error message "SSL_shutdown() failed + *) Bugfix: nginx issued the bogus error message "SSL_shutdown() failed (SSL: )"; the bug had appeared in 0.6.23. - *) Bugfix: in HTTPS mode requests might fail with the "bad write retry" + *) Bugfix: in HTTPS mode requests might fail with the "bad write retry" error; the bug had appeared in 0.6.23. Changes with nginx 0.6.25 08 Jan 2008 - *) Change: now the "server_name_in_redirect" directive is used instead + *) Change: now the "server_name_in_redirect" directive is used instead of the "server_name" directive's special "*" parameter. - *) Change: now wildcard and regex names can be used as main name in a + *) Change: now wildcard and regex names can be used as main name in a "server_name" directive. - *) Change: the "satisfy_any" directive was replaced by the "satisfy" + *) Change: the "satisfy_any" directive was replaced by the "satisfy" directive. - *) Workaround: old worker processes might hog CPU after reconfiguration + *) Workaround: old worker processes might hog CPU after reconfiguration if they was run under Linux OpenVZ. *) Feature: the "min_delete_depth" directive. *) Bugfix: the COPY and MOVE methods did not work with single files. - *) Bugfix: the ngx_http_gzip_static_module did not allow the + *) Bugfix: the ngx_http_gzip_static_module did not allow the ngx_http_dav_module to work; the bug had appeared in 0.6.23. *) Bugfix: socket leak in HTTPS mode if deferred accept was used. Thanks to Ben Maurer. - *) Bugfix: nginx could not be built without PCRE library; the bug had + *) Bugfix: nginx could not be built without PCRE library; the bug had appeared in 0.6.23. Changes with nginx 0.6.24 27 Dec 2007 - *) Bugfix: a segmentation fault might occur in worker process if HTTPS + *) Bugfix: a segmentation fault might occur in worker process if HTTPS was used; the bug had appeared in 0.6.23. Changes with nginx 0.6.23 27 Dec 2007 - *) Change: the "off" parameter in the "ssl_session_cache" directive; - now this is default parameter. - - *) Change: the "open_file_cache_retest" directive was renamed to the + *) Change: the "off" parameter in the "ssl_session_cache" directive; now + this is default parameter. + + *) Change: the "open_file_cache_retest" directive was renamed to the "open_file_cache_valid". *) Feature: the "open_file_cache_min_uses" directive. @@ -2259,20 +2293,20 @@ *) Feature: the "gzip_disable" directive. - *) Feature: the "memcached_pass" directive may be used inside the "if" + *) Feature: the "memcached_pass" directive may be used inside the "if" block. - *) Bugfix: a segmentation fault occurred in worker process, if the + *) Bugfix: a segmentation fault occurred in worker process, if the "memcached_pass" and "if" directives were used in the same location. - *) Bugfix: if a "satisfy_any on" directive was used and not all access - and auth modules directives were set, then other given access and + *) Bugfix: if a "satisfy_any on" directive was used and not all access + and auth modules directives were set, then other given access and auth directives were not tested; - *) Bugfix: regex parameters in a "valid_referers" directive were not + *) Bugfix: regex parameters in a "valid_referers" directive were not inherited from previous level. - *) Bugfix: a "post_action" directive did run if a request was completed + *) Bugfix: a "post_action" directive did run if a request was completed with 499 status code. *) Bugfix: optimization of 16K buffer usage in a SSL connection. @@ -2281,71 +2315,71 @@ *) Bugfix: the STARTTLS in SMTP mode did not work. Thanks to Oleg Motienko. - *) Bugfix: in HTTPS mode requests might fail with the "bad write retry" + *) Bugfix: in HTTPS mode requests might fail with the "bad write retry" error; the bug had appeared in 0.5.13. Changes with nginx 0.6.22 19 Dec 2007 - *) Change: now all ngx_http_perl_module methods return values copied to + *) Change: now all ngx_http_perl_module methods return values copied to perl's allocated memory. - *) Bugfix: if nginx was built with ngx_http_perl_module, the perl - before 5.8.6 was used, and perl supported threads, then during - reconfiguration the master process aborted; the bug had appeared in + *) Bugfix: if nginx was built with ngx_http_perl_module, the perl before + 5.8.6 was used, and perl supported threads, then during + reconfiguration the master process aborted; the bug had appeared in 0.5.9. Thanks to Boris Zhmurov. - *) Bugfix: the ngx_http_perl_module methods may get invalid values of + *) Bugfix: the ngx_http_perl_module methods may get invalid values of the regex captures. - *) Bugfix: a segmentation fault occurred in worker process, if the - $r->has_request_body() method was called for a request whose small + *) Bugfix: a segmentation fault occurred in worker process, if the + $r->has_request_body() method was called for a request whose small request body was already received. - *) Bugfix: large_client_header_buffers did not freed before going to + *) Bugfix: large_client_header_buffers did not freed before going to keep-alive state. Thanks to Olexander Shtepa. - *) Bugfix: the last address was missed in the $upstream_addr variable; + *) Bugfix: the last address was missed in the $upstream_addr variable; the bug had appeared in 0.6.18. - *) Bugfix: the "fastcgi_catch_stderr" directive did return error code; - now it returns 502 code, that can be rerouted to a next server using + *) Bugfix: the "fastcgi_catch_stderr" directive did return error code; + now it returns 502 code, that can be rerouted to a next server using the "fastcgi_next_upstream invalid_header" directive. - *) Bugfix: a segmentation fault occurred in master process if the - "fastcgi_catch_stderr" directive was used; the bug had appeared in + *) Bugfix: a segmentation fault occurred in master process if the + "fastcgi_catch_stderr" directive was used; the bug had appeared in 0.6.10. Thanks to Manlio Perillo. Changes with nginx 0.6.21 03 Dec 2007 - *) Change: if variable values used in a "proxy_pass" directive contain + *) Change: if variable values used in a "proxy_pass" directive contain IP-addresses only, then a "resolver" directive is not mandatory. - *) Bugfix: a segmentation fault might occur in worker process if a - "proxy_pass" directive with URI-part was used; the bug had appeared + *) Bugfix: a segmentation fault might occur in worker process if a + "proxy_pass" directive with URI-part was used; the bug had appeared in 0.6.19. - *) Bugfix: if resolver was used on platform that does not support + *) Bugfix: if resolver was used on platform that does not support kqueue, then nginx issued an alert "name is out of response". Thanks to Andrei Nigmatulin. - *) 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 + *) 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 + *) Bugfix: if a plain text HTTP/0.9 version request was made to HTTPS server, then nginx returned usual response. Changes with nginx 0.6.20 28 Nov 2007 - *) Bugfix: a segmentation fault might occur in worker process if a - "proxy_pass" directive with URI-part was used; the bug had appeared + *) Bugfix: a segmentation fault might occur in worker process if a + "proxy_pass" directive with URI-part was used; the bug had appeared in 0.6.19. @@ -2356,20 +2390,20 @@ Changes with nginx 0.6.18 27 Nov 2007 - *) Change: now the ngx_http_userid_module adds start time microseconds + *) Change: now the ngx_http_userid_module adds start time microseconds to the cookie field contains a pid value. - *) Change: now the full request line instead of URI only is written to + *) Change: now the full request line instead of URI only is written to error_log. *) Feature: variables support in the "proxy_pass" directive. *) Feature: the "resolver" and "resolver_timeout" directives. - *) Feature: now the directive "add_header last-modified ''" deletes a + *) Feature: now the directive "add_header last-modified ''" deletes a "Last-Modified" response header line. - *) Bugfix: the "limit_rate" directive did not allow to use full + *) Bugfix: the "limit_rate" directive did not allow to use full throughput, even if limit value was very high. @@ -2378,19 +2412,19 @@ *) Feature: the "If-Range" request header line support. Thanks to Alexander V. Inyukhin. - *) Bugfix: URL double escaping in a redirect of the "msie_refresh" + *) Bugfix: URL double escaping in a redirect of the "msie_refresh" directive; the bug had appeared in 0.6.4. - *) Bugfix: the "autoindex" directive did not work with the "alias /" + *) Bugfix: the "autoindex" directive did not work with the "alias /" directive. - *) Bugfix: a segmentation fault might occur in worker process if + *) Bugfix: a segmentation fault might occur in worker process if subrequests were used. - *) Bugfix: the big responses may be transferred truncated if SSL and + *) Bugfix: the big responses may be transferred truncated if SSL and gzip were used. - *) Bugfix: the $status variable was equal to 0 if a proxied server + *) Bugfix: the $status variable was equal to 0 if a proxied server returned response in HTTP/0.9 version. @@ -2399,8 +2433,8 @@ *) Change: now the uname(2) is used on Linux instead of procfs. Thanks to Ilya Novikov. - *) Bugfix: if the "?" character was in a "error_page" directive, then - it was escaped in a proxied request; the bug had appeared in 0.6.11. + *) Bugfix: if the "?" character was in a "error_page" directive, then it + was escaped in a proxied request; the bug had appeared in 0.6.11. *) Bugfix: compatibility with mget. @@ -2418,21 +2452,21 @@ *) 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 + *) 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 + *) Bugfix: nginx returned the 400 response on requests like "GET http://www.domain.com HTTP/1.0". Thanks to James Oakley. - *) Bugfix: if request with request body was redirected using the - "error_page" directive, then nginx tried to read the request body + *) Bugfix: if request with request body was redirected using the + "error_page" directive, then nginx tried to read the request body again; the bug had appeared in 0.6.7. - *) Bugfix: a segmentation fault occurred in worker process if no - server_name was explicitly defined for server processing request; - the bug had appeared in 0.6.7. + *) Bugfix: a segmentation fault occurred in worker process if no + server_name was explicitly defined for server processing request; the + bug had appeared in 0.6.7. Changes with nginx 0.6.14 15 Oct 2007 @@ -2441,31 +2475,31 @@ *) Feature: the "encoding" parameter in the "echo" SSI command. - *) Feature: the "access_log" directive may be used inside the + *) Feature: the "access_log" directive may be used inside the "limit_except" block. - *) Bugfix: if all upstream servers were failed, then all servers had - got weight the was equal one until servers became alive; the bug had + *) Bugfix: if all upstream servers were failed, then all servers had got + weight the was equal one until servers became alive; the bug had appeared in 0.6.6. - *) Bugfix: a segmentation fault occurred in worker process if - $date_local and $date_gmt were used outside the + *) 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 + *) 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 + *) 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 + *) Bugfix: a worker process may got caught in an endless loop, if the memcached was used. - *) Bugfix: nginx supported low case only "close" and "keep-alive" - values in the "Connection" request header line; the bug had appeared - in 0.6.11. + *) Bugfix: nginx supported low case only "close" and "keep-alive" values + in the "Connection" request header line; the bug had appeared in + 0.6.11. *) Bugfix: sub_filter did not work with empty substitution. @@ -2474,7 +2508,7 @@ Changes with nginx 0.6.13 24 Sep 2007 - *) Bugfix: nginx did not close directory file on HEAD request if + *) Bugfix: nginx did not close directory file on HEAD request if autoindex was used. Thanks to Arkadiusz Patyk. @@ -2483,82 +2517,82 @@ *) Change: mail proxy was split on three modules: pop3, imap and smtp. - *) Feature: the --without-mail_pop3_module, --without-mail_imap_module, + *) Feature: the --without-mail_pop3_module, --without-mail_imap_module, and --without-mail_smtp_module configuration parameters. - *) Feature: the "smtp_greeting_delay" and "smtp_client_buffer" + *) Feature: the "smtp_greeting_delay" and "smtp_client_buffer" directives of the ngx_mail_smtp_module. - *) Bugfix: the trailing wildcards did not work; the bug had appeared in + *) Bugfix: the trailing wildcards did not work; the bug had appeared in 0.6.9. - *) Bugfix: nginx could not start on Solaris if the shared PCRE library + *) Bugfix: nginx could not start on Solaris if the shared PCRE library located in non-standard place was used. - *) Bugfix: the "proxy_hide_header" and "fastcgi_hide_header" directives - did not hide response header lines whose name was longer than 32 + *) Bugfix: the "proxy_hide_header" and "fastcgi_hide_header" directives + did not hide response header lines whose name was longer than 32 characters. Thanks to Manlio Perillo. Changes with nginx 0.6.11 11 Sep 2007 - *) Bugfix: active connection counter always increased if mail proxy was + *) Bugfix: active connection counter always increased if mail proxy was used. - *) Bugfix: if backend returned response header only using non-buffered + *) Bugfix: if backend returned response header only using non-buffered proxy, then nginx closed backend connection on timeout. - *) Bugfix: nginx did not support several "Connection" request header + *) Bugfix: nginx did not support several "Connection" request header lines. - *) Bugfix: if the "max_fails" was set for upstream server, then after - first failure server weight was always one; the bug had appeared in + *) Bugfix: if the "max_fails" was set for upstream server, then after + first failure server weight was always one; the bug had appeared in 0.6.6. Changes with nginx 0.6.10 03 Sep 2007 - *) Feature: the "open_file_cache", "open_file_cache_retest", and + *) Feature: the "open_file_cache", "open_file_cache_retest", and "open_file_cache_errors" directives. *) Bugfix: socket leak; the bug had appeared in 0.6.7. - *) Bugfix: a charset set by the "charset" directive was not appended to + *) Bugfix: a charset set by the "charset" directive was not appended to the "Content-Type" header set by $r->send_http_header(). - *) Bugfix: a segmentation fault might occur in worker process if + *) Bugfix: a segmentation fault might occur in worker process if /dev/poll method was used. Changes with nginx 0.6.9 28 Aug 2007 - *) Bugfix: a worker process may got caught in an endless loop, if the + *) Bugfix: a worker process may got caught in an endless loop, if the HTTPS protocol was used; the bug had appeared in 0.6.7. - *) Bugfix: if server listened on two addresses or ports and trailing + *) Bugfix: if server listened on two addresses or ports and trailing wildcard was used, then nginx did not run. - *) Bugfix: the "ip_hash" directive might incorrectly mark servers as + *) Bugfix: the "ip_hash" directive might incorrectly mark servers as down. - *) Bugfix: nginx could not be built on amd64; the bug had appeared in + *) Bugfix: nginx could not be built on amd64; the bug had appeared in 0.6.8. Changes with nginx 0.6.8 20 Aug 2007 - *) Change: now nginx tries to set the "worker_priority", - "worker_rlimit_nofile", "worker_rlimit_core", and + *) Change: now nginx tries to set the "worker_priority", + "worker_rlimit_nofile", "worker_rlimit_core", and "worker_rlimit_sigpending" without super-user privileges. - *) Change: now nginx escapes space and "%" in request to a mail proxy + *) Change: now nginx escapes space and "%" in request to a mail proxy authentication server. *) Change: now nginx escapes "%" in $memcached_key variable. - *) Bugfix: nginx used path relative to configuration prefix for - non-absolute configuration file path specified in the "-c" key; the + *) Bugfix: nginx used path relative to configuration prefix for + non-absolute configuration file path specified in the "-c" key; the bug had appeared in 0.6.6. *) Bugfix: nginx did not work on FreeBSD/sparc64. @@ -2566,45 +2600,45 @@ Changes with nginx 0.6.7 15 Aug 2007 - *) Change: now the paths specified in the "include", - "auth_basic_user_file", "perl_modules", "ssl_certificate", - "ssl_certificate_key", and "ssl_client_certificate" directives are - relative to directory of nginx configuration file nginx.conf, but - not to nginx prefix directory. + *) Change: now the paths specified in the "include", + "auth_basic_user_file", "perl_modules", "ssl_certificate", + "ssl_certificate_key", and "ssl_client_certificate" directives are + relative to directory of nginx configuration file nginx.conf, but not + to nginx prefix directory. *) Change: the --sysconfdir=PATH option in configure was canceled. - *) Change: the special make target "upgrade1" was defined for online + *) Change: the special make target "upgrade1" was defined for online upgrade of 0.1.x versions. - *) Feature: the "server_name" and "valid_referers" directives support + *) Feature: the "server_name" and "valid_referers" directives support regular expressions. - *) Feature: the "server" directive in the "upstream" context supports + *) Feature: the "server" directive in the "upstream" context supports the "backup" parameter. - *) Feature: the ngx_http_perl_module supports the + *) Feature: the ngx_http_perl_module supports the $r->discard_request_body. - *) Feature: the "add_header Last-Modified ..." directive changes the + *) Feature: the "add_header Last-Modified ..." directive changes the "Last-Modified" response header line. - *) Bugfix: if a response different than 200 was returned to a request - with body and connection went to the keep-alive state after the + *) Bugfix: if a response different than 200 was returned to a request + with body and connection went to the keep-alive state after the request, then nginx returned 400 for the next request. - *) Bugfix: a segmentation fault occurred in worker process if invalid + *) Bugfix: a segmentation fault occurred in worker process if invalid address was set in the "auth_http" directive. - *) Bugfix: now nginx uses default listen backlog value 511 on all + *) Bugfix: now nginx uses default listen backlog value 511 on all platforms except FreeBSD. Thanks to Jiang Hong. - *) Bugfix: a worker process may got caught in an endless loop, if a - "server" inside "upstream" block was marked as "down"; the bug had + *) Bugfix: a worker process may got caught in an endless loop, if a + "server" inside "upstream" block was marked as "down"; the bug had appeared in 0.6.6. - *) Bugfix: now Solaris sendfilev() is not used to transfer the client + *) Bugfix: now Solaris sendfilev() is not used to transfer the client request body to FastCGI-server via the unix domain socket. @@ -2620,13 +2654,13 @@ *) Bugfix: fair big weight upstream balancer. - *) Bugfix: if a client has closed connection to mail proxy then nginx + *) Bugfix: if a client has closed connection to mail proxy then nginx might not close connection to backend. - *) Bugfix: if the same host without specified port was used as backend + *) Bugfix: if the same host without specified port was used as backend for HTTP and HTTPS, then nginx used only one port - 80 or 443. - *) Bugfix: fix building on Solaris/amd64 by Sun Studio 11 and early + *) Bugfix: fix building on Solaris/amd64 by Sun Studio 11 and early versions; the bug had appeared in 0.6.4. @@ -2643,8 +2677,7 @@ *) Bugfix: now nginx escapes space in $memcached_key variable. - *) Bugfix: nginx was incorrectly built by Sun Studio on - Solaris/amd64. + *) Bugfix: nginx was incorrectly built by Sun Studio on Solaris/amd64. Thanks to Jiang Hong. *) Bugfix: of minor potential bugs. @@ -2656,13 +2689,13 @@ *) Security: the "msie_refresh" directive allowed XSS. Thanks to Maxim Boguk. - *) Change: the "proxy_store" and "fastcgi_store" directives were + *) Change: the "proxy_store" and "fastcgi_store" directives were changed. - *) Feature: the "proxy_store_access" and "fastcgi_store_access" + *) Feature: the "proxy_store_access" and "fastcgi_store_access" directives. - *) Bugfix: nginx did not work on Solaris/sparc64 if it was built by Sun + *) Bugfix: nginx did not work on Solaris/sparc64 if it was built by Sun Studio. Thanks to Andrei Nigmatulin. @@ -2674,79 +2707,79 @@ *) Feature: the "proxy_store" and "fastcgi_store" directives. - *) Bugfix: a segmentation fault might occur in worker process if the + *) Bugfix: a segmentation fault might occur in worker process if the "auth_http_header" directive was used. Thanks to Maxim Dounin. - *) Bugfix: a segmentation fault occurred in worker process if the + *) Bugfix: a segmentation fault occurred in worker process if the CRAM-MD5 authentication method was used, but it was not enabled. - *) Bugfix: a segmentation fault might occur in worker process when the + *) Bugfix: a segmentation fault might occur in worker process when the HTTPS protocol was used in the "proxy_pass" directive. - *) Bugfix: a segmentation fault might occur in worker process if the + *) Bugfix: a segmentation fault might occur in worker process if the eventport method was used. - *) Bugfix: the "proxy_ignore_client_abort" and - "fastcgi_ignore_client_abort" directives did not work; the bug had + *) Bugfix: the "proxy_ignore_client_abort" and + "fastcgi_ignore_client_abort" directives did not work; the bug had appeared in 0.5.13. Changes with nginx 0.6.2 09 Jul 2007 - *) Bugfix: if the FastCGI header was split in records, then nginx - passed garbage in the header to a client. + *) Bugfix: if the FastCGI header was split in records, then nginx passed + garbage in the header to a client. Changes with nginx 0.6.1 17 Jun 2007 *) Bugfix: in SSI parsing. - *) Bugfix: if remote SSI subrequest was used, then posterior local file + *) Bugfix: if remote SSI subrequest was used, then posterior local file subrequest might transferred to client in wrong order. - *) Bugfix: large SSI inclusions buffered in temporary files were + *) Bugfix: large SSI inclusions buffered in temporary files were truncated. - *) Bugfix: the perl $$ variable value in ngx_http_perl_module was equal + *) Bugfix: the perl $$ variable value in ngx_http_perl_module was equal to the master process identification number. Changes with nginx 0.6.0 14 Jun 2007 - *) Feature: the "server_name", "map", and "valid_referers" directives + *) Feature: the "server_name", "map", and "valid_referers" directives support the "www.example.*" wildcards. Changes with nginx 0.5.25 11 Jun 2007 - *) Bugfix: nginx could not be built with the - --without-http_rewrite_module parameter; the bug had appeared in + *) Bugfix: nginx could not be built with the + --without-http_rewrite_module parameter; the bug had appeared in 0.5.24. Changes with nginx 0.5.24 06 Jun 2007 - *) Security: the "ssl_verify_client" directive did not work if request + *) Security: the "ssl_verify_client" directive did not work if request was made using HTTP/0.9. - *) Bugfix: a part of response body might be passed uncompressed if gzip + *) Bugfix: a part of response body might be passed uncompressed if gzip was used; the bug had appeared in 0.5.23. Changes with nginx 0.5.23 04 Jun 2007 - *) Feature: the ngx_http_ssl_module supports Server Name Indication TLS + *) Feature: the ngx_http_ssl_module supports Server Name Indication TLS extension. *) Feature: the "fastcgi_catch_stderr" directive. Thanks to Nick S. Grechukh, OWOX project. - *) Bugfix: a segmentation fault occurred in master process if two + *) Bugfix: a segmentation fault occurred in master process if two virtual servers should bind() to the overlapping ports. - *) Bugfix: if nginx was built with ngx_http_perl_module and perl - supported threads, then during second reconfiguration the error + *) Bugfix: if nginx was built with ngx_http_perl_module and perl + supported threads, then during second reconfiguration the error messages "panic: MUTEX_LOCK" and "perl_parse() failed" were issued. *) Bugfix: in the HTTPS protocol in the "proxy_pass" directive. @@ -2754,20 +2787,20 @@ Changes with nginx 0.5.22 29 May 2007 - *) Bugfix: a big request body might not be passed to backend; the bug + *) Bugfix: a big request body might not be passed to backend; the bug had appeared in 0.5.21. Changes with nginx 0.5.21 28 May 2007 - *) Bugfix: if server has more than about ten locations, then regex + *) Bugfix: if server has more than about ten locations, then regex locations might be choosen not in that order as they were specified. - *) Bugfix: a worker process may got caught in an endless loop on 64-bit + *) Bugfix: a worker process may got caught in an endless loop on 64-bit platform, if the 33-rd or next in succession backend has failed. Thanks to Anton Povarov. - *) Bugfix: a bus error might occur on Solaris/sparc64 if the PCRE + *) Bugfix: a bus error might occur on Solaris/sparc64 if the PCRE library was used. Thanks to Andrei Nigmatulin. @@ -2778,22 +2811,21 @@ *) Feature: the "sendfile_max_chunk" directive. - *) Feature: the "$http_...", "$sent_http_...", and "$upstream_http_..." + *) Feature: the "$http_...", "$sent_http_...", and "$upstream_http_..." variables may be changed using the "set" directive. - *) Bugfix: a segmentation fault might occur in worker process if the - SSI command 'if expr="$var = /"' was used. - - *) Bugfix: trailing boundary of multipart range response was - transferred incorrectly. + *) Bugfix: a segmentation fault might occur in worker process if the SSI + command 'if expr="$var = /"' was used. + + *) Bugfix: trailing boundary of multipart range response was transferred + incorrectly. Thanks to Evan Miller. - *) Bugfix: nginx did not work on Solaris/sparc64 if it was built by Sun + *) Bugfix: nginx did not work on Solaris/sparc64 if it was built by Sun Studio. Thanks to Andrei Nigmatulin. - *) Bugfix: the ngx_http_perl_module could not be built by Solaris - make. + *) Bugfix: the ngx_http_perl_module could not be built by Solaris make. Thanks to Andrei Nigmatulin. @@ -2801,19 +2833,19 @@ *) Change: now the $request_time variable has millisecond precision. - *) Change: the method $r->rflush of ngx_http_perl_module was renamed to + *) Change: the method $r->rflush of ngx_http_perl_module was renamed to the $r->flush. *) Feature: the $upstream_addr variable. - *) Feature: the "proxy_headers_hash_max_size" and + *) Feature: the "proxy_headers_hash_max_size" and "proxy_headers_hash_bucket_size" directives. Thanks to Volodymyr Kostyrko. - *) Bugfix: the files more than 2G could not be transferred using + *) Bugfix: the files more than 2G could not be transferred using sendfile and limit_rate on 64-bit platforms. - *) Bugfix: the files more than 2G could not be transferred using + *) Bugfix: the files more than 2G could not be transferred using sendfile on 64-bit Linux. @@ -2823,16 +2855,16 @@ *) Feature: the "$upstream_http_..." variables. - *) Feature: now the $upstream_status and $upstream_response_time + *) Feature: now the $upstream_status and $upstream_response_time variables keep data about all upstreams before X-Accel-Redirect. - *) Bugfix: a segmentation fault occurred in master process after first - reconfiguration and receiving any signal if nginx was built with - ngx_http_perl_module and perl did not support multiplicity; the bug + *) Bugfix: a segmentation fault occurred in master process after first + reconfiguration and receiving any signal if nginx was built with + ngx_http_perl_module and perl did not support multiplicity; the bug had appeared in 0.5.9. - *) Bugfix: if perl did not support multiplicity, then after - reconfiguration perl code did not work; the bug had appeared in + *) Bugfix: if perl did not support multiplicity, then after + reconfiguration perl code did not work; the bug had appeared in 0.3.38. @@ -2840,68 +2872,68 @@ *) Change: now nginx always returns the 405 status for the TRACE method. - *) Feature: now nginx supports the "include" directive inside the + *) Feature: now nginx supports the "include" directive inside the "types" block. - *) Bugfix: the $document_root variable usage in the "root" and "alias" + *) Bugfix: the $document_root variable usage in the "root" and "alias" directives is disabled: this caused recursive stack overflow. *) Bugfix: in the HTTPS protocol in the "proxy_pass" directive. - *) Bugfix: in some cases non-cachable variables (such as $uri variable) + *) Bugfix: in some cases non-cachable variables (such as $uri variable) returned old cached value. Changes with nginx 0.5.16 26 Mar 2007 - *) Bugfix: the C-class network was not used as hash key in the - "ip_hash" directive. + *) Bugfix: the C-class network was not used as hash key in the "ip_hash" + directive. Thanks to Pavel Yarkovoy. - *) Bugfix: a segmentation fault might occur in worker process if a - charset was set in the "Content-Type" header line and the line has + *) Bugfix: a segmentation fault might occur in worker process if a + charset was set in the "Content-Type" header line and the line has trailing ";"; the bug had appeared in 0.3.50. - *) Bugfix: the "[alert] zero size buf" error when FastCGI server was - used and a request body written in a temporary file was multiple of + *) Bugfix: the "[alert] zero size buf" error when FastCGI server was + used and a request body written in a temporary file was multiple of 32K. - *) Bugfix: nginx could not be built on Solaris without the --with-debug + *) Bugfix: nginx could not be built on Solaris without the --with-debug option; the bug had appeared in 0.5.15. Changes with nginx 0.5.15 19 Mar 2007 - *) Feature: the mail proxy supports authenticated SMTP proxying and the + *) Feature: the mail proxy supports authenticated SMTP proxying and the "smtp_auth", "smtp_capablities", and "xclient" directives. Thanks to Anton Yuzhaninov and Maxim Dounin. - *) Feature: now the keep-alive connections are closed just after + *) Feature: now the keep-alive connections are closed just after receiving the reconfiguration signal. - *) Change: the "imap" and "auth" directives were renamed to the "mail" + *) Change: the "imap" and "auth" directives were renamed to the "mail" and "pop3_auth" directives. - *) Bugfix: a segmentation fault occurred in worker process if the - CRAM-MD5 authentication method was used and the APOP method was + *) Bugfix: a segmentation fault occurred in worker process if the + CRAM-MD5 authentication method was used and the APOP method was disabled. - *) Bugfix: if the "starttls only" directive was used in POP3 protocol, + *) Bugfix: if the "starttls only" directive was used in POP3 protocol, then nginx allowed authentication without switching to the SSL mode. - *) Bugfix: worker processes did not exit after reconfiguration and did + *) Bugfix: worker processes did not exit after reconfiguration and did not rotate logs if the eventport method was used. - *) Bugfix: a worker process may got caught in an endless loop, if the + *) Bugfix: a worker process may got caught in an endless loop, if the "ip_hash" directive was used. - *) Bugfix: now nginx does not log some alerts if eventport or /dev/poll + *) Bugfix: now nginx does not log some alerts if eventport or /dev/poll methods are used. Changes with nginx 0.5.14 23 Feb 2007 - *) Bugfix: nginx ignored superfluous closing "}" in the end of + *) Bugfix: nginx ignored superfluous closing "}" in the end of configuration file. @@ -2909,33 +2941,33 @@ *) Feature: the COPY and MOVE methods. - *) Bugfix: the ngx_http_realip_module set garbage for requests passed + *) Bugfix: the ngx_http_realip_module set garbage for requests passed via keep-alive connection. *) Bugfix: nginx did not work on big-endian 64-bit Linux. Thanks to Andrei Nigmatulin. - *) Bugfix: now when IMAP/POP3 proxy receives too long command it closes + *) Bugfix: now when IMAP/POP3 proxy receives too long command it closes the connection right away, but not after timeout. - *) Bugfix: if the "epoll" method was used and a client closed a - connection prematurely, then nginx closed the connection after a - send timeout only. - - *) Bugfix: nginx could not be built on platforms different from i386, + *) Bugfix: if the "epoll" method was used and a client closed a + connection prematurely, then nginx closed the connection after a send + timeout only. + + *) Bugfix: nginx could not be built on platforms different from i386, amd64, sparc, and ppc; the bug had appeared in 0.5.8. Changes with nginx 0.5.12 12 Feb 2007 - *) Bugfix: nginx could not be built on platforms different from i386, + *) Bugfix: nginx could not be built on platforms different from i386, amd64, sparc, and ppc; the bug had appeared in 0.5.8. - *) Bugfix: a segmentation fault might occur in worker process if the - temporary files were used while working with FastCGI server; the bug + *) Bugfix: a segmentation fault might occur in worker process if the + temporary files were used while working with FastCGI server; the bug had appeared in 0.5.8. - *) Bugfix: a segmentation fault might occur in worker process if the + *) Bugfix: a segmentation fault might occur in worker process if the $fastcgi_script_name variable was logged. *) Bugfix: ngx_http_perl_module could not be built on Solaris. @@ -2946,69 +2978,69 @@ *) Feature: now configure detects system PCRE library in MacPorts. Thanks to Chris McGrath. - *) Bugfix: the response was incorrect if several ranges were requested; + *) Bugfix: the response was incorrect if several ranges were requested; the bug had appeared in 0.5.6. - *) Bugfix: the "create_full_put_path" directive could not create the + *) Bugfix: the "create_full_put_path" directive could not create the intermediate directories if no "dav_access" directive was set. Thanks to Evan Miller. - *) Bugfix: the "0" response code might be logged in the access_log + *) Bugfix: the "0" response code might be logged in the access_log instead of the "400" and "408" error codes. - *) Bugfix: a segmentation fault might occur in worker process if nginx + *) Bugfix: a segmentation fault might occur in worker process if nginx was built with -O2 optimization. Changes with nginx 0.5.10 26 Jan 2007 - *) Bugfix: while online executable file upgrade the new master process + *) Bugfix: while online executable file upgrade the new master process did not inherit the listening sockets; the bug had appeared in 0.5.9. - *) Bugfix: a segmentation fault might occur in worker process if nginx + *) Bugfix: a segmentation fault might occur in worker process if nginx was built with -O2 optimization; the bug had appeared in 0.5.1. Changes with nginx 0.5.9 25 Jan 2007 - *) Change: now the ngx_http_memcached_module uses the $memcached_key + *) Change: now the ngx_http_memcached_module uses the $memcached_key variable value as a key. *) Feature: the $memcached_key variable. - *) Feature: the "clean" parameter in the "client_body_in_file_only" + *) Feature: the "clean" parameter in the "client_body_in_file_only" directive. *) Feature: the "env" directive. *) Feature: the "sendfile" directive is available inside the "if" block. - *) Feature: now on failure of the writing to access nginx logs a - message to error_log, but not more often than once a minute. - - *) Bugfix: the "access_log off" directive did not always turn off the + *) Feature: now on failure of the writing to access nginx logs a message + to error_log, but not more often than once a minute. + + *) Bugfix: the "access_log off" directive did not always turn off the logging. Changes with nginx 0.5.8 19 Jan 2007 - *) Bugfix: a segmentation fault might occur if + *) Bugfix: a segmentation fault might occur if "client_body_in_file_only on" was used and a request body was small. - *) Bugfix: a segmentation fault occurred if - "client_body_in_file_only on" and "proxy_pass_request_body off" or - "fastcgi_pass_request_body off" directives were used, and nginx + *) Bugfix: a segmentation fault occurred if + "client_body_in_file_only on" and "proxy_pass_request_body off" or + "fastcgi_pass_request_body off" directives were used, and nginx switched to a next upstream. - *) Bugfix: if the "proxy_buffering off" directive was used and a client - connection was non-active, then the connection was closed after send + *) Bugfix: if the "proxy_buffering off" directive was used and a client + connection was non-active, then the connection was closed after send timeout; the bug had appeared in 0.4.7. - *) Bugfix: if the "epoll" method was used and a client closed a - connection prematurely, then nginx closed the connection after a - send timeout only. - - *) Bugfix: the "[alert] zero size buf" error when FastCGI server was + *) Bugfix: if the "epoll" method was used and a client closed a + connection prematurely, then nginx closed the connection after a send + timeout only. + + *) Bugfix: the "[alert] zero size buf" error when FastCGI server was used. *) Bugfixes in the "limit_zone" directive. @@ -3020,15 +3052,15 @@ *) Bugfixes in the "ssl_session_cache" and "limit_zone" directives. - *) Bugfix: the segmentation fault was occurred on start or while - reconfiguration if the "ssl_session_cache" or "limit_zone" - directives were used on 64-bit platforms. - - *) Bugfix: a segmentation fault occurred if the "add_before_body" or - "add_after_body" directives were used and there was no - "Content-Type" header line in response. - - *) Bugfix: the OpenSSL library was always built with the threads + *) Bugfix: the segmentation fault was occurred on start or while + reconfiguration if the "ssl_session_cache" or "limit_zone" directives + were used on 64-bit platforms. + + *) Bugfix: a segmentation fault occurred if the "add_before_body" or + "add_after_body" directives were used and there was no "Content-Type" + header line in response. + + *) Bugfix: the OpenSSL library was always built with the threads support. Thanks to Den Ivanov. @@ -3037,19 +3069,19 @@ Changes with nginx 0.5.6 09 Jan 2007 - *) Change: now the ngx_http_index_module ignores all methods except the + *) Change: now the ngx_http_index_module ignores all methods except the GET, HEAD, and POST methods. *) Feature: the ngx_http_limit_zone_module. *) Feature: the $binary_remote_addr variable. - *) Feature: the "ssl_session_cache" directives of the + *) Feature: the "ssl_session_cache" directives of the ngx_http_ssl_module and ngx_imap_ssl_module. *) Feature: the DELETE method supports recursive removal. - *) Bugfix: the byte-ranges were transferred incorrectly if the + *) Bugfix: the byte-ranges were transferred incorrectly if the $r->sendfile() was used. @@ -3059,13 +3091,13 @@ *) Feature: the -V switch. - *) Feature: the "worker_rlimit_core" directive supports size in K, M, + *) Feature: the "worker_rlimit_core" directive supports size in K, M, and G. - *) Bugfix: the nginx.pm module now could be installed by an - unprivileged user. - - *) Bugfix: a segmentation fault might occur if the $r->request_body or + *) Bugfix: the nginx.pm module now could be installed by an unprivileged + user. + + *) Bugfix: a segmentation fault might occur if the $r->request_body or $r->request_body_file methods were used. *) Bugfix: the ppc platform specific bugs. @@ -3073,85 +3105,85 @@ Changes with nginx 0.5.4 15 Dec 2006 - *) Feature: the "perl" directive may be used inside the "limit_except" + *) Feature: the "perl" directive may be used inside the "limit_except" block. - *) Bugfix: the ngx_http_dav_module required the "Date" request header + *) Bugfix: the ngx_http_dav_module required the "Date" request header line for the DELETE method. - *) Bugfix: if one only parameter was used in the "dav_access" - directive, then nginx might report about configuration error. - - *) Bugfix: a segmentation fault might occur if the $host variable was + *) Bugfix: if one only parameter was used in the "dav_access" directive, + then nginx might report about configuration error. + + *) Bugfix: a segmentation fault might occur if the $host variable was used; the bug had appeared in 0.4.14. Changes with nginx 0.5.3 13 Dec 2006 - *) Feature: the ngx_http_perl_module supports the $r->status, + *) Feature: the ngx_http_perl_module supports the $r->status, $r->log_error, and $r->sleep methods. - *) Feature: the $r->variable method supports variables that do not - exist in nginx configuration. + *) Feature: the $r->variable method supports variables that do not exist + in nginx configuration. *) Bugfix: the $r->has_request_body method did not work. Changes with nginx 0.5.2 11 Dec 2006 - *) Bugfix: if the "proxy_pass" directive used the name of the - "upstream" block, then nginx tried to resolve the name; the bug had - appeared in 0.5.1. + *) Bugfix: if the "proxy_pass" directive used the name of the "upstream" + block, then nginx tried to resolve the name; the bug had appeared in + 0.5.1. Changes with nginx 0.5.1 11 Dec 2006 - *) Bugfix: the "post_action" directive might not run after a + *) Bugfix: the "post_action" directive might not run after a unsuccessful completion of a request. *) Workaround: for Eudora for Mac; the bug had appeared in 0.4.11. Thanks to Bron Gondwana. - *) Bugfix: if the "upstream" name was used in the "fastcgi_pass", then - the message "no port in upstream" was issued; the bug had appeared - in 0.5.0. - - *) Bugfix: if the "proxy_pass" and "fastcgi_pass" directives used the - same servers but different ports, then these directives uses the + *) Bugfix: if the "upstream" name was used in the "fastcgi_pass", then + the message "no port in upstream" was issued; the bug had appeared in + 0.5.0. + + *) Bugfix: if the "proxy_pass" and "fastcgi_pass" directives used the + same servers but different ports, then these directives uses the first described port; the bug had appeared in 0.5.0. - *) Bugfix: if the "proxy_pass" and "fastcgi_pass" directives used the - unix domain sockets, then these directives used first described + *) Bugfix: if the "proxy_pass" and "fastcgi_pass" directives used the + unix domain sockets, then these directives used first described socket; the bug had appeared in 0.5.0. - *) Bugfix: ngx_http_auth_basic_module ignored the user if it was in the - last line in the password file and there was no the carriage return, + *) Bugfix: ngx_http_auth_basic_module ignored the user if it was in the + last line in the password file and there was no the carriage return, the line feed, or the ":" symbol after the password. - *) Bugfix: the $upstream_response_time variable might be equal to + *) Bugfix: the $upstream_response_time variable might be equal to "0.000", although response time was more than 1 millisecond. Changes with nginx 0.5.0 04 Dec 2006 - *) Change: the parameters in the "%name" form in the "log_format" + *) Change: the parameters in the "%name" form in the "log_format" directive are not supported anymore. - *) Change: the "proxy_upstream_max_fails", - "proxy_upstream_fail_timeout", "fastcgi_upstream_max_fails", - "fastcgi_upstream_fail_timeout", "memcached_upstream_max_fails", and - "memcached_upstream_fail_timeout" directives are not supported + *) Change: the "proxy_upstream_max_fails", + "proxy_upstream_fail_timeout", "fastcgi_upstream_max_fails", + "fastcgi_upstream_fail_timeout", "memcached_upstream_max_fails", and + "memcached_upstream_fail_timeout" directives are not supported anymore. - *) Feature: the "server" directive in the "upstream" context supports + *) Feature: the "server" directive in the "upstream" context supports the "max_fails", "fail_timeout", and "down" parameters. *) Feature: the "ip_hash" directive inside the "upstream" block. - *) Feature: the WAIT status in the "Auth-Status" header line of the + *) Feature: the WAIT status in the "Auth-Status" header line of the IMAP/POP3 proxy authentication server response. - *) Bugfix: nginx could not be built on 64-bit platforms; the bug had + *) Bugfix: nginx could not be built on 64-bit platforms; the bug had appeared in 0.4.14. @@ -3159,62 +3191,62 @@ *) Feature: the "proxy_pass_error_message" directive in IMAP/POP3 proxy. - *) Feature: now configure detects system PCRE library on FreeBSD, - Linux, and NetBSD. - - *) Bugfix: ngx_http_perl_module did not work with perl built with the + *) Feature: now configure detects system PCRE library on FreeBSD, Linux, + and NetBSD. + + *) Bugfix: ngx_http_perl_module did not work with perl built with the threads support; the bug had appeared in 0.3.38. - *) Bugfix: ngx_http_perl_module did not work if perl was called + *) Bugfix: ngx_http_perl_module did not work if perl was called recursively. *) Bugfix: nginx ignored a host name in a request line. - *) Bugfix: a worker process may got caught in an endless loop, if a + *) Bugfix: a worker process may got caught in an endless loop, if a FastCGI server sent too many data to the stderr. - *) Bugfix: the $upstream_response_time variable may be negative if the + *) Bugfix: the $upstream_response_time variable may be negative if the system time was changed backward. - *) Bugfix: the "Auth-Login-Attempt" parameter was not sent to IMAP/POP3 + *) Bugfix: the "Auth-Login-Attempt" parameter was not sent to IMAP/POP3 proxy authentication server when POP3 was used. - *) Bugfix: a segmentation fault might occur if connect to IMAP/POP3 + *) Bugfix: a segmentation fault might occur if connect to IMAP/POP3 proxy authentication server failed. Changes with nginx 0.4.13 15 Nov 2006 - *) Feature: the "proxy_pass" directive may be used inside the + *) Feature: the "proxy_pass" directive may be used inside the "limit_except" block. *) Feature: the "limit_except" directive supports all WebDAV methods. - *) Bugfix: if the "add_before_body" directive was used without the - "add_after_body" directive, then a response did not transferred + *) Bugfix: if the "add_before_body" directive was used without the + "add_after_body" directive, then a response did not transferred complete. - *) Bugfix: a large request body did not receive if the epoll method and + *) Bugfix: a large request body did not receive if the epoll method and the deferred accept() were used. - *) Bugfix: a charset could not be set for ngx_http_autoindex_module + *) Bugfix: a charset could not be set for ngx_http_autoindex_module responses; the bug had appeared in 0.3.50. - *) Bugfix: the "[alert] zero size buf" error when FastCGI server was + *) Bugfix: the "[alert] zero size buf" error when FastCGI server was used; *) Bugfix: the --group= configuration parameter was ignored. Thanks to Thomas Moschny. - *) Bugfix: the 50th subrequest in SSI response did not work; the bug - had appeared in 0.3.50. + *) Bugfix: the 50th subrequest in SSI response did not work; the bug had + appeared in 0.3.50. Changes with nginx 0.4.12 31 Oct 2006 *) Feature: the ngx_http_perl_module supports the $r->variable method. - *) Bugfix: if a big static file was included using SSI in a response, + *) Bugfix: if a big static file was included using SSI in a response, then the response may be transferred incomplete. *) Bugfix: nginx did not omit the "#fragment" part in URI. @@ -3224,28 +3256,28 @@ *) Feature: the POP3 proxy supports the AUTH LOGIN PLAIN and CRAM-MD5. - *) Feature: the ngx_http_perl_module supports the $r->allow_ranges + *) Feature: the ngx_http_perl_module supports the $r->allow_ranges method. - *) Bugfix: if the APOP was enabled in the POP3 proxy, then the - USER/PASS commands might not work; the bug had appeared in 0.4.10. + *) Bugfix: if the APOP was enabled in the POP3 proxy, then the USER/PASS + commands might not work; the bug had appeared in 0.4.10. Changes with nginx 0.4.10 23 Oct 2006 *) Feature: the POP3 proxy supports the APOP command. - *) Bugfix: if the select, poll or /dev/poll methods were used, then - while waiting authentication server response the IMAP/POP3 proxy + *) Bugfix: if the select, poll or /dev/poll methods were used, then + while waiting authentication server response the IMAP/POP3 proxy hogged CPU. - *) Bugfix: a segmentation fault might occur if the $server_addr - variable was used in the "map" directive. - - *) Bugfix: the ngx_http_flv_module did not support the byte ranges for + *) Bugfix: a segmentation fault might occur if the $server_addr variable + was used in the "map" directive. + + *) Bugfix: the ngx_http_flv_module did not support the byte ranges for full responses; the bug had appeared in 0.4.7. - *) Bugfix: nginx could not be built on Debian amd64; the bug had + *) Bugfix: nginx could not be built on Debian amd64; the bug had appeared in 0.4.9. @@ -3253,17 +3285,17 @@ *) Feature: the "set" parameter in the "include" SSI command. - *) Feature: the ngx_http_perl_module now tests the nginx.pm module + *) Feature: the ngx_http_perl_module now tests the nginx.pm module version. Changes with nginx 0.4.8 11 Oct 2006 - *) Bugfix: if an "include" SSI command were before another "include" - SSI command with a "wait" parameter, then the "wait" parameter might - not work. - - *) Bugfix: the ngx_http_flv_module added the FLV header to the full + *) Bugfix: if an "include" SSI command were before another "include" SSI + command with a "wait" parameter, then the "wait" parameter might not + work. + + *) Bugfix: the ngx_http_flv_module added the FLV header to the full responses. Thanks to Alexey Kovyrin. @@ -3274,38 +3306,38 @@ *) Feature: the $request_body_file variable. - *) Feature: the "charset" and "source_charset" directives support the + *) Feature: the "charset" and "source_charset" directives support the variables. - *) Bugfix: if an "include" SSI command were before another "include" - SSI command with a "wait" parameter, then the "wait" parameter might - not work. - - *) Bugfix: if the "proxy_buffering off" directive was used or while - working with memcached the connections might not be closed on + *) Bugfix: if an "include" SSI command were before another "include" SSI + command with a "wait" parameter, then the "wait" parameter might not + work. + + *) Bugfix: if the "proxy_buffering off" directive was used or while + working with memcached the connections might not be closed on timeout. - *) Bugfix: nginx did not run on 64-bit platforms except amd64, sparc64, + *) Bugfix: nginx did not run on 64-bit platforms except amd64, sparc64, and ppc64. Changes with nginx 0.4.6 06 Oct 2006 - *) Bugfix: nginx did not run on 64-bit platforms except amd64, sparc64, + *) Bugfix: nginx did not run on 64-bit platforms except amd64, sparc64, and ppc64. *) Bugfix: nginx sent the chunked response for HTTP/1.1 request, - if its length was set by text string in the + if its length was set by text string in the $r->headers_out("Content-Length", ...) method. - *) Bugfix: after redirecting error by an "error_page" directive any - ngx_http_rewrite_module directive returned this error code; the bug + *) Bugfix: after redirecting error by an "error_page" directive any + ngx_http_rewrite_module directive returned this error code; the bug had appeared in 0.4.4. Changes with nginx 0.4.5 02 Oct 2006 - *) Bugfix: nginx could not be built on Linux and Solaris; the bug had + *) Bugfix: nginx could not be built on Linux and Solaris; the bug had appeared in 0.4.4. @@ -3318,29 +3350,29 @@ *) Feature: the "include" directive supports the "*" mask. Thanks to Jonathan Dance. - *) Bugfix: the "return" directive always overrode the "error_page" + *) Bugfix: the "return" directive always overrode the "error_page" response code redirected by the "error_page" directive. - *) Bugfix: a segmentation fault occurred if zero-length body was in PUT + *) Bugfix: a segmentation fault occurred if zero-length body was in PUT method. - *) Bugfix: the redirect was changed incorrectly if the variables were + *) Bugfix: the redirect was changed incorrectly if the variables were used in the "proxy_redirect" directive. Changes with nginx 0.4.3 26 Sep 2006 - *) Change: now the 499 error could not be redirected using an + *) Change: now the 499 error could not be redirected using an "error_page" directive. *) Feature: the Solaris 10 event ports support. *) Feature: the ngx_http_browser_module. - *) Bugfix: a segmentation fault may occur while redirecting the 400 + *) Bugfix: a segmentation fault may occur while redirecting the 400 error to the proxied server using a "proxy_pass" directive. - *) Bugfix: a segmentation fault occurred if an unix domain socket was + *) Bugfix: a segmentation fault occurred if an unix domain socket was used in a "proxy_pass" directive; the bug had appeared in 0.3.47. *) Bugfix: SSI did work with memcached and nonbuffered responses. @@ -3350,8 +3382,8 @@ Changes with nginx 0.4.2 14 Sep 2006 - *) Bugfix: the O_NOATIME flag support on Linux was canceled; the bug - had appeared in 0.4.1. + *) Bugfix: the O_NOATIME flag support on Linux was canceled; the bug had + appeared in 0.4.1. Changes with nginx 0.4.1 14 Sep 2006 @@ -3359,32 +3391,31 @@ *) Bugfix: the DragonFlyBSD compatibility. Thanks to Pavel Nazarov. - *) Workaround: of bug in 64-bit Linux sendfile(), when file is more - than 2G. - - *) Feature: now on Linux nginx uses O_NOATIME flag for static - requests. + *) Workaround: of bug in 64-bit Linux sendfile(), when file is more than + 2G. + + *) Feature: now on Linux nginx uses O_NOATIME flag for static requests. Thanks to Yusuf Goolamabbas. Changes with nginx 0.4.0 30 Aug 2006 - *) Change in internal API: the HTTP modules initialization was moved + *) Change in internal API: the HTTP modules initialization was moved from the init module phase to the HTTP postconfiguration phase. - *) Change: now the request body is not read beforehand for the - ngx_http_perl_module: it's required to start the reading using the + *) Change: now the request body is not read beforehand for the + ngx_http_perl_module: it's required to start the reading using the $r->has_request_body method. *) Feature: the ngx_http_perl_module supports the DECLINED return code. - *) Feature: the ngx_http_dav_module supports the incoming "Date" header + *) Feature: the ngx_http_dav_module supports the incoming "Date" header line for the PUT method. *) Feature: the "ssi" directive is available inside the "if" block. - *) Bugfix: a segmentation fault occurred if there was an "index" - directive with variables and the first index name was without + *) Bugfix: a segmentation fault occurred if there was an "index" + directive with variables and the first index name was without variables; the bug had appeared in 0.1.29. @@ -3396,26 +3427,26 @@ *) Feature: the "recursive_error_pages" directive. - *) Bugfix: the "rewrite" directive returned incorrect redirect, if the + *) Bugfix: the "rewrite" directive returned incorrect redirect, if the redirect had the captured escaped symbols from original URI. Changes with nginx 0.3.60 18 Aug 2006 - *) Bugfix: a worker process may got caught in an endless loop while an + *) Bugfix: a worker process may got caught in an endless loop while an error redirection; the bug had appeared in 0.3.59. Changes with nginx 0.3.59 16 Aug 2006 - *) Feature: now is possible to do several redirection using the + *) Feature: now is possible to do several redirection using the "error_page" directive. *) Bugfix: the "dav_access" directive did not support three parameters. - *) Bugfix: the "error_page" directive did not changes the - "Content-Type" header line after the "X-Accel-Redirect" was used; - the bug had appeared in 0.3.58. + *) Bugfix: the "error_page" directive did not changes the "Content-Type" + header line after the "X-Accel-Redirect" was used; the bug had + appeared in 0.3.58. Changes with nginx 0.3.58 14 Aug 2006 @@ -3424,12 +3455,12 @@ *) Change: now the procfs interface instead of sysctl is used on Linux. - *) Change: now the "Content-Type" header line is inherited from first + *) Change: now the "Content-Type" header line is inherited from first response when the "X-Accel-Redirect" was used. *) Bugfix: the "error_page" directive did not redirect the 413 error. - *) Bugfix: the trailing "?" did not remove old arguments if no new + *) Bugfix: the trailing "?" did not remove old arguments if no new arguments were added to a rewritten URI. *) Bugfix: nginx could not run on 64-bit FreeBSD 7.0-CURRENT. @@ -3442,10 +3473,10 @@ *) Bugfix: in the "!-e" operator of the "if" directive. Thanks to Andrian Budanstov. - *) Bugfix: while a client certificate verification nginx did not send - to a client the required certificates information. - - *) Bugfix: the $document_root variable did not support the variables in + *) Bugfix: while a client certificate verification nginx did not send to + a client the required certificates information. + + *) Bugfix: the $document_root variable did not support the variables in the "root" directive. @@ -3453,11 +3484,11 @@ *) Feature: the "dav_access" directive. - *) Feature: the "if" directive supports the "-d", "!-d", "-e", "!-e", + *) Feature: the "if" directive supports the "-d", "!-d", "-e", "!-e", "-x", and "!-x" operators. - *) Bugfix: a segmentation fault occurred if a request returned a - redirect and some sent to client header lines were logged in the + *) Bugfix: a segmentation fault occurred if a request returned a + redirect and some sent to client header lines were logged in the access log. @@ -3469,108 +3500,108 @@ *) Feature: the unicode2nginx script was added to contrib. - *) Bugfix: if a "root" was specified by variable only, then the root - was relative to a server prefix. - - *) Bugfix: if the request contained "//" or "/./" and escaped symbols + *) Bugfix: if a "root" was specified by variable only, then the root was + relative to a server prefix. + + *) Bugfix: if the request contained "//" or "/./" and escaped symbols after them, then the proxied request was sent unescaped. - *) Bugfix: the $r->header_in("Cookie") of the ngx_http_perl_module now + *) Bugfix: the $r->header_in("Cookie") of the ngx_http_perl_module now returns all "Cookie" header lines. - *) Bugfix: a segmentation fault occurred if - "client_body_in_file_only on" was used and nginx switched to a next + *) Bugfix: a segmentation fault occurred if + "client_body_in_file_only on" was used and nginx switched to a next upstream. - *) Bugfix: on some condition while reconfiguration character codes - inside the "charset_map" may be treated invalid; the bug had - appeared in 0.3.50. + *) Bugfix: on some condition while reconfiguration character codes + inside the "charset_map" may be treated invalid; the bug had appeared + in 0.3.50. Changes with nginx 0.3.54 11 Jul 2006 *) Feature: nginx now logs the subrequest information to the error log. - *) Feature: the "proxy_next_upstream", "fastcgi_next_upstream", and + *) Feature: the "proxy_next_upstream", "fastcgi_next_upstream", and "memcached_next_upstream" directives support the "off" parameter. - *) Feature: the "debug_connection" directive supports the CIDR address + *) Feature: the "debug_connection" directive supports the CIDR address form. - *) Bugfix: if a response of proxied server or FastCGI server was + *) Bugfix: if a response of proxied server or FastCGI server was converted from UTF-8 or back, then it may be transferred incomplete. - *) Bugfix: the $upstream_response_time variable had the time of the + *) Bugfix: the $upstream_response_time variable had the time of the first request to a backend only. - *) Bugfix: nginx could not be built on amd64 platform; the bug had + *) Bugfix: nginx could not be built on amd64 platform; the bug had appeared in 0.3.53. Changes with nginx 0.3.53 07 Jul 2006 - *) Change: the "add_header" directive adds the string to 204, 301, and + *) Change: the "add_header" directive adds the string to 204, 301, and 302 responses. - *) Feature: the "server" directive in the "upstream" context supports + *) Feature: the "server" directive in the "upstream" context supports the "weight" parameter. *) Feature: the "server_name" directive supports the "*" wildcard. *) Feature: nginx supports the request body size more than 2G. - *) Bugfix: if a client was successfully authorized using "satisfy_any - on", then anyway the message "access forbidden by rule" was written + *) Bugfix: if a client was successfully authorized using "satisfy_any + on", then anyway the message "access forbidden by rule" was written in the log. - *) Bugfix: the "PUT" method may erroneously not create a file and - return the 409 code. - - *) Bugfix: if the IMAP/POP3 backend returned an error, then nginx + *) Bugfix: the "PUT" method may erroneously not create a file and return + the 409 code. + + *) Bugfix: if the IMAP/POP3 backend returned an error, then nginx continued proxying anyway. Changes with nginx 0.3.52 03 Jul 2006 - *) Change: the ngx_http_index_module behavior for the "POST /" requests - is reverted to the 0.3.40 version state: the module now does not + *) Change: the ngx_http_index_module behavior for the "POST /" requests + is reverted to the 0.3.40 version state: the module now does not return the 405 error. - *) Bugfix: the worker process may got caught in an endless loop if the + *) Bugfix: the worker process may got caught in an endless loop if the limit rate was used; the bug had appeared in 0.3.37. - *) Bugfix: ngx_http_charset_module logged "unknown charset" alert, even + *) Bugfix: ngx_http_charset_module logged "unknown charset" alert, even if the recoding was not needed; the bug had appeared in 0.3.50. - *) Bugfix: if a code response of the PUT request was 409, then a + *) Bugfix: if a code response of the PUT request was 409, then a temporary file was not removed. Changes with nginx 0.3.51 30 Jun 2006 - *) Bugfix: the "<" symbols might disappeared some conditions in the - SSI; the bug had appeared in 0.3.50. + *) Bugfix: the "<" symbols might disappeared some conditions in the SSI; + the bug had appeared in 0.3.50. Changes with nginx 0.3.50 28 Jun 2006 - *) Change: the "proxy_redirect_errors" and "fastcgi_redirect_errors" - directives was renamed to the "proxy_intercept_errors" and + *) Change: the "proxy_redirect_errors" and "fastcgi_redirect_errors" + directives was renamed to the "proxy_intercept_errors" and "fastcgi_intercept_errors" directives. - *) Feature: the ngx_http_charset_module supports the recoding from the + *) Feature: the ngx_http_charset_module supports the recoding from the single byte encodings to the UTF-8 encoding and back. - *) Feature: the "X-Accel-Charset" response header line is supported in + *) Feature: the "X-Accel-Charset" response header line is supported in proxy and FastCGI mode. - *) Bugfix: the "\" escape symbol in the "\"" and "\'" pairs in the SSI + *) Bugfix: the "\" escape symbol in the "\"" and "\'" pairs in the SSI command was removed only if the command also has the "$" symbol. - *) Bugfix: the "<!--" string might be added on some conditions in the + *) Bugfix: the "<!--" string might be added on some conditions in the SSI after inclusion. - *) Bugfix: if the "Content-Length: 0" header line was in response, then + *) Bugfix: if the "Content-Length: 0" header line was in response, then in nonbuffered proxying mode the client connection was not closed. @@ -3578,26 +3609,26 @@ *) Bugfix: in the "set" directive. - *) Bugfix: if two or more FastCGI subrequests was in SSI, then first - subrequest output was included instead of second and following + *) Bugfix: if two or more FastCGI subrequests was in SSI, then first + subrequest output was included instead of second and following subrequests. Changes with nginx 0.3.48 29 May 2006 - *) Change: now the ngx_http_charset_module works for subrequests, if - the response has no "Content-Type" header line. - - *) Bugfix: if the "proxy_pass" directive has no URI part, then the - "proxy_redirect default" directive add the unnecessary slash in - start of the rewritten redirect. - - *) Bugfix: the internal redirect always transform client's HTTP method - to GET, now the transformation is made for the "X-Accel-Redirect" - redirects only and if the method is not HEAD; the bug had appeared - in 0.3.42. - - *) Bugfix: the ngx_http_perl_module could not be built, if the perl was + *) Change: now the ngx_http_charset_module works for subrequests, if the + response has no "Content-Type" header line. + + *) Bugfix: if the "proxy_pass" directive has no URI part, then the + "proxy_redirect default" directive add the unnecessary slash in start + of the rewritten redirect. + + *) Bugfix: the internal redirect always transform client's HTTP method + to GET, now the transformation is made for the "X-Accel-Redirect" + redirects only and if the method is not HEAD; the bug had appeared in + 0.3.42. + + *) Bugfix: the ngx_http_perl_module could not be built, if the perl was built with the threads support; the bug had appeared in 0.3.46. @@ -3605,42 +3636,42 @@ *) Feature: the "upstream" directive. - *) Change: now the "\" escape symbol in the "\"" and "\'" pairs in the + *) Change: now the "\" escape symbol in the "\"" and "\'" pairs in the SSI command is always removed. Changes with nginx 0.3.46 11 May 2006 - *) Feature: the "proxy_hide_header", "proxy_pass_header", + *) Feature: the "proxy_hide_header", "proxy_pass_header", "fastcgi_hide_header", and "fastcgi_pass_header" directives. - *) Change: the "proxy_pass_x_powered_by", "fastcgi_x_powered_by", and + *) Change: the "proxy_pass_x_powered_by", "fastcgi_x_powered_by", and "proxy_pass_server" directives were canceled. - *) Feature: the "X-Accel-Buffering" response header line is supported - in proxy mode. - - *) Bugfix: the reconfiguration bug and memory leaks in the + *) Feature: the "X-Accel-Buffering" response header line is supported in + proxy mode. + + *) Bugfix: the reconfiguration bug and memory leaks in the ngx_http_perl_module. Changes with nginx 0.3.45 06 May 2006 - *) Feature: the "ssl_verify_client", "ssl_verify_depth", and + *) Feature: the "ssl_verify_client", "ssl_verify_depth", and "ssl_client_certificate" directives. - *) Change: the $request_method variable now returns the main request + *) Change: the $request_method variable now returns the main request method. - *) Change: the ° symbol codes were changed in koi-win conversion + *) Change: the ° symbol codes were changed in koi-win conversion table. - *) Feature: the euro and N symbols were added to koi-win conversion + *) Feature: the euro and N symbols were added to koi-win conversion table. - *) Bugfix: if nginx distributed the requests among several backends and - some backend failed, then requests intended for this backend was - directed to one live backend only instead of being distributed among + *) Bugfix: if nginx distributed the requests among several backends and + some backend failed, then requests intended for this backend was + directed to one live backend only instead of being distributed among the rest. @@ -3648,7 +3679,7 @@ *) Feature: the "wait" parameter in the "include" SSI command. - *) Feature: the Ukrainian and Byelorussian characters were added to + *) Feature: the Ukrainian and Byelorussian characters were added to koi-win conversion table. *) Bugfix: in the SSI. @@ -3661,18 +3692,18 @@ Changes with nginx 0.3.42 26 Apr 2006 - *) Feature: the "bind" option of the "listen" directive in IMAP/POP3 + *) Feature: the "bind" option of the "listen" directive in IMAP/POP3 proxy. - *) Bugfix: if the same capture in the "rewrite" directive was used more + *) Bugfix: if the same capture in the "rewrite" directive was used more then once. - *) Bugfix: the $sent_http_content_type, $sent_http_content_length, - $sent_http_last_modified, $sent_http_connection, - $sent_http_keep_alive, and $sent_http_transfer_encoding variables + *) Bugfix: the $sent_http_content_type, $sent_http_content_length, + $sent_http_last_modified, $sent_http_connection, + $sent_http_keep_alive, and $sent_http_transfer_encoding variables were not written to access log. - *) Bugfix: the $sent_http_cache_control returned value of the single + *) Bugfix: the $sent_http_cache_control returned value of the single "Cache-Control" response header line. @@ -3680,13 +3711,13 @@ *) Feature: the -v switch. - *) Bugfix: the segmentation fault may occurred if the SSI page has + *) Bugfix: the segmentation fault may occurred if the SSI page has remote subrequests. *) Bugfix: in FastCGI handling. - *) Bugfix: if the perl modules path was not set using - --with-perl_modules_path=PATH or the "perl_modules", then the + *) Bugfix: if the perl modules path was not set using + --with-perl_modules_path=PATH or the "perl_modules", then the segmentation fault was occurred. @@ -3701,21 +3732,21 @@ Changes with nginx 0.3.39 17 Apr 2006 - *) Feature: the "uninitialized_variable_warn" directive; the logging - level of the "uninitialized variable" message was lowered from + *) Feature: the "uninitialized_variable_warn" directive; the logging + level of the "uninitialized variable" message was lowered from "alert" to "warn". *) Feature: the "override_charset" directive. - *) Change: now if the unknown variable is used in the "echo" and "if - expr='$name'" SSI-commands, then the "unknown variable" message is + *) Change: now if the unknown variable is used in the "echo" and "if + expr='$name'" SSI-commands, then the "unknown variable" message is not logged. - *) Bugfix: the active connection counter increased on the exceeding of - the connection limit specified by the "worker_connections" - directive; the bug had appeared in 0.2.0. - - *) Bugfix: the limit rate might not work on some condition; the bug had + *) Bugfix: the active connection counter increased on the exceeding of + the connection limit specified by the "worker_connections" directive; + the bug had appeared in 0.2.0. + + *) Bugfix: the limit rate might not work on some condition; the bug had appeared in 0.3.38. @@ -3726,20 +3757,20 @@ *) Change: the ngx_http_perl_module optimizations. Thanks to Sergey Skvortsov. - *) Feature: the ngx_http_perl_module supports the $r->request_body_file + *) Feature: the ngx_http_perl_module supports the $r->request_body_file method. *) Feature: the "client_body_in_file_only" directive. - *) Workaround: now on disk overflow nginx tries to write access logs + *) Workaround: now on disk overflow nginx tries to write access logs once a second only. Thanks to Anton Yuzhaninov and Maxim Dounin. - *) Bugfix: now the "limit_rate" directive more precisely limits rate if + *) Bugfix: now the "limit_rate" directive more precisely limits rate if rate is more than 100 Kbyte/s. Thanks to ForJest. - *) Bugfix: now the IMAP/POP3 proxy escapes the "\r" and "\n" symbols in + *) Bugfix: now the IMAP/POP3 proxy escapes the "\r" and "\n" symbols in login and password to pass authorization server. Thanks to Maxim Dounin. @@ -3748,10 +3779,10 @@ *) Feature: the "limit_except" directive. - *) Feature: the "if" directive supports the "!~", "!~*", "-f", and - "!-f" operators. - - *) Feature: the ngx_http_perl_module supports the $r->request_body + *) Feature: the "if" directive supports the "!~", "!~*", "-f", and "!-f" + operators. + + *) Feature: the ngx_http_perl_module supports the $r->request_body method. *) Bugfix: in the ngx_http_addition_filter_module. @@ -3761,37 +3792,37 @@ *) Feature: the ngx_http_addition_filter_module. - *) Feature: the "proxy_pass" and "fastcgi_pass" directives may be used + *) Feature: the "proxy_pass" and "fastcgi_pass" directives may be used inside the "if" block. - *) Feature: the "proxy_ignore_client_abort" and + *) Feature: the "proxy_ignore_client_abort" and "fastcgi_ignore_client_abort" directives. *) Feature: the "$request_completion" variable. - *) Feature: the ngx_http_perl_module supports the $r->request_method - and $r->remote_addr. + *) Feature: the ngx_http_perl_module supports the $r->request_method and + $r->remote_addr. *) Feature: the ngx_http_ssi_module supports the "elif" command. - *) Bugfix: the "\/" string in the expression of the "if" command of the + *) Bugfix: the "\/" string in the expression of the "if" command of the ngx_http_ssi_module was treated incorrectly. - *) Bugfix: in the regular expressions in the "if" command of the + *) Bugfix: in the regular expressions in the "if" command of the ngx_http_ssi_module. - *) Bugfix: if the relative path was specified in the - "client_body_temp_path", "proxy_temp_path", "fastcgi_temp_path", and - "perl_modules" directives, then the directory was used relatively to + *) Bugfix: if the relative path was specified in the + "client_body_temp_path", "proxy_temp_path", "fastcgi_temp_path", and + "perl_modules" directives, then the directory was used relatively to a current path but not to a server prefix. Changes with nginx 0.3.35 22 Mar 2006 - *) Bugfix: the accept-filter and the TCP_DEFER_ACCEPT option were set + *) Bugfix: the accept-filter and the TCP_DEFER_ACCEPT option were set for first "listen" directive only; the bug had appeared in 0.3.31. - *) Bugfix: in the "proxy_pass" directive without the URI part in a + *) Bugfix: in the "proxy_pass" directive without the URI part in a subrequest. @@ -3802,10 +3833,10 @@ Changes with nginx 0.3.33 15 Mar 2006 - *) Feature: the "http_503" parameter of the "proxy_next_upstream" or + *) Feature: the "http_503" parameter of the "proxy_next_upstream" or "fastcgi_next_upstream" directives. - *) Bugfix: ngx_http_perl_module did not work with inlined in the + *) Bugfix: ngx_http_perl_module did not work with inlined in the configuration code, if it was not started with the "sub" word. *) Bugfix: in the "post_action" directive. @@ -3813,7 +3844,7 @@ Changes with nginx 0.3.32 11 Mar 2006 - *) Bugfix: the debug logging on startup and reconfiguration time was + *) Bugfix: the debug logging on startup and reconfiguration time was removed; the bug had appeared in 0.3.31. @@ -3821,22 +3852,21 @@ *) Change: now nginx passes the malformed proxied backend responses. - *) Feature: the "listen" directives support the address in the "*:port" + *) Feature: the "listen" directives support the address in the "*:port" form. *) Feature: the EVFILER_TIMER support in MacOSX 10.4. - *) Workaround: for MacOSX 64-bit kernel kqueue millisecond timeout - bug. + *) Workaround: for MacOSX 64-bit kernel kqueue millisecond timeout bug. Thanks to Andrei Nigmatulin. - *) Bugfix: if there were several "listen" directives listening one - various addresses inside one server, then server names like - "*.domain.tld" worked for first address only; the bug had appeared - in 0.3.18. - - *) Bugfix: if the HTTPS protocol was used in the "proxy_pass" directive - and the request body was in temporary file then the request was not + *) Bugfix: if there were several "listen" directives listening one + various addresses inside one server, then server names like + "*.domain.tld" worked for first address only; the bug had appeared in + 0.3.18. + + *) Bugfix: if the HTTPS protocol was used in the "proxy_pass" directive + and the request body was in temporary file then the request was not transferred. *) Bugfix: perl 5.8.8 compatibility. @@ -3844,29 +3874,29 @@ Changes with nginx 0.3.30 22 Feb 2006 - *) Change: the ECONNABORTED error log level was changed to "error" from + *) Change: the ECONNABORTED error log level was changed to "error" from "crit". - *) Bugfix: the ngx_http_perl_module could not be build without the + *) Bugfix: the ngx_http_perl_module could not be build without the ngx_http_ssi_filter_module. - *) Bugfix: nginx could not be built on i386 platform, if the PIC was + *) Bugfix: nginx could not be built on i386 platform, if the PIC was used; the bug had appeared in 0.3.27. Changes with nginx 0.3.29 20 Feb 2006 - *) Feature: now nginx uses less memory, if PHP in FastCGI mode sends + *) Feature: now nginx uses less memory, if PHP in FastCGI mode sends many warnings before the response. - *) Bugfix: the "Transfer-Encoding: chunked" header line was issued in + *) Bugfix: the "Transfer-Encoding: chunked" header line was issued in the 204 responses for the HTTP/1.1 requests. - *) Bugfix: nginx returned the 502 response, if the complete response + *) Bugfix: nginx returned the 502 response, if the complete response header lines were transferred in a separate FastCGI records. - *) Bugfix: if the proxied URI was specified in the "post_action" - directive, then it ran only after a successful completion of a + *) Bugfix: if the proxied URI was specified in the "post_action" + directive, then it ran only after a successful completion of a request. @@ -3876,58 +3906,58 @@ *) Feature: the --with-cpu-opt=ppc64 configuration parameter. - *) Bugfix: on some condition the proxied connection with a client was + *) Bugfix: on some condition the proxied connection with a client was terminated prematurely. Thanks to Vladimir Shutoff. - *) Bugfix: the "X-Accel-Limit-Rate" header line was not taken into - account if the request was redirected using the "X-Accel-Redirect" + *) Bugfix: the "X-Accel-Limit-Rate" header line was not taken into + account if the request was redirected using the "X-Accel-Redirect" header line. - *) Bugfix: the "post_action" directive ran only after a successful + *) Bugfix: the "post_action" directive ran only after a successful completion of a request. - *) Bugfix: the proxied response body generated by the "post_action" + *) Bugfix: the proxied response body generated by the "post_action" directive was transferred to a client. Changes with nginx 0.3.27 08 Feb 2006 - *) Change: the "variables_hash_max_size" and + *) Change: the "variables_hash_max_size" and "variables_hash_bucket_size" directives. - *) Feature: the $body_bytes_sent variable can be used not only in the + *) Feature: the $body_bytes_sent variable can be used not only in the "log_format" directive. *) Feature: the $ssl_protocol and $ssl_cipher variables. - *) Feature: the cache line size detection for widespread CPUs at start + *) Feature: the cache line size detection for widespread CPUs at start time. - *) Feature: now the "accept_mutex" directive is supported using - fcntl(2) on platforms different from i386, amd64, sparc64, and ppc. - - *) Feature: the "lock_file" directive and the --with-lock-path=PATH + *) Feature: now the "accept_mutex" directive is supported using fcntl(2) + on platforms different from i386, amd64, sparc64, and ppc. + + *) Feature: the "lock_file" directive and the --with-lock-path=PATH autoconfiguration directive. - *) Bugfix: if the HTTPS protocol was used in the "proxy_pass" directive + *) Bugfix: if the HTTPS protocol was used in the "proxy_pass" directive then the requests with the body was not transferred. Changes with nginx 0.3.26 03 Feb 2006 - *) Change: the "optimize_host_names" directive was renamed to the + *) Change: the "optimize_host_names" directive was renamed to the "optimize_server_names". - *) Bugfix: if in the "proxy_pass" directive was no the URI part, then - the main request URI was transferred to a backend while proxying the + *) Bugfix: if in the "proxy_pass" directive was no the URI part, then + the main request URI was transferred to a backend while proxying the SSI subrequest. Changes with nginx 0.3.25 01 Feb 2006 - *) Bugfix: the segmentation fault was occurred on start or while - reconfiguration if there was invalid configuration; the bug had + *) Bugfix: the segmentation fault was occurred on start or while + reconfiguration if there was invalid configuration; the bug had appeared in 0.3.24. @@ -3935,16 +3965,16 @@ *) Workaround: for bug in FreeBSD kqueue. - *) Bugfix: now a response generated by the "post_action" directive is + *) Bugfix: now a response generated by the "post_action" directive is not transferred to a client. *) Bugfix: the memory leaks were occurring if many log files were used. - *) Bugfix: the first "proxy_redirect" directive was working inside one + *) Bugfix: the first "proxy_redirect" directive was working inside one location. - *) Bugfix: on 64-bit platforms segmentation fault may occurred on start - if the many names were used in the "server_name" directives; the bug + *) Bugfix: on 64-bit platforms segmentation fault may occurred on start + if the many names were used in the "server_name" directives; the bug had appeared in 0.3.18. @@ -3952,23 +3982,23 @@ *) Feature: the "optimize_host_names" directive. - *) Bugfix: in using of the variables in the "path" and "alias" + *) Bugfix: in using of the variables in the "path" and "alias" directives. - *) Bugfix: the ngx_http_perl_module was incorrectly built on Linux and + *) Bugfix: the ngx_http_perl_module was incorrectly built on Linux and Solaris. Changes with nginx 0.3.22 17 Jan 2006 - *) Feature: the ngx_http_perl_module supports the $r->args and + *) Feature: the ngx_http_perl_module supports the $r->args and $r->unescape methods. - *) Feature: the method $r->query_string of ngx_http_perl_module was + *) Feature: the method $r->query_string of ngx_http_perl_module was canceled. - *) Bugfix: segmentation fault was occurred if the "none" or "blocked" - values was specified in the "valid_referers" directive; the bug had + *) Bugfix: segmentation fault was occurred if the "none" or "blocked" + values was specified in the "valid_referers" directive; the bug had appeared in 0.3.18. @@ -3976,7 +4006,7 @@ *) Feature: the ngx_http_perl_module. - *) Change: the "valid_referers" directive allows the referreres without + *) Change: the "valid_referers" directive allows the referreres without URI part. @@ -3984,8 +4014,8 @@ *) Bugfix: in SSI handling. - *) Bugfix: the ngx_http_memcached_module did not support the keys in - the "/usr?args" form. + *) Bugfix: the ngx_http_memcached_module did not support the keys in the + "/usr?args" form. Changes with nginx 0.3.19 28 Dec 2005 @@ -3999,47 +4029,47 @@ Changes with nginx 0.3.18 26 Dec 2005 - *) Feature: the "server_names" directive supports the ".domain.tld" + *) Feature: the "server_names" directive supports the ".domain.tld" names. - *) Feature: the "server_names" directive uses the hash for the + *) Feature: the "server_names" directive uses the hash for the "*.domain.tld" names and more effective hash for usual names. - *) Change: the "server_names_hash_max_size" and + *) Change: the "server_names_hash_max_size" and "server_names_hash_bucket_size" directives. - *) Change: the "server_names_hash" and "server_names_hash_threshold" + *) Change: the "server_names_hash" and "server_names_hash_threshold" directives were canceled. *) Feature: the "valid_referers" directive uses the hash site names. - *) Change: now the "valid_referers" directive checks the site names - only without the URI part. - - *) Bugfix: some ".domain.tld" names incorrectly processed by the + *) Change: now the "valid_referers" directive checks the site names only + without the URI part. + + *) Bugfix: some ".domain.tld" names incorrectly processed by the ngx_http_map_module. - *) Bugfix: segmentation fault was occurred if configuration file did - not exist; the bug had appeared in 0.3.12. - - *) Bugfix: on 64-bit platforms segmentation fault may occurred on - start; the bug had appeared in 0.3.16. + *) Bugfix: segmentation fault was occurred if configuration file did not + exist; the bug had appeared in 0.3.12. + + *) Bugfix: on 64-bit platforms segmentation fault may occurred on start; + the bug had appeared in 0.3.16. Changes with nginx 0.3.17 18 Dec 2005 - *) Change: now on Linux configure checks the presence of epoll and + *) Change: now on Linux configure checks the presence of epoll and sendfile64() in kernel. - *) Feature: the "map" directive supports domain names in the + *) Feature: the "map" directive supports domain names in the ".domain.tld" form. - *) Bugfix: the timeouts were not used in SSL handshake; the bug had + *) Bugfix: the timeouts were not used in SSL handshake; the bug had appeared in 0.2.4. *) Bugfix: in the HTTPS protocol in the "proxy_pass" directive. - *) Bugfix: when the HTTPS protocol was used in the "proxy_pass" + *) Bugfix: when the HTTPS protocol was used in the "proxy_pass" directive the port 80 was used by default. @@ -4047,41 +4077,41 @@ *) Feature: the ngx_http_map_module. - *) Feature: the "types_hash_max_size" and "types_hash_bucket_size" + *) Feature: the "types_hash_max_size" and "types_hash_bucket_size" directives. *) Feature: the "ssi_value_length" directive. *) Feature: the "worker_rlimit_core" directive. - *) Workaround: the connection number in logs was always 1 if nginx was - built by the icc 8.1 or 9.0 compilers with optimization for + *) Workaround: the connection number in logs was always 1 if nginx was + built by the icc 8.1 or 9.0 compilers with optimization for Pentium 4. *) Bugfix: the "config timefmt" SSI command set incorrect time format. - *) Bugfix: nginx did not close connection to IMAP/POP3 backend for the + *) Bugfix: nginx did not close connection to IMAP/POP3 backend for the SSL connections; the bug had appeared in 0.3.13. Thanks to Rob Mueller. - *) Bugfix: segmentation fault may occurred in at SSL shutdown; the bug + *) Bugfix: segmentation fault may occurred in at SSL shutdown; the bug had appeared in 0.3.13. Changes with nginx 0.3.15 07 Dec 2005 - *) Feature: the new 444 code of the "return" directive to close + *) Feature: the new 444 code of the "return" directive to close connection. *) Feature: the "so_keepalive" directive in IMAP/POP3 proxy. - *) Bugfix: if there are unclosed connection nginx now calls abort() - only on gracefull quit and active "debug_points" directive. + *) Bugfix: if there are unclosed connection nginx now calls abort() only + on gracefull quit and active "debug_points" directive. Changes with nginx 0.3.14 05 Dec 2005 - *) Bugfix: in the 304 response the body was transferred; the bug had + *) Bugfix: in the 304 response the body was transferred; the bug had appeared in 0.3.13. @@ -4089,69 +4119,69 @@ *) Feature: the IMAP/POP3 proxy supports STARTTLS and STLS. - *) Bugfix: the IMAP/POP3 proxy did not work with the select, poll, and + *) Bugfix: the IMAP/POP3 proxy did not work with the select, poll, and /dev/poll methods. *) Bugfix: in SSI handling. - *) Bugfix: now Solaris sendfilev() is not used to transfer the client + *) Bugfix: now Solaris sendfilev() is not used to transfer the client request body to FastCGI-server via the unix domain socket. - *) Bugfix: the "auth_basic" directive did not disable the - authorization; the bug had appeared in 0.3.11. + *) Bugfix: the "auth_basic" directive did not disable the authorization; + the bug had appeared in 0.3.11. Changes with nginx 0.3.12 26 Nov 2005 - *) Security: if nginx was built with the ngx_http_realip_module and the - "satisfy_any on" directive was used, then access and authorization - directives did not work. The ngx_http_realip_module was not built - and is not built by default. + *) Security: if nginx was built with the ngx_http_realip_module and the + "satisfy_any on" directive was used, then access and authorization + directives did not work. The ngx_http_realip_module was not built and + is not built by default. *) Change: the "$time_gmt" variable name was changed to "$time_local". - *) Change: the "proxy_header_buffer_size" and - "fastcgi_header_buffer_size" directives was renamed to the + *) Change: the "proxy_header_buffer_size" and + "fastcgi_header_buffer_size" directives was renamed to the "proxy_buffer_size" and "fastcgi_buffer_size" directives. *) Feature: the ngx_http_memcached_module. *) Feature: the "proxy_buffering" directive. - *) Bugfix: the changes in accept mutex handling when the "rtsig" method + *) Bugfix: the changes in accept mutex handling when the "rtsig" method was used; the bug had appeared in 0.3.0. - *) Bugfix: if the client sent the "Transfer-Encoding: chunked" header + *) Bugfix: if the client sent the "Transfer-Encoding: chunked" header line, then nginx returns the 411 error. - *) Bugfix: if the "auth_basic" directive was inherited from the http - level, then the realm in the "WWW-Authenticate" header line was + *) Bugfix: if the "auth_basic" directive was inherited from the http + level, then the realm in the "WWW-Authenticate" header line was without the "Basic realm" text. - *) Bugfix: if the "combined" format was explicitly specified in the - "access_log" directive, then the empty lines was written to the log; + *) Bugfix: if the "combined" format was explicitly specified in the + "access_log" directive, then the empty lines was written to the log; the bug had appeared in 0.3.8. - *) Bugfix: nginx did not run on the sparc platform under any OS except + *) Bugfix: nginx did not run on the sparc platform under any OS except Solaris. - *) Bugfix: now it is not necessary to place space between the quoted + *) Bugfix: now it is not necessary to place space between the quoted string and closing bracket in the "if" directive. Changes with nginx 0.3.11 15 Nov 2005 - *) Bugfix: nginx did not pass the client request headers and body while + *) Bugfix: nginx did not pass the client request headers and body while proxying; the bug had appeared in 0.3.10. Changes with nginx 0.3.10 15 Nov 2005 - *) Change: the "valid_referers" directive and the "$invalid_referer" - variable were moved to the new ngx_http_referer_module from the + *) Change: the "valid_referers" directive and the "$invalid_referer" + variable were moved to the new ngx_http_referer_module from the ngx_http_rewrite_module. - *) Change: the "$apache_bytes_sent" variable name was changed to + *) Change: the "$apache_bytes_sent" variable name was changed to "$body_bytes_sent". *) Feature: the "$sent_http_..." variables. @@ -4168,73 +4198,73 @@ *) Feature: the "worker_cpu_affinity" directive for Linux. - *) Bugfix: the "rewrite" directive did not unescape URI part in - redirect, now it is unescaped except the %00-%25 and %7F-%FF + *) Bugfix: the "rewrite" directive did not unescape URI part in + redirect, now it is unescaped except the %00-%25 and %7F-%FF characters. *) Bugfix: nginx could not be built by the icc 9.0 compiler. - *) Bugfix: if the SSI was enabled for zero size static file, then the + *) Bugfix: if the SSI was enabled for zero size static file, then the chunked response was encoded incorrectly. Changes with nginx 0.3.9 10 Nov 2005 - *) Bugfix: nginx considered URI as unsafe if two any symbols was - between two slashes; the bug had appeared in 0.3.8. + *) Bugfix: nginx considered URI as unsafe if two any symbols was between + two slashes; the bug had appeared in 0.3.8. Changes with nginx 0.3.8 09 Nov 2005 - *) Security: nginx now checks URI got from a backend in - "X-Accel-Redirect" header line or in SSI file for the "/../" paths + *) Security: nginx now checks URI got from a backend in + "X-Accel-Redirect" header line or in SSI file for the "/../" paths and zeroes. - *) Change: nginx now does not treat the empty user name in the + *) Change: nginx now does not treat the empty user name in the "Authorization" header line as valid one. - *) Feature: the "ssl_session_timeout" directives of the + *) Feature: the "ssl_session_timeout" directives of the ngx_http_ssl_module and ngx_imap_ssl_module. - *) Feature: the "auth_http_header" directive of the + *) Feature: the "auth_http_header" directive of the ngx_imap_auth_http_module. *) Feature: the "add_header" directive. *) Feature: the ngx_http_realip_module. - *) Feature: the new variables to use in the "log_format" directive: - $bytes_sent, $apache_bytes_sent, $status, $time_gmt, $uri, - $request_time, $request_length, $upstream_status, - $upstream_response_time, $gzip_ratio, $uid_got, $uid_set, - $connection, $pipe, and $msec. The parameters in the "%name" form + *) Feature: the new variables to use in the "log_format" directive: + $bytes_sent, $apache_bytes_sent, $status, $time_gmt, $uri, + $request_time, $request_length, $upstream_status, + $upstream_response_time, $gzip_ratio, $uid_got, $uid_set, + $connection, $pipe, and $msec. The parameters in the "%name" form will be canceled soon. - *) Change: now the false variable values in the "if" directive are the + *) Change: now the false variable values in the "if" directive are the empty string "" and string starting with "0". - *) Bugfix: while using proxied or FastCGI-server nginx may leave + *) Bugfix: while using proxied or FastCGI-server nginx may leave connections and temporary files with client requests in open state. - *) Bugfix: the worker processes did not flush the buffered logs on + *) Bugfix: the worker processes did not flush the buffered logs on graceful exit. - *) Bugfix: if the request URI was changes by the "rewrite" directive - and the request was proxied in location given by regular expression, - then the incorrect request was transferred to backend; the bug had + *) Bugfix: if the request URI was changes by the "rewrite" directive and + the request was proxied in location given by regular expression, then + the incorrect request was transferred to backend; the bug had appeared in 0.2.6. - *) Bugfix: the "expires" directive did not remove the previous - "Expires" header. - - *) Bugfix: nginx may stop to accept requests if the "rtsig" method and + *) Bugfix: the "expires" directive did not remove the previous "Expires" + header. + + *) Bugfix: nginx may stop to accept requests if the "rtsig" method and several worker processes were used. - *) Bugfix: the "\"" and "\'" escape symbols were incorrectly handled in + *) Bugfix: the "\"" and "\'" escape symbols were incorrectly handled in SSI commands. - *) Bugfix: if the response was ended just after the SSI command and - gzipping was used, then the response did not transferred complete or + *) Bugfix: if the response was ended just after the SSI command and + gzipping was used, then the response did not transferred complete or did not transferred at all. @@ -4242,78 +4272,77 @@ *) Feature: the "access_log" supports the "buffer=" parameter. - *) Bugfix: nginx could not be built on platforms different from i386, + *) Bugfix: nginx could not be built on platforms different from i386, amd64, sparc, and ppc; the bug had appeared in 0.3.2. Changes with nginx 0.3.6 24 Oct 2005 - *) Change: now the IMAP/POP3 proxy do not send the empty login to + *) Change: now the IMAP/POP3 proxy do not send the empty login to authorization server. *) Feature: the "log_format" supports the variables in the $name form. - *) Bugfix: if at least in one server was no the "listen" directive, - then nginx did not listen on the 80 port; the bug had appeared in - 0.3.3. - - *) Bugfix: if the URI part is omitted in "proxy_pass" directive, the - the 80 port was always used. + *) Bugfix: if at least in one server was no the "listen" directive, then + nginx did not listen on the 80 port; the bug had appeared in 0.3.3. + + *) Bugfix: if the URI part is omitted in "proxy_pass" directive, the the + 80 port was always used. Changes with nginx 0.3.5 21 Oct 2005 - *) Bugfix: the segmentation fault may occurred if the IMAP/POP3 login + *) Bugfix: the segmentation fault may occurred if the IMAP/POP3 login was changed by authorization server; the bug had appeared in 0.2.2. - *) Bugfix: the accept mutex did not work and all connections were + *) Bugfix: the accept mutex did not work and all connections were handled by one process; the bug had appeared in 0.3.3. - *) Bugfix: the timeout did not work if the "rtsig" method and the + *) Bugfix: the timeout did not work if the "rtsig" method and the "timer_resolution" directive were used. Changes with nginx 0.3.4 19 Oct 2005 - *) Bugfix: nginx could not be built on Linux 2.4+ and MacOS X; the bug + *) Bugfix: nginx could not be built on Linux 2.4+ and MacOS X; the bug had appeared in 0.3.3. Changes with nginx 0.3.3 19 Oct 2005 - *) Change: the "bl" and "af" parameters of the "listen" directive was + *) Change: the "bl" and "af" parameters of the "listen" directive was renamed to the "backlog" and "accept_filter". - *) Feature: the "rcvbuf" and "sndbuf" parameters of the "listen" + *) Feature: the "rcvbuf" and "sndbuf" parameters of the "listen" directive. - *) Change: the "$msec" log parameter does not require now the - additional the gettimeofday() system call. + *) Change: the "$msec" log parameter does not require now the additional + the gettimeofday() system call. *) Feature: the -t switch now tests the "listen" directives. - *) Bugfix: if the invalid address was specified in the "listen" - directive, then after the -HUP signal nginx left an open socket in + *) Bugfix: if the invalid address was specified in the "listen" + directive, then after the -HUP signal nginx left an open socket in the CLOSED state. - *) Bugfix: the mime type may be incorrectly set to default value for + *) Bugfix: the mime type may be incorrectly set to default value for index file with variable in the name; the bug had appeared in 0.3.0. *) Feature: the "timer_resolution" directive. *) Feature: the millisecond "$upstream_response_time" log parameter. - *) Bugfix: a temporary file with client request body now is removed - just after the response header was transferred to a client. + *) Bugfix: a temporary file with client request body now is removed just + after the response header was transferred to a client. *) Bugfix: OpenSSL 0.9.6 compatibility. *) Bugfix: the SSL certificate and key file paths could not be relative. - *) Bugfix: the "ssl_prefer_server_ciphers" directive did not work in - the ngx_imap_ssl_module. - - *) Bugfix: the "ssl_protocols" directive allowed to specify the single + *) Bugfix: the "ssl_prefer_server_ciphers" directive did not work in the + ngx_imap_ssl_module. + + *) Bugfix: the "ssl_protocols" directive allowed to specify the single protocol only. @@ -4321,101 +4350,100 @@ *) Feature: the Sun Studio 10 C compiler support. - *) Feature: the "proxy_upstream_max_fails", - "proxy_upstream_fail_timeout", "fastcgi_upstream_max_fails", and + *) Feature: the "proxy_upstream_max_fails", + "proxy_upstream_fail_timeout", "fastcgi_upstream_max_fails", and "fastcgi_upstream_fail_timeout" directives. Changes with nginx 0.3.1 10 Oct 2005 - *) Bugfix: the segmentation fault occurred when the signal queue - overflowed if the "rtsig" method was used; the bug had appeared in + *) Bugfix: the segmentation fault occurred when the signal queue + overflowed if the "rtsig" method was used; the bug had appeared in 0.2.0. - *) Change: correct handling of the "\\", "\"", "\'", and "\$" pairs in + *) Change: correct handling of the "\\", "\"", "\'", and "\$" pairs in SSI. Changes with nginx 0.3.0 07 Oct 2005 - *) Change: the 10-days live time limit of worker process was - eliminated. The limit was introduced because of millisecond timers - overflow. + *) Change: the 10-days live time limit of worker process was eliminated. + The limit was introduced because of millisecond timers overflow. Changes with nginx 0.2.6 05 Oct 2005 - *) Change: while using load-balancing the time before the failed - backend retry was decreased from 60 to 10 seconds. - - *) Change: the "proxy_pass_unparsed_uri" was canceled, the original URI + *) Change: while using load-balancing the time before the failed backend + retry was decreased from 60 to 10 seconds. + + *) Change: the "proxy_pass_unparsed_uri" was canceled, the original URI now passed, if the URI part is omitted in "proxy_pass" directive. - *) Feature: the "error_page" directive supports redirects and allows + *) Feature: the "error_page" directive supports redirects and allows more flexible to change an error code. - *) Change: the charset in the "Content-Type" header line now is ignored + *) Change: the charset in the "Content-Type" header line now is ignored in proxied subrequests. - *) Bugfix: if the URI was changed in the "if" block and request did not - found new configuration, then the ngx_http_rewrite_module rules ran + *) Bugfix: if the URI was changed in the "if" block and request did not + found new configuration, then the ngx_http_rewrite_module rules ran again. - *) Bugfix: if the "set" directive set the ngx_http_geo_module variable - in some configuration part, the this variable was not available in - other configuration parts and the "using uninitialized variable" + *) Bugfix: if the "set" directive set the ngx_http_geo_module variable + in some configuration part, the this variable was not available in + other configuration parts and the "using uninitialized variable" error was occurred; the bug had appeared in 0.2.2. Changes with nginx 0.2.5 04 Oct 2005 - *) Change: the duplicate value of the ngx_http_geo_module variable now + *) Change: the duplicate value of the ngx_http_geo_module variable now causes the warning and changes old value. *) Feature: the ngx_http_ssi_module supports the "set" command. - *) Feature: the ngx_http_ssi_module supports the "file" parameter in - the "include" command. - - *) Feature: the ngx_http_ssi_module supports the variable value + *) Feature: the ngx_http_ssi_module supports the "file" parameter in the + "include" command. + + *) Feature: the ngx_http_ssi_module supports the variable value substitutions in expressions of the "if" command. Changes with nginx 0.2.4 03 Oct 2005 - *) Feature: the ngx_http_ssi_module supports "$var=text", "$var!=text", + *) Feature: the ngx_http_ssi_module supports "$var=text", "$var!=text", "$var=/text/", and "$var!=/text/" expressions in the "if" command. - *) Bugfix: in proxying location without trailing slash; the bug had + *) Bugfix: in proxying location without trailing slash; the bug had appeared in 0.1.44. - *) Bugfix: the segmentation fault may occurred if the "rtsig" method - was used; the bug had appeared in 0.2.0. + *) Bugfix: the segmentation fault may occurred if the "rtsig" method was + used; the bug had appeared in 0.2.0. Changes with nginx 0.2.3 30 Sep 2005 - *) Bugfix: nginx could not be built without the --with-debug option; - the bug had appeared in 0.2.2. + *) Bugfix: nginx could not be built without the --with-debug option; the + bug had appeared in 0.2.2. Changes with nginx 0.2.2 30 Sep 2005 *) Feature: the "config errmsg" command of the ngx_http_ssi_module. - *) Change: the ngx_http_geo_module variables can be overridden by the + *) Change: the ngx_http_geo_module variables can be overridden by the "set" directive. - *) Feature: the "ssl_protocols" and "ssl_prefer_server_ciphers" + *) Feature: the "ssl_protocols" and "ssl_prefer_server_ciphers" directives of the ngx_http_ssl_module and ngx_imap_ssl_module. - *) Bugfix: the ngx_http_autoindex_module did not show correctly the - long file names; - - *) Bugfix: the ngx_http_autoindex_module now do not show the files + *) Bugfix: the ngx_http_autoindex_module did not show correctly the long + file names; + + *) Bugfix: the ngx_http_autoindex_module now do not show the files starting by dot. - *) Bugfix: if the SSL handshake failed then another connection may be + *) Bugfix: if the SSL handshake failed then another connection may be closed too. Thanks to Rob Mueller. @@ -4424,36 +4452,36 @@ Changes with nginx 0.2.1 23 Sep 2005 - *) Bugfix: if all backend using in load-balancing failed after one - error, then nginx may got caught in an endless loop; the bug had + *) Bugfix: if all backend using in load-balancing failed after one + error, then nginx may got caught in an endless loop; the bug had appeared in 0.2.0. Changes with nginx 0.2.0 23 Sep 2005 - *) The pid-file names used during online upgrade was changed and now is - not required a manual rename operation. The old master process adds - the ".oldbin" suffix to its pid-file and executes a new binary file. - The new master process creates usual pid-file without the ".newbin" - suffix. If the master process exits, then old master process renames - back its pid-file with the ".oldbin" suffix to the pid-file without + *) The pid-file names used during online upgrade was changed and now is + not required a manual rename operation. The old master process adds + the ".oldbin" suffix to its pid-file and executes a new binary file. + The new master process creates usual pid-file without the ".newbin" + suffix. If the master process exits, then old master process renames + back its pid-file with the ".oldbin" suffix to the pid-file without suffix. - *) Change: the "worker_connections" directive, new name of the - "connections" directive; now the directive specifies maximum number + *) Change: the "worker_connections" directive, new name of the + "connections" directive; now the directive specifies maximum number of connections, but not maximum socket descriptor number. *) Feature: SSL supports the session cache inside one worker process. *) Feature: the "satisfy_any" directive. - *) Change: the ngx_http_access_module and ngx_http_auth_basic_module do + *) Change: the ngx_http_access_module and ngx_http_auth_basic_module do not run for subrequests. - *) Feature: the "worker_rlimit_nofile" and "worker_rlimit_sigpending" + *) Feature: the "worker_rlimit_nofile" and "worker_rlimit_sigpending" directives. - *) Bugfix: if all backend using in load-balancing failed after one + *) Bugfix: if all backend using in load-balancing failed after one error, then nginx did not try do connect to them during 60 seconds. *) Bugfix: in IMAP/POP3 command argument parsing. @@ -4463,17 +4491,17 @@ *) Bugfix: errors while using SSI and gzipping. - *) Bugfix: the "Expires" and "Cache-Control" header lines were omitted + *) Bugfix: the "Expires" and "Cache-Control" header lines were omitted from the 304 responses. Thanks to Alexandr Kukushkin. Changes with nginx 0.1.45 08 Sep 2005 - *) Change: the "ssl_engine" directive was canceled in the + *) Change: the "ssl_engine" directive was canceled in the ngx_http_ssl_module and now is introduced at global level. - *) Bugfix: the responses with SSI subrequests did not transferred via + *) Bugfix: the responses with SSI subrequests did not transferred via SSL connection. *) Various bug fixes in the IMAP/POP3 proxy. @@ -4487,126 +4515,126 @@ *) Feature: the "userid_mark" directive. - *) Feature: the $remote_user variable value is determined independently + *) Feature: the $remote_user variable value is determined independently of authorization use. Changes with nginx 0.1.43 30 Aug 2005 - *) Feature: the listen(2) backlog in the "listen" directive can be + *) Feature: the listen(2) backlog in the "listen" directive can be changed using the -HUP signal. *) Feature: the geo2nginx.pl script was added to contrib. - *) Change: the FastCGI parameters with the empty values now are passed + *) Change: the FastCGI parameters with the empty values now are passed to a server. - *) Bugfix: the segmentation fault occurred or the worker process may - got caught in an endless loop if the proxied or FastCGI server sent - the "Cache-Control" header line and the "expires" directive was - used; in the proxied mode the the bug had appeared in 0.1.29. + *) Bugfix: the segmentation fault occurred or the worker process may got + caught in an endless loop if the proxied or FastCGI server sent the + "Cache-Control" header line and the "expires" directive was used; in + the proxied mode the the bug had appeared in 0.1.29. Changes with nginx 0.1.42 23 Aug 2005 - *) Bugfix: if the request URI had a zero length after the processing in - the ngx_http_proxy_module, then the segmentation fault or bus error + *) Bugfix: if the request URI had a zero length after the processing in + the ngx_http_proxy_module, then the segmentation fault or bus error occurred in the ngx_http_proxy_module. - *) Bugfix: the "limit_rate" directive did not work inside the "if" + *) Bugfix: the "limit_rate" directive did not work inside the "if" block; the bug had appeared in 0.1.38. Changes with nginx 0.1.41 25 Jul 2005 - *) Bugfix: if the variable was used in the configuration file, then it + *) Bugfix: if the variable was used in the configuration file, then it can not be used in SSI. Changes with nginx 0.1.40 22 Jul 2005 - *) Bugfix: if a client sent too long header line, then the request + *) Bugfix: if a client sent too long header line, then the request information did not logged in the error log. - *) Bugfix: the "Set-Cookie" header line was not transferred when the + *) Bugfix: the "Set-Cookie" header line was not transferred when the "X-Accel-Redirect" was used; the bug had appeared in 0.1.39. - *) Bugfix: the "Content-Disposition" header line was not transferred + *) Bugfix: the "Content-Disposition" header line was not transferred when the "X-Accel-Redirect" was used. - *) Bugfix: the master process did not close the listen socket on the + *) Bugfix: the master process did not close the listen socket on the SIGQUIT signal. - *) Bugfix: after on-line upgrade on Linux and Solaris the process name + *) Bugfix: after on-line upgrade on Linux and Solaris the process name became shorter in the "ps" command. Changes with nginx 0.1.39 14 Jul 2005 - *) The changes in the ngx_http_charset_module: the "default_charset" - directive was canceled; the "charset" directive sets the response + *) The changes in the ngx_http_charset_module: the "default_charset" + directive was canceled; the "charset" directive sets the response charset; the "source_charset" directive sets the source charset only. - *) Bugfix: the backend "WWW-Authenticate" header line did not + *) Bugfix: the backend "WWW-Authenticate" header line did not transferred while the 401 response code redirecting. - *) Bugfix: the ngx_http_proxy_module and ngx_http_fastcgi_module may - close a connection before anything was transferred to a client; the + *) Bugfix: the ngx_http_proxy_module and ngx_http_fastcgi_module may + close a connection before anything was transferred to a client; the bug had appeared in 0.1.38. *) Workaround: the Linux glibc crypt_r() initialization bug. - *) Bugfix: the ngx_http_ssi_module did not support the relative URI in + *) Bugfix: the ngx_http_ssi_module did not support the relative URI in the "include virtual" command. - *) Bugfix: if the backend response had the "Location" header line and - nginx should not rewrite this line, then the 500 code response body + *) Bugfix: if the backend response had the "Location" header line and + nginx should not rewrite this line, then the 500 code response body was transferred; the bug had appeared in 0.1.29. - *) Bugfix: some directives of the ngx_http_proxy_module and - ngx_http_fastcgi_module were not inherited from the server to the + *) Bugfix: some directives of the ngx_http_proxy_module and + ngx_http_fastcgi_module were not inherited from the server to the location level; the bug had appeared in 0.1.29. - *) Bugfix: the ngx_http_ssl_module did not support the certificate + *) Bugfix: the ngx_http_ssl_module did not support the certificate chain. - *) Bugfix: the ngx_http_autoindex_module did not show correctly the - long file names; the bug had appeared in 0.1.38. - - *) Bugfixes in IMAP/POP3 proxy in interaction with a backend at the + *) Bugfix: the ngx_http_autoindex_module did not show correctly the long + file names; the bug had appeared in 0.1.38. + + *) Bugfixes in IMAP/POP3 proxy in interaction with a backend at the login state. Changes with nginx 0.1.38 08 Jul 2005 - *) Feature: the "limit_rate" directive is supported in in proxy and + *) Feature: the "limit_rate" directive is supported in in proxy and FastCGI mode. - *) Feature: the "X-Accel-Limit-Rate" response header line is supported + *) Feature: the "X-Accel-Limit-Rate" response header line is supported in proxy and FastCGI mode. *) Feature: the "break" directive. *) Feature: the "log_not_found" directive. - *) Bugfix: the response status code was not changed when request was + *) Bugfix: the response status code was not changed when request was redirected by the ""X-Accel-Redirect" header line. - *) Bugfix: the variables set by the "set" directive could not be used - in SSI. - - *) Bugfix: the segmentation fault may occurred if the SSI page has more + *) Bugfix: the variables set by the "set" directive could not be used in + SSI. + + *) Bugfix: the segmentation fault may occurred if the SSI page has more than one remote subrequest. - *) Bugfix: nginx treated the backend response as invalid if the status - line in the header was transferred in two packets; the bug had + *) Bugfix: nginx treated the backend response as invalid if the status + line in the header was transferred in two packets; the bug had appeared in 0.1.29. *) Feature: the "ssi_types" directive. *) Feature: the "autoindex_exact_size" directive. - *) Bugfix: the ngx_http_autoindex_module did not support the long file + *) Bugfix: the ngx_http_autoindex_module did not support the long file names in UTF-8. *) Feature: the IMAP/POP3 proxy. @@ -4616,34 +4644,34 @@ *) Change: now the "\n" is added to the end of the "nginx.pid" file. - *) Bugfix: the responses may be transferred not completely, if many + *) Bugfix: the responses may be transferred not completely, if many parts or the big parts were included by SSI. - *) Bugfix: if all backends had returned the 404 reponse and the - "http_404" parameter of the "proxy_next_upstream" or - "fastcgi_next_upstream" directives was used, then nginx started to + *) Bugfix: if all backends had returned the 404 reponse and the + "http_404" parameter of the "proxy_next_upstream" or + "fastcgi_next_upstream" directives was used, then nginx started to request all backends again. Changes with nginx 0.1.36 15 Jun 2005 - *) Change: if the request header has duplicate the "Host", - "Connection", "Content-Length", or "Authorization" lines, then nginx - now returns the 400 error. + *) Change: if the request header has duplicate the "Host", "Connection", + "Content-Length", or "Authorization" lines, then nginx now returns + the 400 error. *) Change: the "post_accept_timeout" directive was canceled. - *) Feature: the "default", "af=", "bl=", "deferred", and "bind" + *) Feature: the "default", "af=", "bl=", "deferred", and "bind" parameters of the "listen" directive. *) Feature: the FreeBSD accept filters support. *) Feature: the Linux TCP_DEFER_ACCEPT support. - *) Bugfix: the ngx_http_autoindex_module did not support the file names + *) Bugfix: the ngx_http_autoindex_module did not support the file names in UTF-8. - *) Bugfix: the new log file can be rotated by the -USR1 signal only if + *) Bugfix: the new log file can be rotated by the -USR1 signal only if the reconfiguration by the -HUP signal was made twice. @@ -4653,61 +4681,61 @@ *) Feature: the "port_in_redirect" directive. - *) Bugfix: the segmentation fault was occurred if the backend response + *) Bugfix: the segmentation fault was occurred if the backend response header was in several packets; the bug had appeared in 0.1.29. - *) Bugfix: if more than 10 servers were configured or some server did - not use the "listen" directive, then the segmentation fault was + *) Bugfix: if more than 10 servers were configured or some server did + not use the "listen" directive, then the segmentation fault was occurred on the start. - *) Bugfix: the segmentation fault might occur if the response was - bigger than the temporary file. - - *) Bugfix: nginx returned the 400 response on requests like - "GET http://www.domain.com/uri HTTP/1.0"; the bug had appeared in + *) Bugfix: the segmentation fault might occur if the response was bigger + than the temporary file. + + *) Bugfix: nginx returned the 400 response on requests like + "GET http://www.domain.com/uri HTTP/1.0"; the bug had appeared in 0.1.28. Changes with nginx 0.1.34 26 May 2005 - *) Bugfix: the worker process may got caught in an endless loop if the + *) Bugfix: the worker process may got caught in an endless loop if the big response part were include by SSI. - *) Bugfix: the variables set by the "set" directive were not available + *) Bugfix: the variables set by the "set" directive were not available in SSI. *) Feature: the "autoindex_localtime" directive. - *) Bugfix: the empty value of the "proxy_set_header" directive forbids + *) Bugfix: the empty value of the "proxy_set_header" directive forbids the client request header line passing. Changes with nginx 0.1.33 23 May 2005 - *) Bugfix: nginx could not be built with the --without-pcre parameter; + *) Bugfix: nginx could not be built with the --without-pcre parameter; the bug had appeared in 0.1.29. - *) Bugfix: 3, 4, 7, and 8 the "proxy_set_header" directives in one - level cause the bus fault on start up. + *) Bugfix: 3, 4, 7, and 8 the "proxy_set_header" directives in one level + cause the bus fault on start up. *) Bugfix: the HTTP protocol was specified in the HTTPS redirects. - *) Bugfix: if the "rewrite" directive used the captures inside the "if" + *) Bugfix: if the "rewrite" directive used the captures inside the "if" directive, then the 500 error code was returned. Changes with nginx 0.1.32 19 May 2005 - *) Bugfix: the arguments were omitted in the redirects, issued by the + *) Bugfix: the arguments were omitted in the redirects, issued by the "rewrite" directive; the bug had appeared in 0.1.29. - *) Feature: the "if" directive supports the captures in regular + *) Feature: the "if" directive supports the captures in regular expressions. - *) Feature: the "set" directive supports the variables and the captures + *) Feature: the "set" directive supports the variables and the captures of regular expressions. - *) Feature: the "X-Accel-Redirect" response header line is supported in + *) Feature: the "X-Accel-Redirect" response header line is supported in proxy and FastCGI mode. @@ -4719,23 +4747,23 @@ *) Bugfix: errors while using SSI and gzipping. - *) Bugfix: the redirect with the 301 code was transferred without + *) Bugfix: the redirect with the 301 code was transferred without response body; the bug had appeared in 0.1.30. Changes with nginx 0.1.30 14 May 2005 - *) Bugfix: the worker process may got caught in an endless loop if the + *) Bugfix: the worker process may got caught in an endless loop if the SSI was used. *) Bugfix: the response encrypted by SSL may not transferred complete. - *) Bugfix: if the length of the response part received at once from - proxied or FastCGI server was equal to 500, then nginx returns the - 500 response code; in proxy mode the the bug had appeared in 0.1.29 + *) Bugfix: if the length of the response part received at once from + proxied or FastCGI server was equal to 500, then nginx returns the + 500 response code; in proxy mode the the bug had appeared in 0.1.29 only. - *) Bugfix: nginx did not consider the directives with 8 or 9 parameters + *) Bugfix: nginx did not consider the directives with 8 or 9 parameters as invalid. *) Feature: the "return" directive can return the 204 response code. @@ -4747,47 +4775,47 @@ *) Feature: the ngx_http_ssi_module supports "include virtual" command. - *) Feature: the ngx_http_ssi_module supports the condition command like - 'if expr="$NAME"' and "else" and "endif" commands. Only one nested + *) Feature: the ngx_http_ssi_module supports the condition command like + 'if expr="$NAME"' and "else" and "endif" commands. Only one nested level is supported. - *) Feature: the ngx_http_ssi_module supports the DATE_LOCAL and - DATE_GMT variables and "config timefmt" command. + *) Feature: the ngx_http_ssi_module supports the DATE_LOCAL and DATE_GMT + variables and "config timefmt" command. *) Feature: the "ssi_ignore_recycled_buffers" directive. - *) Bugfix: the "echo" command did not show the default value for the + *) Bugfix: the "echo" command did not show the default value for the empty QUERY_STRING variable. *) Change: the ngx_http_proxy_module was rewritten. - *) Feature: the "proxy_redirect", "proxy_pass_request_headers", + *) Feature: the "proxy_redirect", "proxy_pass_request_headers", "proxy_pass_request_body", and "proxy_method" directives. - *) Feature: the "proxy_set_header" directive. The "proxy_x_var" was + *) Feature: the "proxy_set_header" directive. The "proxy_x_var" was canceled and must be replaced with the proxy_set_header directive. - *) Change: the "proxy_preserve_host" is canceled and must be replaced - with the "proxy_set_header Host $host" and the "proxy_redirect off" - directives, the "proxy_set_header Host $host:$proxy_port" directive + *) Change: the "proxy_preserve_host" is canceled and must be replaced + with the "proxy_set_header Host $host" and the "proxy_redirect off" + directives, the "proxy_set_header Host $host:$proxy_port" directive and the appropriate proxy_redirect directives. - *) Change: the "proxy_set_x_real_ip" is canceled and must be replaced + *) Change: the "proxy_set_x_real_ip" is canceled and must be replaced with the "proxy_set_header X-Real-IP $remote_addr" directive. - *) Change: the "proxy_add_x_forwarded_for" is canceled and must be - replaced with - the "proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for" + *) Change: the "proxy_add_x_forwarded_for" is canceled and must be + replaced with + the "proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for" directive. - *) Change: the "proxy_set_x_url" is canceled and must be replaced with - the "proxy_set_header X-URL http://$host:$server_port$request_uri" + *) Change: the "proxy_set_x_url" is canceled and must be replaced with + the "proxy_set_header X-URL http://$host:$server_port$request_uri" directive. *) Feature: the "fastcgi_param" directive. - *) Change: the "fastcgi_root", "fastcgi_set_var" and "fastcgi_params" - directive are canceled and must be replaced with the fastcgi_param + *) Change: the "fastcgi_root", "fastcgi_set_var" and "fastcgi_params" + directive are canceled and must be replaced with the fastcgi_param directives. *) Feature: the "index" directive can use the variables. @@ -4800,32 +4828,32 @@ *) Feature: the "internal" directive. - *) Feature: the CONTENT_LENGTH, CONTENT_TYPE, REMOTE_PORT, SERVER_ADDR, - SERVER_PORT, SERVER_PROTOCOL, DOCUMENT_ROOT, SERVER_NAME, + *) Feature: the CONTENT_LENGTH, CONTENT_TYPE, REMOTE_PORT, SERVER_ADDR, + SERVER_PORT, SERVER_PROTOCOL, DOCUMENT_ROOT, SERVER_NAME, REQUEST_METHOD, REQUEST_URI, and REMOTE_USER variables. - *) Change: nginx now passes the invalid lines in a client request + *) Change: nginx now passes the invalid lines in a client request headers or a backend response header. - *) Bugfix: if the backend did not transfer response for a long time and - the "send_timeout" was less than "proxy_read_timeout", then nginx + *) Bugfix: if the backend did not transfer response for a long time and + the "send_timeout" was less than "proxy_read_timeout", then nginx returned the 408 response. - *) Bugfix: the segmentation fault was occurred if the backend sent an + *) Bugfix: the segmentation fault was occurred if the backend sent an invalid line in response header; the bug had appeared in 0.1.26. - *) Bugfix: the segmentation fault may occurred in FastCGI fault + *) Bugfix: the segmentation fault may occurred in FastCGI fault tolerance configuration. - *) Bugfix: the "expires" directive did not remove the previous - "Expires" and "Cache-Control" headers. - - *) Bugfix: nginx did not take into account trailing dot in "Host" - header line. + *) Bugfix: the "expires" directive did not remove the previous "Expires" + and "Cache-Control" headers. + + *) Bugfix: nginx did not take into account trailing dot in "Host" header + line. *) Bugfix: the ngx_http_auth_module did not work under Linux. - *) Bugfix: the rewrite directive worked incorrectly, if the arguments + *) Bugfix: the rewrite directive worked incorrectly, if the arguments were in a request. *) Bugfix: nginx could not be built on MacOS X. @@ -4842,55 +4870,55 @@ *) Feature: the "blocked" parameter of the "valid_referers" directive. - *) Change: the errors while handling the request header now logged at - "info" level. The server name and the "Host" and "Referer" header + *) Change: the errors while handling the request header now logged at + "info" level. The server name and the "Host" and "Referer" header lines also logged. *) Change: the "Host" header line is also logged in error log. - *) Feature: the proxy_pass_unparsed_uri directive. The special handling - of the "://" symbols in URI, appeared in 0.1.11 version, now is + *) Feature: the proxy_pass_unparsed_uri directive. The special handling + of the "://" symbols in URI, appeared in 0.1.11 version, now is canceled. - *) Bugfix: nginx could not be built on FreeBSD and Linux, if the - --without-ngx_http_auth_basic_module configuration parameter was + *) Bugfix: nginx could not be built on FreeBSD and Linux, if the + --without-ngx_http_auth_basic_module configuration parameter was used. Changes with nginx 0.1.26 22 Mar 2005 - *) Change: the invalid client header lines are now ignored and logged - at the info level. + *) Change: the invalid client header lines are now ignored and logged at + the info level. *) Change: the server name is also logged in error log. - *) Feature: the ngx_http_auth_basic_module module and the auth_basic - and auth_basic_user_file directives. + *) Feature: the ngx_http_auth_basic_module module and the auth_basic and + auth_basic_user_file directives. Changes with nginx 0.1.25 19 Mar 2005 *) Bugfix: nginx did run on Linux parisc. - *) Feature: nginx now does not start under FreeBSD if the sysctl + *) Feature: nginx now does not start under FreeBSD if the sysctl kern.ipc.somaxconn value is too big. - *) Bugfix: if a request was internally redirected by the - ngx_http_index_module module to the ngx_http_proxy_module or - ngx_http_fastcgi_module modules, then the index file was not closed + *) Bugfix: if a request was internally redirected by the + ngx_http_index_module module to the ngx_http_proxy_module or + ngx_http_fastcgi_module modules, then the index file was not closed after request completion. - *) Feature: the "proxy_pass" can be used in location with regular + *) Feature: the "proxy_pass" can be used in location with regular expression. - *) Feature: the ngx_http_rewrite_filter_module module supports the + *) Feature: the ngx_http_rewrite_filter_module module supports the condition like "if ($HTTP_USER_AGENT ~ MSIE)". - *) Bugfix: nginx started too slow if the large number of addresses and + *) Bugfix: nginx started too slow if the large number of addresses and text values were used in the "geo" directive. - *) Change: a variable name must be declared as "$name" in the "geo" - directive. The previous variant without "$" is still supported, but + *) Change: a variable name must be declared as "$name" in the "geo" + directive. The previous variant without "$" is still supported, but will be removed soon. *) Feature: the "%{VARIABLE}v" logging parameter. @@ -4904,58 +4932,58 @@ Changes with nginx 0.1.24 04 Mar 2005 - *) Feature: the ngx_http_ssi_filter_module supports the QUERY_STRING - and DOCUMENT_URI variables. - - *) Bugfix: the ngx_http_autoindex_module may some times return the 404 - response for existent directory, if this directory was used in + *) Feature: the ngx_http_ssi_filter_module supports the QUERY_STRING and + DOCUMENT_URI variables. + + *) Bugfix: the ngx_http_autoindex_module may some times return the 404 + response for existent directory, if this directory was used in "alias" directive. - *) Bugfix: the ngx_http_ssi_filter_module ran incorrectly for large + *) Bugfix: the ngx_http_ssi_filter_module ran incorrectly for large responses. - *) Bugfix: the lack of the "Referer" header line was always accounted - as valid referrer. + *) Bugfix: the lack of the "Referer" header line was always accounted as + valid referrer. Changes with nginx 0.1.23 01 Mar 2005 - *) Feature: the ngx_http_ssi_filter_module and the ssi, - ssi_silent_errors, and ssi_min_file_chunk directives. The 'echo - var="HTTP_..." default=""' and 'echo var="REMOTE_ADDR"' commands are + *) Feature: the ngx_http_ssi_filter_module and the ssi, + ssi_silent_errors, and ssi_min_file_chunk directives. The 'echo + var="HTTP_..." default=""' and 'echo var="REMOTE_ADDR"' commands are supported. *) Feature: the %request_time log parameter. - *) Feature: if the request has no the "Host" header line, then the - "proxy_preserve_host" directive set this header line to the first + *) Feature: if the request has no the "Host" header line, then the + "proxy_preserve_host" directive set this header line to the first server name of the "server_name" directive. - *) Bugfix: nginx could not be built on platforms different from i386, + *) Bugfix: nginx could not be built on platforms different from i386, amd64, sparc, and ppc; the bug had appeared in 0.1.22. - *) Bugfix: the ngx_http_autoindex_module now shows the information not + *) Bugfix: the ngx_http_autoindex_module now shows the information not about the symlink, but about file or directory it points to. - *) Bugfix: the %apache_length parameter logged the negative length of + *) Bugfix: the %apache_length parameter logged the negative length of the response header if the no response was transferred to a client. Changes with nginx 0.1.22 22 Feb 2005 - *) Bugfix: the ngx_http_stub_status_module showed incorrect handled + *) Bugfix: the ngx_http_stub_status_module showed incorrect handled connections statistics if the proxying or FastCGI server were used. - *) Bugfix: the installation paths were incorrectly quoted on Linux and + *) Bugfix: the installation paths were incorrectly quoted on Linux and Solaris; the bug had appeared in 0.1.21. Changes with nginx 0.1.21 22 Feb 2005 - *) Bugfix: the ngx_http_stub_status_module showed incorrect statistics + *) Bugfix: the ngx_http_stub_status_module showed incorrect statistics if "rtsig" method was used or if several worker process ran on SMP. - *) Bugfix: nginx could not be built by the icc compiler on Linux or if + *) Bugfix: nginx could not be built by the icc compiler on Linux or if the zlib-1.2.x library was building from sources. *) Bugfix: nginx could not be built on NetBSD 2.0. @@ -4963,7 +4991,7 @@ Changes with nginx 0.1.20 17 Feb 2005 - *) Feature: the new "script_filename" and "remote_port" parameters of + *) Feature: the new "script_filename" and "remote_port" parameters of the fastcgi_params directive. *) Bugfix: the FastCGI stderr stream was handled incorrectly. @@ -4971,68 +4999,68 @@ Changes with nginx 0.1.19 16 Feb 2005 - *) Bugfix: now, if request contains the zero, then the 404 error is + *) Bugfix: now, if request contains the zero, then the 404 error is returned for the local requests. *) Bugfix: nginx could not be built on NetBSD 2.0. - *) Bugfix: the timeout may occur while reading of the the client - request body via SSL connections. + *) Bugfix: the timeout may occur while reading of the the client request + body via SSL connections. Changes with nginx 0.1.18 09 Feb 2005 - *) Workaround: the default values of the devpoll_events and the - devpoll_changes directives changed from 512 to 32 to be compatible + *) Workaround: the default values of the devpoll_events and the + devpoll_changes directives changed from 512 to 32 to be compatible with Solaris 10. - *) Bugfix: the proxy_set_x_var and fastcgi_set_var directives were not + *) Bugfix: the proxy_set_x_var and fastcgi_set_var directives were not inherited. - *) Bugfix: in a redirect rewrite directive arguments were concatenated + *) Bugfix: in a redirect rewrite directive arguments were concatenated with URI by an "&" rather than a "?". - *) Bugfix: the lines without trailing ";" in the file being included by + *) Bugfix: the lines without trailing ";" in the file being included by the ngx_http_geo_module were silently ignored. *) Feature: the ngx_http_stub_status_module. - *) Bugfix: the unknown log format in the access_log directive caused - the segmentation fault. - - *) Feature: the new "document_root" parameter of the fastcgi_params + *) Bugfix: the unknown log format in the access_log directive caused the + segmentation fault. + + *) Feature: the new "document_root" parameter of the fastcgi_params directive. *) Feature: the fastcgi_redirect_errors directive. - *) Feature: the new "break" modifier of the "rewrite" directive allows - to stop the rewrite/location cycle and sets the current - configuration to the request. + *) Feature: the new "break" modifier of the "rewrite" directive allows + to stop the rewrite/location cycle and sets the current configuration + to the request. Changes with nginx 0.1.17 03 Feb 2005 - *) Change: the ngx_http_rewrite_module was rewritten from the scratch. - Now it is possible to redirect, to return the error codes, to check - the variables and referrers. The directives can be used inside + *) Change: the ngx_http_rewrite_module was rewritten from the scratch. + Now it is possible to redirect, to return the error codes, to check + the variables and referrers. The directives can be used inside locations. The redirect directive was canceled. *) Feature: the ngx_http_geo_module. *) Feature: the proxy_set_x_var and fastcgi_set_var directives. - *) Bugfix: the location configuration with "=" modifier may be used in + *) Bugfix: the location configuration with "=" modifier may be used in another location. - *) Bugfix: the correct content type was set only for requests that use + *) Bugfix: the correct content type was set only for requests that use small caps letters in extension. - *) Bugfix: if the proxy_pass or fastcgi_pass directives were set in the - location, and access was denied, and the error was redirected to a + *) Bugfix: if the proxy_pass or fastcgi_pass directives were set in the + location, and access was denied, and the error was redirected to a static page, then the segmentation fault occurred. - *) Bugfix: if in a proxied "Location" header was a relative URL, then a - host name and a slash were added to them; the bug had appeared in + *) Bugfix: if in a proxied "Location" header was a relative URL, then a + host name and a slash were added to them; the bug had appeared in 0.1.14. *) Bugfix: the system error message was not logged on Linux. @@ -5040,82 +5068,82 @@ Changes with nginx 0.1.16 25 Jan 2005 - *) Bugfix: if the response were transferred by chunks, then on the HEAD + *) Bugfix: if the response were transferred by chunks, then on the HEAD request the final chunk was issued. - *) Bugfix: the "Connection: keep-alive" header were issued, even if the + *) Bugfix: the "Connection: keep-alive" header were issued, even if the keepalive_timeout directive forbade the keep-alive use. - *) Bugfix: the errors in the ngx_http_fastcgi_module caused the + *) Bugfix: the errors in the ngx_http_fastcgi_module caused the segmentation faults. - *) Bugfix: the compressed response encrypted by SSL may not transferred + *) Bugfix: the compressed response encrypted by SSL may not transferred complete. - *) Bugfix: the TCP-specific TCP_NODELAY, TCP_NOPSUH, and TCP_CORK + *) Bugfix: the TCP-specific TCP_NODELAY, TCP_NOPSUH, and TCP_CORK options, are not used for the unix domain sockets. *) Feature: the rewrite directive supports the arguments rewriting. - *) Bugfix: the response code 400 was returned for the POST request with + *) Bugfix: the response code 400 was returned for the POST request with the "Content-Length: 0" header; the bug had appeared in 0.1.14. Changes with nginx 0.1.15 19 Jan 2005 - *) Bugfix: the error while the connecting to the FastCGI server caused + *) Bugfix: the error while the connecting to the FastCGI server caused segmentation fault. - *) Bugfix: the correct handling of the regular expression, that has + *) Bugfix: the correct handling of the regular expression, that has different number of the captures and substitutions. - *) Feature: the location, that is passed to the FastCGI server, can be + *) Feature: the location, that is passed to the FastCGI server, can be regular expression. - *) Bugfix: the FastCGI's parameter REQUEST_URI is now passed with the + *) Bugfix: the FastCGI's parameter REQUEST_URI is now passed with the arguments and in the original state. - *) Bugfix: the ngx_http_rewrite_module module was required to be built + *) Bugfix: the ngx_http_rewrite_module module was required to be built to use the regular expressions in locations. - *) Bugfix: the directive "proxy_preserve_host on" adds port 80 to the - "Host" headers, if upstream listen on port 80; the bug had appeared + *) Bugfix: the directive "proxy_preserve_host on" adds port 80 to the + "Host" headers, if upstream listen on port 80; the bug had appeared in 0.1.14. - *) Bugfix: the same paths in autoconfiguration parameters - --http-client-body-temp-path=PATH and --http-proxy-temp-path=PATH, - or --http-client-body-temp-path=PATH and - --http-fastcgi-temp-path=PATH caused segmentation fault. + *) Bugfix: the same paths in autoconfiguration parameters + --http-client-body-temp-path=PATH and --http-proxy-temp-path=PATH, or + --http-client-body-temp-path=PATH and --http-fastcgi-temp-path=PATH + caused segmentation fault. Changes with nginx 0.1.14 18 Jan 2005 - *) Feature: the autoconfiguration directives: - --http-client-body-temp-path=PATH, --http-proxy-temp-path=PATH, and + *) Feature: the autoconfiguration directives: + --http-client-body-temp-path=PATH, --http-proxy-temp-path=PATH, and --http-fastcgi-temp-path=PATH - *) Change: the directory name for the temporary files with the client - request body is specified by directive client_body_temp_path, by + *) Change: the directory name for the temporary files with the client + request body is specified by directive client_body_temp_path, by default it is <prefix>/client_body_temp. - *) Feature: the ngx_http_fastcgi_module and the directives: - fastcgi_pass, fastcgi_root, fastcgi_index, fastcgi_params, - fastcgi_connect_timeout, fastcgi_send_timeout, fastcgi_read_timeout, - fastcgi_send_lowat, fastcgi_header_buffer_size, fastcgi_buffers, - fastcgi_busy_buffers_size, fastcgi_temp_path, - fastcgi_max_temp_file_size, fastcgi_temp_file_write_size, + *) Feature: the ngx_http_fastcgi_module and the directives: + fastcgi_pass, fastcgi_root, fastcgi_index, fastcgi_params, + fastcgi_connect_timeout, fastcgi_send_timeout, fastcgi_read_timeout, + fastcgi_send_lowat, fastcgi_header_buffer_size, fastcgi_buffers, + fastcgi_busy_buffers_size, fastcgi_temp_path, + fastcgi_max_temp_file_size, fastcgi_temp_file_write_size, fastcgi_next_upstream, and fastcgi_x_powered_by. - *) Bugfix: the "[alert] zero size buf" error; the bug had appeared in + *) Bugfix: the "[alert] zero size buf" error; the bug had appeared in 0.1.3. - *) Change: the URI must be specified after the host name in the + *) Change: the URI must be specified after the host name in the proxy_pass directive. - *) Change: the %3F symbol in the URI was considered as the argument + *) Change: the %3F symbol in the URI was considered as the argument string start. - *) Feature: the unix domain sockets support in the + *) Feature: the unix domain sockets support in the ngx_http_proxy_module. *) Feature: the ssl_engine and ssl_ciphers directives. @@ -5124,13 +5152,13 @@ Changes with nginx 0.1.13 21 Dec 2004 - *) Feature: the server_names_hash and server_names_hash_threshold + *) Feature: the server_names_hash and server_names_hash_threshold directives. - *) Bugfix: the *.domain.tld names in the "server_name" directive did - not work. - - *) Bugfix: the %request_length log parameter logged the incorrect + *) Bugfix: the *.domain.tld names in the "server_name" directive did not + work. + + *) Bugfix: the %request_length log parameter logged the incorrect length. @@ -5138,12 +5166,12 @@ *) Feature: the %request_length log parameter. - *) Bugfix: when using the /dev/poll, select and poll on the platforms, - where these methods may do the false reports, there may be the long - delay when the request was passed via the keep-alive connection. It + *) Bugfix: when using the /dev/poll, select and poll on the platforms, + where these methods may do the false reports, there may be the long + delay when the request was passed via the keep-alive connection. It may be at least on Solaris when using the /dev/poll. - *) Bugfix: the send_lowat directive is ignored on Linux because Linux + *) Bugfix: the send_lowat directive is ignored on Linux because Linux does not support the SO_SNDLOWAT option. @@ -5151,26 +5179,26 @@ *) Feature: the worker_priority directive. - *) Change: both tcp_nopush and tcp_nodelay directives affect the + *) Change: both tcp_nopush and tcp_nodelay directives affect the transferred response. *) Bugfix: nginx did not call initgroups(). Thanks to Andrew Sitnikov and Andrei Nigmatulin. - *) Change: now the ngx_http_autoindex_module shows the file size in the + *) Change: now the ngx_http_autoindex_module shows the file size in the bytes. - *) Bugfix: the ngx_http_autoindex_module returned the 500 error if the + *) Bugfix: the ngx_http_autoindex_module returned the 500 error if the broken symlink was in a directory. - *) Bugfix: the files bigger than 4G could not be transferred using + *) Bugfix: the files bigger than 4G could not be transferred using sendfile. - *) Bugfix: if the backend was resolved to several backends and there - was an error while the response waiting then process may got caught - in an endless loop. - - *) Bugfix: the worker process may exit with the "unknown cycle" message + *) Bugfix: if the backend was resolved to several backends and there was + an error while the response waiting then process may got caught in an + endless loop. + + *) Bugfix: the worker process may exit with the "unknown cycle" message when the /dev/poll method was used. *) Bugfix: "close() channel failed" errors. @@ -5179,44 +5207,43 @@ *) Bugfix: the send_lowat directive did not work on Linux. - *) Bugfix: the segmentation fault occurred if there was no events + *) Bugfix: the segmentation fault occurred if there was no events section in configuration. *) Bugfix: nginx could not be built on OpenBSD. - *) Bugfix: the double slashes in "://" in the URI were converted to + *) Bugfix: the double slashes in "://" in the URI were converted to ":/". Changes with nginx 0.1.10 26 Nov 2004 - *) Bugfix: if the request without arguments contains "//", "/./", - "/../" or "%XX" then the last character in the request line was - lost; the bug had appeared in 0.1.9. - - *) Bugfix: the fix in 0.1.9 for the files bigger than 2G on Linux did + *) Bugfix: if the request without arguments contains "//", "/./", "/../" + or "%XX" then the last character in the request line was lost; the + bug had appeared in 0.1.9. + + *) Bugfix: the fix in 0.1.9 for the files bigger than 2G on Linux did not work. Changes with nginx 0.1.9 25 Nov 2004 - *) Bugfix: the proxied request was sent without arguments if the - request contains "//", "/./", "/../" or "%XX". - - *) Bugfix: the large compressed responses may be transferred not + *) Bugfix: the proxied request was sent without arguments if the request + contains "//", "/./", "/../" or "%XX". + + *) Bugfix: the large compressed responses may be transferred not completely. - *) Bugfix: the files bigger than 2G was not transferred on Linux that + *) Bugfix: the files bigger than 2G was not transferred on Linux that does not support sendfile64(). - *) Bugfix: while the build configuration on Linux the - --with-poll_module parameter was required; the bug had appeared in - 0.1.8. + *) Bugfix: while the build configuration on Linux the --with-poll_module + parameter was required; the bug had appeared in 0.1.8. Changes with nginx 0.1.8 20 Nov 2004 - *) Bugfix: in the ngx_http_autoindex_module if the long file names were + *) Bugfix: in the ngx_http_autoindex_module if the long file names were in the listing. *) Feature: the "^~" modifier in the location directive. @@ -5226,34 +5253,34 @@ Changes with nginx 0.1.7 12 Nov 2004 - *) Bugfix: on FreeBSD the segmentation fault may occur if the size of + *) Bugfix: on FreeBSD the segmentation fault may occur if the size of the transferred file was changed; the bug had appeared in 0.1.5. Changes with nginx 0.1.6 11 Nov 2004 - *) Bugfix: some location directive combinations with the regular + *) Bugfix: some location directive combinations with the regular expressions caused the wrong configuration choose. Changes with nginx 0.1.5 11 Nov 2004 - *) Bugfix: on Solaris and Linux there may be too many "recvmsg() + *) Bugfix: on Solaris and Linux there may be too many "recvmsg() returned not enough data" alerts. - *) Bugfix: there were the "writev() failed (22: Invalid argument)" - errors on Solaris in proxy mode without sendfile. On other platforms - that do not support sendfile at all the process got caught in an + *) Bugfix: there were the "writev() failed (22: Invalid argument)" + errors on Solaris in proxy mode without sendfile. On other platforms + that do not support sendfile at all the process got caught in an endless loop. - *) Bugfix: segmentation fault on Solaris in proxy mode and using + *) Bugfix: segmentation fault on Solaris in proxy mode and using sendfile. *) Bugfix: segmentation fault on Solaris. *) Bugfix: on-line upgrade did not work on Linux. - *) Bugfix: the ngx_http_autoindex_module module did not escape the + *) Bugfix: the ngx_http_autoindex_module module did not escape the spaces, the quotes, and the percent signs in the directory listing. *) Change: the decrease of the copy operations. @@ -5272,31 +5299,31 @@ *) Feature: the proxy_set_x_url directive. - *) Bugfix: proxy module may get caught in an endless loop when sendfile + *) Bugfix: proxy module may get caught in an endless loop when sendfile is not used. Changes with nginx 0.1.2 21 Oct 2004 - *) Feature: the --user=USER, --group=GROUP, and --with-ld-opt=OPTIONS + *) Feature: the --user=USER, --group=GROUP, and --with-ld-opt=OPTIONS options in configure. *) Feature: the server_name directive supports *.domain.tld. *) Bugfix: the portability improvements. - *) Bugfix: if configuration file was set in command line, the + *) Bugfix: if configuration file was set in command line, the reconfiguration was impossible; the bug had appeared in 0.1.1. - *) Bugfix: proxy module may get caught in an endless loop when sendfile + *) Bugfix: proxy module may get caught in an endless loop when sendfile is not used. - *) Bugfix: with sendfile the response was not recoded according to the + *) Bugfix: with sendfile the response was not recoded according to the charset module directives; the bug had appeared in 0.1.1. *) Bugfix: very seldom bug in the kqueue processing. - *) Bugfix: the gzip module compressed the proxied responses that was + *) Bugfix: the gzip module compressed the proxied responses that was already compressed. @@ -5306,24 +5333,24 @@ *) Feature: the tcp_nodelay directive. - *) Feature: the send_lowat directive is working not only on OSes that + *) Feature: the send_lowat directive is working not only on OSes that support kqueue NOTE_LOWAT, but also on OSes that support SO_SNDLOWAT. *) Feature: the setproctitle() emulation for Linux and Solaris. *) Bugfix: the "Location" header rewrite bug fixed while the proxying. - *) Bugfix: the ngx_http_chunked_module module may get caught in an + *) Bugfix: the ngx_http_chunked_module module may get caught in an endless loop. *) Bugfix: the /dev/poll module bugs fixed. - *) Bugfix: the responses were corrupted when the temporary files were + *) Bugfix: the responses were corrupted when the temporary files were used while the proxying. *) Bugfix: the unescaped requests were passed to the backend. - *) Bugfix: while the build configuration on Linux 2.4 the + *) Bugfix: while the build configuration on Linux 2.4 the --with-poll_module parameter was required.
--- a/text/ru/CHANGES.ru-1.0 Mon Aug 29 13:27:52 2011 +0000 +++ b/text/ru/CHANGES.ru-1.0 Mon Aug 29 14:38:04 2011 +0000 @@ -1,21 +1,63 @@ +Изменения в nginx 1.0.6 29.07.2011 + + *) Добавление: уменьшение времени работы загрузчика кэша. + + *) Добавление: уменьшение времени загрузки конфигураций с большим + количеством HTTPS серверов. + + *) Добавление: теперь nginx поддерживает шифры с обменом ECDHE-ключами. + Спасибо Adrian Kotelba. + + *) Добавление: директива lingering_close. + + *) Добавление: теперь разделяемые зоны и кэши используют семафоры POSIX + на Solaris. + Спасибо Денису Иванову. + + *) Исправление: nginx не собирался на Linux 3.0. + + *) Исправление: при использовании директив fastcgi/scgi/uwsgi_param со + значениями, начинающимися со строки "HTTP_", в рабочем процессе мог + произойти segmentation fault; ошибка появилась в 0.8.40. + + *) Исправление: закрытия соединения для pipelined-запросов. + + *) Исправление: nginx не запрещал сжатие при получении значения + "gzip;q=0" в строке "Accept-Encoding" в заголовке запроса клиента. + + *) Исправление: таймаута при небуферизированном проксировании. + + *) Исправление: утечки памяти при использовании переменных в директиве + proxy_pass при работе с бэкендом по HTTPS. + + *) Исправление: в проверке параметра директивы proxy_pass, заданного + переменными. + Спасибо Lanshun Zhou. + + *) Исправление: SSL не работал на QNX. + + *) Исправление: SSL модули не собирались gcc 4.6 без параметра + --with-debug. + + Изменения в nginx 1.0.5 19.07.2011 - *) Изменение: теперь по умолчанию используются следующие шифры SSL: + *) Изменение: теперь по умолчанию используются следующие шифры SSL: "HIGH:!aNULL:!MD5". Спасибо Rob Stradling. - *) Добавление: директивы referer_hash_max_size и + *) Добавление: директивы referer_hash_max_size и referer_hash_bucket_size. Спасибо Witold Filipczyk. *) Добавление: переменная $uid_reset. - *) Исправление: при использовании кэширования в рабочем процессе мог + *) Исправление: при использовании кэширования в рабочем процессе мог произойти segmentation fault. Спасибо Lanshun Zhou. - *) Исправление: при использовании кэширования рабочие процессы могли + *) Исправление: при использовании кэширования рабочие процессы могли зациклиться во время переконфигурации; ошибка появилась в 0.8.48. Спасибо Максиму Дунину. @@ -25,38 +67,38 @@ Изменения в nginx 1.0.4 01.06.2011 - *) Изменение: теперь в регулярных выражениях в директиве map можно + *) Изменение: теперь в регулярных выражениях в директиве map можно задать чувствительность к регистру с помощью префиксов "~" и "~*". - *) Добавление: теперь разделяемые зоны и кэши используют семафоры POSIX + *) Добавление: теперь разделяемые зоны и кэши используют семафоры POSIX на Linux. Спасибо Денису Латыпову. *) Исправление: сообщения "stalled cache updating". - *) Исправление: nginx не собирался с параметром + *) Исправление: nginx не собирался с параметром --without-http_auth_basic_module; ошибка появилась в 1.0.3. Изменения в nginx 1.0.3 25.05.2011 - *) Добавление: директива auth_basic_user_file поддерживает шифрование + *) Добавление: директива auth_basic_user_file поддерживает шифрование пароля методами "$apr1", "{PLAIN}" и "{SSHA}". Спасибо Максиму Дунину. *) Добавление: директива geoip_org и переменная $geoip_org. Спасибо Александру Ускову, Arnaud Granal и Денису Латыпову. - *) Добавление: модули ngx_http_geo_module и ngx_http_geoip_module + *) Добавление: модули ngx_http_geo_module и ngx_http_geoip_module поддерживают адреса IPv4, отображённые на IPv6 адреса. - *) Исправление: при проверке адреса IPv4, отображённого на адрес IPv6, - в рабочем процессе происходил segmentation fault, если директивы - access или deny были определены только для адресов IPv6; ошибка - появилась в 0.8.22. - - *) Исправление: закэшированный ответ мог быть испорчен, если значения - директив proxy/fastcgi/scgi/uwsgi_cache_bypass и proxy/fastcgi/scgi/ + *) Исправление: при проверке адреса IPv4, отображённого на адрес IPv6, в + рабочем процессе происходил segmentation fault, если директивы access + или deny были определены только для адресов IPv6; ошибка появилась в + 0.8.22. + + *) Исправление: закэшированный ответ мог быть испорчен, если значения + директив proxy/fastcgi/scgi/uwsgi_cache_bypass и proxy/fastcgi/scgi/ uwsgi_no_cache были разными; ошибка появилась в 0.8.46. @@ -72,69 +114,68 @@ Изменения в nginx 1.0.1 03.05.2011 - *) Изменение: теперь директива split_clients использует алгоритм + *) Изменение: теперь директива split_clients использует алгоритм MurmurHash2 из-за лучшего распределения. Спасибо Олегу Мамонтову. - *) Изменение: теперь длинные строки, начинающиеся с нуля, не считаются + *) Изменение: теперь длинные строки, начинающиеся с нуля, не считаются ложными значениями. Спасибо Максиму Дунину. - *) Изменение: теперь по умолчанию nginx использует значение 511 для + *) Изменение: теперь по умолчанию nginx использует значение 511 для listen backlog на Linux. - *) Добавление: переменные $upstream_... можно использовать в SSI и + *) Добавление: переменные $upstream_... можно использовать в SSI и перловом модулях. - *) Исправление: теперь nginx лучше ограничивает размер кэша на - диске. + *) Исправление: теперь nginx лучше ограничивает размер кэша на диске. Спасибо Олегу Мамонтову. - *) Исправление: при парсинге неправильного IPv4 адреса мог произойти + *) Исправление: при парсинге неправильного IPv4 адреса мог произойти segmentation fault; ошибка появилась в 0.8.22. Спасибо Максиму Дунину. *) Исправление: nginx не собирался gcc 4.6 без параметра --with-debug. - *) Исправление: nginx не собирался на Solaris 9 и более ранних; ошибка + *) Исправление: nginx не собирался на Solaris 9 и более ранних; ошибка появилась в 0.9.3. Спасибо Dagobert Michelsen. - *) Исправление: переменная $request_time имела неверные значения, если + *) Исправление: переменная $request_time имела неверные значения, если использовались подзапросы; ошибка появилась в 0.8.47. Спасибо Игорю А. Валькову. Изменения в nginx 1.0.0 12.04.2011 - *) Исправление: cache manager мог нагружать процессор после + *) Исправление: cache manager мог нагружать процессор после переконфигурации. Спасибо Максиму Дунину. - *) Исправление: директива "image_filter crop" неправильно работала в + *) Исправление: директива "image_filter crop" неправильно работала в сочетании с "image_filter rotate 180". - *) Исправление: директива "satisfy any" запрещала выдачу + *) Исправление: директива "satisfy any" запрещала выдачу пользовательской страницы для 401 кода. Изменения в nginx 0.9.7 04.04.2011 - *) Добавление: теперь соединения в состоянии keepalive могут быть + *) Добавление: теперь соединения в состоянии keepalive могут быть закрыты преждевременно, если у воркера нет свободных соединений. Спасибо Максиму Дунину. *) Добавление: параметр rotate директивы image_filter. Спасибо Adam Bocim. - *) Исправление: ситуации, когда бэкенд в директивах fastcgi_pass, - scgi_pass или uwsgi_pass задан выражением и ссылается на описанный + *) Исправление: ситуации, когда бэкенд в директивах fastcgi_pass, + scgi_pass или uwsgi_pass задан выражением и ссылается на описанный upstream. Изменения в nginx 0.9.6 21.03.2011 - *) Добавление: директива map поддерживает регулярные выражения в + *) Добавление: директива map поддерживает регулярные выражения в качестве значения первого параметра. *) Добавление: переменная $time_iso8601 для access_log. @@ -143,20 +184,19 @@ Изменения в nginx 0.9.5 21.02.2011 - *) Изменение: теперь по умолчанию nginx использует значение -1 для + *) Изменение: теперь по умолчанию nginx использует значение -1 для listen backlog на Linux. Спасибо Андрею Нигматулину. - *) Добавление: параметр utf8 в директивах geoip_country и - geoip_city. + *) Добавление: параметр utf8 в директивах geoip_country и geoip_city. Спасибо Денису Латыпову. - *) Исправление: исправление в умолчательной директиве proxy_redirect, + *) Исправление: исправление в умолчательной директиве proxy_redirect, если в директиве proxy_pass не был описан URI. Спасибо Максиму Дунину. - *) Исправление: директива error_page не работала с нестандартными - кодами ошибок; ошибка появилась в 0.8.53. + *) Исправление: директива error_page не работала с нестандартными кодами + ошибок; ошибка появилась в 0.8.53. Спасибо Максиму Дунину. @@ -169,20 +209,20 @@ Изменения в nginx 0.9.3 13.12.2010 - *) Исправление: если для пары IPv6-адрес:порт описан только один - сервер, то выделения в регулярных выражениях в директиве server_name - не работали. - - *) Исправление: nginx не собирался под Solaris; ошибка появилась в + *) Исправление: если для пары IPv6-адрес:порт описан только один сервер, + то выделения в регулярных выражениях в директиве server_name не + работали. + + *) Исправление: nginx не собирался под Solaris; ошибка появилась в 0.9.0. Изменения в nginx 0.9.2 06.12.2010 - *) Добавление: поддержка строки "If-Unmodified-Since" в заголовке + *) Добавление: поддержка строки "If-Unmodified-Since" в заголовке запросе клиента. - *) Изменение: использование accept(), если accept4() не реализован; + *) Изменение: использование accept(), если accept4() не реализован; ошибка появилась в 0.9.0. *) Исправление: nginx не собирался под Cygwin; ошибка появилась в 0.9.0. @@ -193,18 +233,18 @@ Изменения в nginx 0.9.1 30.11.2010 - *) Исправление: директивы вида "return CODE message" не работали; - ошибка появилась в 0.9.0. + *) Исправление: директивы вида "return CODE message" не работали; ошибка + появилась в 0.9.0. Изменения в nginx 0.9.0 29.11.2010 *) Добавление: директива keepalive_disable. - *) Добавление: директива map поддерживает переменные в качестве - значения определяемой переменной. - - *) Добавление: директива map поддерживает пустые строки в качестве + *) Добавление: директива map поддерживает переменные в качестве значения + определяемой переменной. + + *) Добавление: директива map поддерживает пустые строки в качестве значения первого параметра. *) Добавление: директива map поддерживает выражения в первом параметре. @@ -215,38 +255,38 @@ *) Добавление: поддержка accept4() в Linux. Спасибо Simon Liu. - *) Изменение: устранение предупреждения линкера о "sys_errlist" и + *) Изменение: устранение предупреждения линкера о "sys_errlist" и "sys_nerr" под Linux; предупреждение появилось в 0.8.35. - *) Исправление: при использовании директивы auth_basic в рабочем + *) Исправление: при использовании директивы auth_basic в рабочем процессе мог произойти segmentation fault. Спасибо Михаилу Лалетину. - *) Исправление: совместимость с модулем ngx_http_eval_module; ошибка + *) Исправление: совместимость с модулем ngx_http_eval_module; ошибка появилась в 0.8.42. Изменения в nginx 0.8.53 18.10.2010 - *) Добавление: теперь директива error_page позволяет менять код статуса + *) Добавление: теперь директива error_page позволяет менять код статуса у редиректа. - *) Добавление: директива gzip_disable поддерживает специальную маску + *) Добавление: директива gzip_disable поддерживает специальную маску degradation. - *) Исправление: при использовании файлового AIO могла происходить - утечка сокетов. + *) Исправление: при использовании файлового AIO могла происходить утечка + сокетов. Спасибо Максиму Дунину. - *) Исправление: если в первом сервере не была описана директива listen - и нигде явно не описан сервер по умолчанию, то сервером по умолчанию - становился следующий сервер с директивой listen; ошибка появилась в + *) Исправление: если в первом сервере не была описана директива listen и + нигде явно не описан сервер по умолчанию, то сервером по умолчанию + становился следующий сервер с директивой listen; ошибка появилась в 0.8.21. Изменения в nginx 0.8.52 28.09.2010 - *) Исправление: nginx использовал режим SSL для listen сокета, если для + *) Исправление: nginx использовал режим SSL для listen сокета, если для него был установлен любой listen-параметр; ошибка появилась в 0.8.51. @@ -254,98 +294,98 @@ *) Изменение: директива secure_link_expires упразднена. - *) Изменение: уровень логгирования ошибок resolver'а понижен с уровня + *) Изменение: уровень логгирования ошибок resolver'а понижен с уровня alert на error. - *) Добавление: теперь параметр "ssl" listen-сокета можно устанавливать + *) Добавление: теперь параметр "ssl" listen-сокета можно устанавливать несколько раз. Изменения в nginx 0.8.50 02.09.2010 - *) Добавление: директивы secure_link, secure_link_md5 и + *) Добавление: директивы secure_link, secure_link_md5 и secure_link_expires модуля ngx_http_secure_link_module. *) Добавление: ключ -q. Спасибо Геннадию Махомеду. - *) Исправление: при использовании кэширования рабочие процессы и могли + *) Исправление: при использовании кэширования рабочие процессы и могли зациклиться во время переконфигурации; ошибка появилась в 0.8.48. *) Исправление: в директиве gzip_disable. Спасибо Derrick Petzold. - *) Исправление: nginx/Windows не мог посылать сигналы stop, quit, + *) Исправление: nginx/Windows не мог посылать сигналы stop, quit, reopen, reload процессу, запущенному в другой сессии. Изменения в nginx 0.8.49 09.08.2010 - *) Добавление: директива image_filter_jpeg_quality поддерживает + *) Добавление: директива image_filter_jpeg_quality поддерживает переменные. - *) Исправление: при использовании переменной $geoip_region_name в - рабочем процессе мог произойти segmentation fault; ошибка появилась - в 0.8.48. - - *) Исправление: ошибки, перехваченные error_page, кэшировались только - до следующего запроса; ошибка появилась в 0.8.48. + *) Исправление: при использовании переменной $geoip_region_name в + рабочем процессе мог произойти segmentation fault; ошибка появилась в + 0.8.48. + + *) Исправление: ошибки, перехваченные error_page, кэшировались только до + следующего запроса; ошибка появилась в 0.8.48. Изменения в nginx 0.8.48 03.08.2010 - *) Изменение: теперь по умолчанию директива server_name имеет значение + *) Изменение: теперь по умолчанию директива server_name имеет значение пустое имя "". Спасибо Геннадию Махомеду. - *) Изменение: теперь по умолчанию директива server_name_in_redirect + *) Изменение: теперь по умолчанию директива server_name_in_redirect имеет значение off. - *) Добавление: переменные $geoip_dma_code, $geoip_area_code и + *) Добавление: переменные $geoip_dma_code, $geoip_area_code и $geoip_region_name. Спасибо Christine McGonagle. - *) Исправление: директивы proxy_pass, fastcgi_pass, uwsgi_pass и + *) Исправление: директивы proxy_pass, fastcgi_pass, uwsgi_pass и scgi_pass не наследовались в блоки limit_except. - *) Исправление: директивы proxy_cache_min_uses, fastcgi_cache_min_uses - uwsgi_cache_min_uses и scgi_cache_min_uses не работали; ошибка + *) Исправление: директивы proxy_cache_min_uses, fastcgi_cache_min_uses + uwsgi_cache_min_uses и scgi_cache_min_uses не работали; ошибка появилась в 0.8.46. - *) Исправление: директива fastcgi_split_path_info неверно использовала + *) Исправление: директива fastcgi_split_path_info неверно использовала выделения, если в выделения попадала только часть URI. Спасибо Юрию Тарадаю и Frank Enderle. - *) Исправление: директива rewrite не экранировала символ ";" при - копировании из URI в аргументы. + *) Исправление: директива rewrite не экранировала символ ";" при + копировании из URI в аргументы. Спасибо Daisuke Murase. - *) Исправление: модуль ngx_http_image_filter_module закрывал - соединение, если изображение было больше размера image_filter_buffer. + *) Исправление: модуль ngx_http_image_filter_module закрывал соединение, + если изображение было больше размера image_filter_buffer. Изменения в nginx 0.8.47 28.07.2010 - *) Исправление: переменная $request_time имела неверные значения для + *) Исправление: переменная $request_time имела неверные значения для подзапросов. *) Исправление: ошибки, перехваченные error_page, не кэшировались. - *) Исправление: если использовался параметр max_size, то cache manager + *) Исправление: если использовался параметр max_size, то cache manager мог зациклиться; ошибка появилась в 0.8.46. Изменения в nginx 0.8.46 19.07.2010 - *) Изменение: директивы proxy_no_cache, fastcgi_no_cache, - uwsgi_no_cache и scgi_no_cache теперь влияют только на сохранение - закэшированного ответа. - - *) Добавление: директивы proxy_cache_bypass, fastcgi_cache_bypass, + *) Изменение: директивы proxy_no_cache, fastcgi_no_cache, uwsgi_no_cache + и scgi_no_cache теперь влияют только на сохранение закэшированного + ответа. + + *) Добавление: директивы proxy_cache_bypass, fastcgi_cache_bypass, uwsgi_cache_bypass и scgi_cache_bypass. - *) Исправление: nginx не освобождал память в keys_zone кэшей в случае - ошибки работы с бэкендом: память освобождалась только по истечении + *) Исправление: nginx не освобождал память в keys_zone кэшей в случае + ошибки работы с бэкендом: память освобождалась только по истечении времени неактивности или при недостатке памяти. @@ -354,8 +394,8 @@ *) Добавление: улучшения в модуле ngx_http_xslt_filter. Спасибо Laurence Rowe. - *) Исправление: ответ SSI модуля мог передаваться не полностью после - команды include с параметром wait="yes"; ошибка появилась в 0.7.25. + *) Исправление: ответ SSI модуля мог передаваться не полностью после + команды include с параметром wait="yes"; ошибка появилась в 0.7.25. Спасибо Максиму Дунину. *) Исправление: директива listen не поддерживала параметр setfib=0. @@ -363,20 +403,20 @@ Изменения в nginx 0.8.44 05.07.2010 - *) Изменение: теперь nginx по умолчанию не кэширует ответы бэкендов, в + *) Изменение: теперь nginx по умолчанию не кэширует ответы бэкендов, в заголовке которых есть строка "Set-Cookie". *) Добавление: директива listen поддерживает параметр setfib. Спасибо Андрею Филонову. - *) Исправление: директива sub_filter могла изменять регистр букв при + *) Исправление: директива sub_filter могла изменять регистр букв при частичном совпадении. *) Исправление: совместимость с HP/UX. *) Исправление: совместимость с компилятором AIX xlC_r. - *) Исправление: nginx считал большие пакеты SSLv2 как обычные текстовые + *) Исправление: nginx считал большие пакеты SSLv2 как обычные текстовые запросы. Спасибо Miroslaw Jaworski. @@ -385,22 +425,22 @@ *) Добавление: ускорение загрузки больших баз geo-диапазонов. - *) Исправление: перенаправление ошибки в "location /zero {return 204;}" - без изменения кода ответа оставляло тело ошибки; ошибка появилась в + *) Исправление: перенаправление ошибки в "location /zero {return 204;}" + без изменения кода ответа оставляло тело ошибки; ошибка появилась в 0.8.42. - *) Исправление: nginx мог закрывать IPv6 listen сокет во время + *) Исправление: nginx мог закрывать IPv6 listen сокет во время переконфигурации. Спасибо Максиму Дунину. - *) Исправление: переменную $uid_set можно использовать на любой стадии + *) Исправление: переменную $uid_set можно использовать на любой стадии обработки запроса. Изменения в nginx 0.8.42 21.06.2010 - *) Изменение: теперь nginx проверяет location'ы, заданные регулярными - выражениями, если запрос полностью совпал с location'ом, заданным + *) Изменение: теперь nginx проверяет location'ы, заданные регулярными + выражениями, если запрос полностью совпал с location'ом, заданным строкой префикса. Предыдущее поведение появилось в 0.7.1. *) Добавление: модуль ngx_http_scgi_module. @@ -411,49 +451,49 @@ Изменения в nginx 0.8.41 15.06.2010 - *) Безопасность: рабочий процесс nginx/Windows мог завершаться аварийно + *) Безопасность: рабочий процесс nginx/Windows мог завершаться аварийно при запросе файла с неверной кодировкой UTF-8. - *) Изменение: теперь nginx разрешает использовать пробелы в строке + *) Изменение: теперь nginx разрешает использовать пробелы в строке запроса. - *) Исправление: директива proxy_redirect неправильно изменяла строку + *) Исправление: директива proxy_redirect неправильно изменяла строку "Refresh" в заголовке ответа бэкенда. Спасибо Андрею Андрееву и Максиму Согину. - *) Исправление: nginx не поддерживал путь без имени хоста в строке + *) Исправление: nginx не поддерживал путь без имени хоста в строке "Destination" в заголовке запроса. Изменения в nginx 0.8.40 07.06.2010 - *) Безопасность: теперь nginx/Windows игнорирует имя потока файла по + *) Безопасность: теперь nginx/Windows игнорирует имя потока файла по умолчанию. Спасибо Jose Antonio Vazquez Gonzalez. *) Добавление: модуль ngx_http_uwsgi_module. Спасибо Roberto De Ioris. - *) Добавление: директива fastcgi_param со значением, начинающимся со + *) Добавление: директива fastcgi_param со значением, начинающимся со строки "HTTP_", изменяет строку заголовка в запросе клиента. - *) Исправление: строки "If-Modified-Since", "If-Range" и им подобные в - заголовке запроса клиента передавались FastCGI-серверу при + *) Исправление: строки "If-Modified-Since", "If-Range" и им подобные в + заголовке запроса клиента передавались FastCGI-серверу при кэшировании. - *) Исправление: listen unix domain сокет нельзя было изменить во время + *) Исправление: listen unix domain сокет нельзя было изменить во время переконфигурации. Спасибо Максиму Дунину. Изменения в nginx 0.8.39 31.05.2010 - *) Исправление: наследуемая директива alias неправильно работала во + *) Исправление: наследуемая директива alias неправильно работала во вложенном location'е. *) Исправление: в комбинации директив alias с переменными и try_files; - *) Исправление: listen unix domain и IPv6 сокеты не наследовались во + *) Исправление: listen unix domain и IPv6 сокеты не наследовались во время обновления без перерыва. Спасибо Максиму Дунину. @@ -462,15 +502,15 @@ *) Добавление: директивы proxy_no_cache и fastcgi_no_cache. - *) Добавление: теперь при использовании переменной $scheme в директиве + *) Добавление: теперь при использовании переменной $scheme в директиве rewrite автоматически делается редирект. Спасибо Piotr Sikora. - *) Исправление: теперь задержки в директиве limit_req соответствует + *) Исправление: теперь задержки в директиве limit_req соответствует описанному алгоритму. Спасибо Максиму Дунину. - *) Исправление: переменную $uid_got нельзя было использовать в SSI и + *) Исправление: переменную $uid_got нельзя было использовать в SSI и перловом модулях. @@ -480,33 +520,33 @@ *) Добавление: директива map поддерживает ключи больше 255 символов. - *) Исправление: nginx игнорировал значения "private" и "no-store" в + *) Исправление: nginx игнорировал значения "private" и "no-store" в строке "Cache-Control" в заголовке ответа бэкенда. - *) Исправление: параметр stub в SSI-директиве include не использовался, + *) Исправление: параметр stub в SSI-директиве include не использовался, если пустой ответ имел код 200. - *) Исправление: если проксированный или FastCGI запрос внутренне - перенаправлялся в другой проксированный или FastCGI location, то в - рабочем процессе мог произойти segmentation fault; ошибка появилась - в 0.8.33. + *) Исправление: если проксированный или FastCGI запрос внутренне + перенаправлялся в другой проксированный или FastCGI location, то в + рабочем процессе мог произойти segmentation fault; ошибка появилась в + 0.8.33. Спасибо Yichun Zhang. - *) Исправление: соединения IMAP к серверу Zimbra могло зависнуть до + *) Исправление: соединения IMAP к серверу Zimbra могло зависнуть до таймаута. Спасибо Alan Batie. Изменения в nginx 0.8.36 22.04.2010 - *) Исправление: модуль ngx_http_dav_module неправильно обрабатывал + *) Исправление: модуль ngx_http_dav_module неправильно обрабатывал методы DELETE, COPY и MOVE для симлинков. - *) Исправление: модуль SSI в подзапросах использовал закэшированные в - основном запросе значения переменных $query_string, $arg_... и им + *) Исправление: модуль SSI в подзапросах использовал закэшированные в + основном запросе значения переменных $query_string, $arg_... и им подобных. - *) Исправление: значение переменной повторно экранировалось после + *) Исправление: значение переменной повторно экранировалось после каждого вывода SSI-команды echo; ошибка появилась в 0.6.14. *) Исправление: рабочий процесс зависал при запросе файла FIFO. @@ -515,7 +555,7 @@ *) Исправление: совместимость с OpenSSL-1.0.0 на 64-битном Linux. Спасибо Максиму Дунину. - *) Исправление: nginx не собирался с параметром --without-http-cache; + *) Исправление: nginx не собирался с параметром --without-http-cache; ошибка появилась в 0.8.35. @@ -525,60 +565,60 @@ *) Добавление: директива chunked_transfer_encoding. - *) Исправление: символ "&" при копировании в аргументы в правилах + *) Исправление: символ "&" при копировании в аргументы в правилах rewrite не экранировался. - *) Исправление: nginx мог завершаться аварийно во время обработки - сигнала или при использовании директивы timer_resolution на + *) Исправление: nginx мог завершаться аварийно во время обработки + сигнала или при использовании директивы timer_resolution на платформах, не поддерживающих методы kqueue или eventport. Спасибо George Xie и Максиму Дунину. - *) Исправление: если временные файлы и постоянное место хранения - располагались на разных файловых системах, то у постоянных файлов + *) Исправление: если временные файлы и постоянное место хранения + располагались на разных файловых системах, то у постоянных файлов время изменения было неверным. Спасибо Максиму Дунину. - *) Исправление: модуль ngx_http_memcached_module мог выдавать ошибку + *) Исправление: модуль ngx_http_memcached_module мог выдавать ошибку "memcached sent invalid trailer". Спасибо Максиму Дунину. - *) Исправление: nginx не мог собрать библиотеку zlib-1.2.4 из исходных + *) Исправление: nginx не мог собрать библиотеку zlib-1.2.4 из исходных текстов. Спасибо Максиму Дунину. - *) Исправление: в рабочем процессе происходил segmentation fault, если - перед ответом FastCGI-сервера было много вывода в stderr; ошибка + *) Исправление: в рабочем процессе происходил segmentation fault, если + перед ответом FastCGI-сервера было много вывода в stderr; ошибка появилась в 0.8.34. Спасибо Максиму Дунину. Изменения в nginx 0.8.34 03.03.2010 - *) Исправление: nginx не поддерживал все шифры, используемые в + *) Исправление: nginx не поддерживал все шифры, используемые в клиентских сертификатах. Спасибо Иннокентию Еникееву. - *) Исправление: nginx неправильно кэшировал FastCGI-ответы, если перед + *) Исправление: nginx неправильно кэшировал FastCGI-ответы, если перед ответом было много вывода в stderr. *) Исправление: nginx не поддерживал HTTPS-рефереры. - *) Исправление: nginx/Windows мог не находить файлы, если путь в + *) Исправление: nginx/Windows мог не находить файлы, если путь в конфигурации был задан в другом регистре; ошибка появилась в 0.8.33. - *) Исправление: переменная $date_local выдавала неверное время, если + *) Исправление: переменная $date_local выдавала неверное время, если использовался формат "%s". Спасибо Максиму Дунину. - *) Исправление: если ssl_session_cache не был установлен или установлен - в none, то при проверке клиентского сертификаты могла происходить + *) Исправление: если ssl_session_cache не был установлен или установлен + в none, то при проверке клиентского сертификаты могла происходить ошибка "session id context uninitialized"; ошибка появилась в 0.7.1. - *) Исправление: geo-диапазон возвращал значение по умолчанию, если - диапазон включал в себя одну и более сетей размером /16 и не + *) Исправление: geo-диапазон возвращал значение по умолчанию, если + диапазон включал в себя одну и более сетей размером /16 и не начинался на границе сети размером /16. - *) Исправление: блок, используемый в параметре stub в SSI-директиве + *) Исправление: блок, используемый в параметре stub в SSI-директиве include, выводился с MIME-типом "text/plain". *) Исправление: $r->sleep() не работал; ошибка появилась в 0.8.11. @@ -586,97 +626,95 @@ Изменения в nginx 0.8.33 01.02.2010 - *) Безопасность: теперь nginx/Windows игнорирует пробелы в конце URI. + *) Безопасность: теперь nginx/Windows игнорирует пробелы в конце URI. Спасибо Dan Crowley, Core Security Technologies. - *) Безопасность: теперь nginx/Windows игнорирует короткие имена файлов. + *) Безопасность: теперь nginx/Windows игнорирует короткие имена файлов. Спасибо Dan Crowley, Core Security Technologies. - *) Изменение: теперь keepalive соединения после запросов POST не + *) Изменение: теперь keepalive соединения после запросов POST не запрещаются для MSIE 7.0+. Спасибо Adam Lounds. *) Изменение: теперь keepalive соединения запрещены для Safari. Спасибо Joshua Sierles. - *) Исправление: если проксированный или FastCGI запрос внутренне - перенаправлялся в другой проксированный или FastCGI location, то - переменная $upstream_response_time могла иметь ненормально большое + *) Исправление: если проксированный или FastCGI запрос внутренне + перенаправлялся в другой проксированный или FastCGI location, то + переменная $upstream_response_time могла иметь ненормально большое значение; ошибка появилась в 0.8.7. - *) Исправление: в рабочем процессе мог произойти segmentation fault при + *) Исправление: в рабочем процессе мог произойти segmentation fault при отбрасывания тела запроса; ошибка появилась в 0.8.11. Изменения в nginx 0.8.32 11.01.2010 - *) Исправление: ошибки при использовании кодировки UTF-8 в + *) Исправление: ошибки при использовании кодировки UTF-8 в ngx_http_autoindex_module. Спасибо Максиму Дунину. - *) Исправление: именованные выделения в регулярных выражениях работали + *) Исправление: именованные выделения в регулярных выражениях работали только для двух переменных. Спасибо Максиму Дунину. - *) Исправление: теперь в строке заголовка запроса "Host" используется - имя "localhost", если в директиве auth_http указан unix domain - сокет. + *) Исправление: теперь в строке заголовка запроса "Host" используется + имя "localhost", если в директиве auth_http указан unix domain сокет. Спасибо Максиму Дунину. - *) Исправление: nginx не поддерживал передачу chunk'ами для 201-ых + *) Исправление: nginx не поддерживал передачу chunk'ами для 201-ых ответов. Спасибо Julian Reich. - *) Исправление: если директива "expires modified" выставляла дату в - прошлом, то в строке заголовка ответа "Cache-Control" выдавалось + *) Исправление: если директива "expires modified" выставляла дату в + прошлом, то в строке заголовка ответа "Cache-Control" выдавалось отрицательное число. Спасибо Алексею Капранову. Изменения в nginx 0.8.31 23.12.2009 - *) Добавление: теперь директива error_page может перенаправлять ответы + *) Добавление: теперь директива error_page может перенаправлять ответы со статусом 301 и 302. - *) Добавление: переменные $geoip_city_continent_code, $geoip_latitude и + *) Добавление: переменные $geoip_city_continent_code, $geoip_latitude и $geoip_longitude. Спасибо Arvind Sundararajan. - *) Добавление: модуль ngx_http_image_filter_module теперь всегда - удаляет EXIF и другие данные, если они занимают больше 5% в - JPEG-файле. - - *) Исправление: nginx закрывал соединение при запросе закэшированного + *) Добавление: модуль ngx_http_image_filter_module теперь всегда удаляет + EXIF и другие данные, если они занимают больше 5% в JPEG-файле. + + *) Исправление: nginx закрывал соединение при запросе закэшированного ответа с пустым телом. Спасибо Piotr Sikora. - *) Исправление: nginx мог не собираться gcc 4.x при использовании + *) Исправление: nginx мог не собираться gcc 4.x при использовании оптимизации -O2 и выше. Спасибо Максиму Дунину и Денису Латыпову. - *) Исправление: регулярные выражения в location всегда тестировались с + *) Исправление: регулярные выражения в location всегда тестировались с учётом регистра; ошибка появилась в 0.8.25. - *) Исправление: nginx кэшировал 304 ответ, если в заголовке + *) Исправление: nginx кэшировал 304 ответ, если в заголовке проксируемого запроса была строка "If-None-Match". Спасибо Tim Dettrick и David Kostal. - *) Исправление: nginx/Windows пытался дважды удалить временный файл при + *) Исправление: nginx/Windows пытался дважды удалить временный файл при перезаписи уже существующего файла. Изменения в nginx 0.8.30 15.12.2009 - *) Изменение: теперь по умолчанию размер буфера директивы + *) Изменение: теперь по умолчанию размер буфера директивы large_client_header_buffers равен 8K. Спасибо Andrew Cholakian. *) Добавление: файл conf/fastcgi.conf для простых конфигураций FastCGI. - *) Исправление: nginx/Windows пытался дважды переименовать временный + *) Исправление: nginx/Windows пытался дважды переименовать временный файл при перезаписи уже существующего файла. - *) Исправление: ошибки double free or corruption, возникающей, если имя + *) Исправление: ошибки double free or corruption, возникающей, если имя хоста не было найдено; ошибка появилась в 0.8.22. Спасибо Константину Свисту. @@ -686,10 +724,10 @@ Изменения в nginx 0.8.29 30.11.2009 - *) Изменение: теперь для проксируемых ответов HTTP/0.9 в лог пишется - код ответа "009". - - *) Добавление: директивы addition_types, charset_types, gzip_types, + *) Изменение: теперь для проксируемых ответов HTTP/0.9 в лог пишется код + ответа "009". + + *) Добавление: директивы addition_types, charset_types, gzip_types, ssi_types, sub_filter_types и xslt_types поддерживают параметр "*". *) Добавление: использование встроенных атомарных операций GCC 4.1+. @@ -698,69 +736,69 @@ *) Добавление: параметр --with-libatomic[=DIR] в configure. Спасибо W-Mark Kubacki. - *) Исправление: listen unix domain сокет имели ограниченные права + *) Исправление: listen unix domain сокет имели ограниченные права доступа. - *) Исправление: закэшированные ответы ответов HTTP/0.9 неправильно + *) Исправление: закэшированные ответы ответов HTTP/0.9 неправильно обрабатывались. - *) Исправление: именованные выделения в регулярных выражениях, заданные + *) Исправление: именованные выделения в регулярных выражениях, заданные как "?P<...>", не работали в директиве server_name. Спасибо Максиму Дунину. Изменения в nginx 0.8.28 23.11.2009 - *) Исправление: nginx не собирался с параметром --without-pcre; ошибка + *) Исправление: nginx не собирался с параметром --without-pcre; ошибка появилась в 0.8.25. Изменения в nginx 0.8.27 17.11.2009 - *) Исправление: регулярные выражения не работали в nginx/Windows; - ошибка появилась в 0.8.25. + *) Исправление: регулярные выражения не работали в nginx/Windows; ошибка + появилась в 0.8.25. Изменения в nginx 0.8.26 16.11.2009 - *) Исправление: ошибки при использовании выделений в директиве rewrite; + *) Исправление: ошибки при использовании выделений в директиве rewrite; ошибка появилась в 0.8.25. - *) Исправление: nginx не собирался без параметра --with-debug; ошибка + *) Исправление: nginx не собирался без параметра --with-debug; ошибка появилась в 0.8.25. Изменения в nginx 0.8.25 16.11.2009 - *) Изменение: теперь в лог ошибок не пишется сообщение, если переменная + *) Изменение: теперь в лог ошибок не пишется сообщение, если переменная не найдена с помощью метода $r->variable(). *) Добавление: модуль ngx_http_degradation_module. *) Добавление: именованные выделения в регулярных выражениях. - *) Добавление: теперь при использовании переменных в директиве + *) Добавление: теперь при использовании переменных в директиве proxy_pass не требуется задавать URI. *) Добавление: теперь директива msie_padding работает и для Chrome. - *) Исправление: в рабочем процессе происходил segmentation fault при + *) Исправление: в рабочем процессе происходил segmentation fault при недостатке памяти; ошибка появилась в 0.8.18. - *) Исправление: nginx передавал сжатые ответы клиентам, не - поддерживающим сжатие, при настройках gzip_static on и gzip_vary - off; ошибка появилась в 0.8.16. + *) Исправление: nginx передавал сжатые ответы клиентам, не + поддерживающим сжатие, при настройках gzip_static on и gzip_vary off; + ошибка появилась в 0.8.16. Изменения в nginx 0.8.24 11.11.2009 - *) Исправление: nginx всегда добавлял строку "Content-Encoding: gzip" в + *) Исправление: nginx всегда добавлял строку "Content-Encoding: gzip" в заголовок 304-ых ответов модуля ngx_http_gzip_static_module. - *) Исправление: nginx не собирался без параметра --with-debug; ошибка + *) Исправление: nginx не собирался без параметра --with-debug; ошибка появилась в 0.8.23. - *) Исправление: параметр "unix:" в директиве set_real_ip_from + *) Исправление: параметр "unix:" в директиве set_real_ip_from неправильно наследовался с предыдущего уровня. *) Исправление: в resolver'е при определении пустого имени. @@ -771,11 +809,11 @@ *) Безопасность: теперь SSL/TLS renegotiation запрещён. Спасибо Максиму Дунину. - *) Исправление: listen unix domain сокет не наследовался во время + *) Исправление: listen unix domain сокет не наследовался во время обновления без перерыва. - *) Исправление: параметр "unix:" в директиве set_real_ip_from не - работал без ещё одной директивы с любым IP-адресом. + *) Исправление: параметр "unix:" в директиве set_real_ip_from не работал + без ещё одной директивы с любым IP-адресом. *) Исправление: segmentation fault и зацикливания в resolver'е. @@ -789,47 +827,47 @@ *) Добавление: директивы access и deny поддерживают IPv6. - *) Добавление: директива set_real_ip_from поддерживает IPv6 адреса в + *) Добавление: директива set_real_ip_from поддерживает IPv6 адреса в заголовках запроса. *) Добавление: параметр "unix:" в директиве set_real_ip_from. - *) Исправление: nginx не удалял unix domain сокет после тестирования + *) Исправление: nginx не удалял unix domain сокет после тестирования конфигурации. - *) Исправление: nginx удалял unix domain сокет во время обновления без + *) Исправление: nginx удалял unix domain сокет во время обновления без перерыва. *) Исправление: оператор "!-x" не работал. Спасибо Максиму Дунину. - *) Исправление: в рабочем процессе мог произойти segmentation fault при + *) Исправление: в рабочем процессе мог произойти segmentation fault при использовании limit_rate в HTTPS сервере. Спасибо Максиму Дунину. - *) Исправление: при записи в лог переменной $limit_rate в рабочем + *) Исправление: при записи в лог переменной $limit_rate в рабочем процессе происходил segmentation fault. Спасибо Максиму Дунину. - *) Исправление: в рабочем процессе мог произойти segmentation fault, - если внутри блока server не было директивы listen; ошибка появилась - в 0.8.21. + *) Исправление: в рабочем процессе мог произойти segmentation fault, + если внутри блока server не было директивы listen; ошибка появилась в + 0.8.21. Изменения в nginx 0.8.21 26.10.2009 *) Добавление: теперь ключ -V показывает статус поддержки TLS SNI. - *) Добавление: директива listen модуля HTTP поддерживает unix domain + *) Добавление: директива listen модуля HTTP поддерживает unix domain сокеты. Спасибо Hongli Lai. *) Добавление: параметр "default_server" в директиве listen. - *) Добавление: теперь параметр "default" не обязателен для установки + *) Добавление: теперь параметр "default" не обязателен для установки параметров listen-сокета. - *) Исправление: nginx не поддерживал даты в 2038 году на 32-битных + *) Исправление: nginx не поддерживал даты в 2038 году на 32-битных платформах; *) Исправление: утечки сокетов; ошибка появилась в 0.8.11. @@ -837,26 +875,25 @@ Изменения в nginx 0.8.20 14.10.2009 - *) Изменение: теперь по умолчанию используются следующие шифры SSL: + *) Изменение: теперь по умолчанию используются следующие шифры SSL: "HIGH:!ADH:!MD5". - *) Исправление: модуль ngx_http_autoindex_module не показывал последний + *) Исправление: модуль ngx_http_autoindex_module не показывал последний слэш для линков на каталоги; ошибка появилась в 0.7.15. - *) Исправление: nginx не закрывал лог, заданный параметром конфигурации + *) Исправление: nginx не закрывал лог, заданный параметром конфигурации --error-log-path; ошибка появилась в 0.7.53. - *) Исправление: nginx не считал запятую разделителем в строке + *) Исправление: nginx не считал запятую разделителем в строке "Cache-Control" в заголовке ответа бэкенда. - *) Исправление: nginx/Windows мог не создать временный файл, файл в - кэше или файл с помощью директив proxy/fastcgi_store, если рабочий - процесс не имел достаточно прав для работы с каталогами верхнего - уровня. - - *) Исправление: строки "Set-Cookie" и "P3P" в заголовке ответа - FastCGI-сервера не скрывались при кэшировании, если не - использовались директивы fastcgi_hide_header с любыми параметрами. + *) Исправление: nginx/Windows мог не создать временный файл, файл в кэше + или файл с помощью директив proxy/fastcgi_store, если рабочий процесс + не имел достаточно прав для работы с каталогами верхнего уровня. + + *) Исправление: строки "Set-Cookie" и "P3P" в заголовке ответа + FastCGI-сервера не скрывались при кэшировании, если не использовались + директивы fastcgi_hide_header с любыми параметрами. *) Исправление: nginx неверно считал размер кэша на диске. @@ -865,10 +902,10 @@ *) Изменение: теперь протокол SSLv2 по умолчанию запрещён. - *) Изменение: теперь по умолчанию используются следующие шифры SSL: + *) Изменение: теперь по умолчанию используются следующие шифры SSL: "ALL:!ADH:RC4+RSA:+HIGH:+MEDIUM". - *) Исправление: директива limit_req не работала; ошибка появилась в + *) Исправление: директива limit_req не работала; ошибка появилась в 0.8.18. @@ -876,23 +913,23 @@ *) Добавление: директива read_ahead. - *) Добавление: теперь можно использовать несколько директив + *) Добавление: теперь можно использовать несколько директив perl_modules. *) Добавление: директивы limit_req_log_level и limit_conn_log_level. - *) Исправление: теперь директива limit_req соответствует алгоритму - leaky bucket. + *) Исправление: теперь директива limit_req соответствует алгоритму leaky + bucket. Спасибо Максиму Дунину. *) Исправление: nginx не работал на Linux/sparc. Спасибо Marcus Ramberg. - *) Исправление: nginx слал символ '\0' в строке "Location" в заголовке - в ответе на запрос MKCOL. + *) Исправление: nginx слал символ '\0' в строке "Location" в заголовке в + ответе на запрос MKCOL. Спасибо Xie Zhenye. - *) Исправление: вместо кода ответа 499 в лог записывался код 0; ошибка + *) Исправление: вместо кода ответа 499 в лог записывался код 0; ошибка появилась в 0.8.11. *) Исправление: утечки сокетов; ошибка появилась в 0.8.11. @@ -900,7 +937,7 @@ Изменения в nginx 0.8.17 28.09.2009 - *) Безопасность: теперь символы "/../" запрещены в строке "Destination" + *) Безопасность: теперь символы "/../" запрещены в строке "Destination" в заголовке запроса. *) Изменение: теперь значение переменной $host всегда в нижнем регистре. @@ -914,7 +951,7 @@ *) Добавление: директива image_filter_transparency. - *) Исправление: директива "addition_types" была неверно названа + *) Исправление: директива "addition_types" была неверно названа "addtion_types". *) Исправление: порчи кэша resolver'а. @@ -923,60 +960,60 @@ *) Исправление: утечки памяти в resolver'е. Спасибо Matthew Dempsky. - *) Исправление: неверная строка запроса в переменной $request - записывалась в access_log только при использовании error_log на + *) Исправление: неверная строка запроса в переменной $request + записывалась в access_log только при использовании error_log на уровне info или debug. - *) Исправление: в поддержке альфа-канала PNG в модуле + *) Исправление: в поддержке альфа-канала PNG в модуле ngx_http_image_filter_module. - *) Исправление: nginx всегда добавлял строку "Vary: Accept-Encoding" в - заголовок ответа, если обе директивы gzip_static и gzip_vary были + *) Исправление: nginx всегда добавлял строку "Vary: Accept-Encoding" в + заголовок ответа, если обе директивы gzip_static и gzip_vary были включены. - *) Исправление: в поддержке кодировки UTF-8 директивой try_files в + *) Исправление: в поддержке кодировки UTF-8 директивой try_files в nginx/Windows. - *) Исправление: ошибки при использовании post_action; ошибка появилась - в 0.8.11. + *) Исправление: ошибки при использовании post_action; ошибка появилась в + 0.8.11. Спасибо Игорю Артемьеву. Изменения в nginx 0.8.15 14.09.2009 - *) Безопасность: при обработке специально созданного запроса в рабочем + *) Безопасность: при обработке специально созданного запроса в рабочем процессе мог произойти segmentation fault. Спасибо Chris Ries. - *) Исправление: если были описаны имена .domain.tld, .sub.domain.tld и - .domain-some.tld, то имя .sub.domain.tld попадало под маску + *) Исправление: если были описаны имена .domain.tld, .sub.domain.tld и + .domain-some.tld, то имя .sub.domain.tld попадало под маску .domain.tld. - *) Исправление: в поддержке прозрачности в модуле + *) Исправление: в поддержке прозрачности в модуле ngx_http_image_filter_module. *) Исправление: в файловом AIO. - *) Исправление: ошибки при использовании X-Accel-Redirect; ошибка + *) Исправление: ошибки при использовании X-Accel-Redirect; ошибка появилась в 0.8.11. - *) Исправление: ошибки при использовании встроенного перла; ошибка + *) Исправление: ошибки при использовании встроенного перла; ошибка появилась в 0.8.11. Изменения в nginx 0.8.14 07.09.2009 - *) Исправление: устаревший закэшированный запрос мог залипнуть в + *) Исправление: устаревший закэшированный запрос мог залипнуть в состоянии "UPDATING". - *) Исправление: при использовании error_log на уровне info или debug в + *) Исправление: при использовании error_log на уровне info или debug в рабочем процессе мог произойти segmentation fault. Спасибо Сергею Боченкову. - *) Исправление: ошибки при использовании встроенного перла; ошибка + *) Исправление: ошибки при использовании встроенного перла; ошибка появилась в 0.8.11. - *) Исправление: директива error_page не перенаправляла ошибку 413; + *) Исправление: директива error_page не перенаправляла ошибку 413; ошибка появилась в 0.6.10. @@ -984,7 +1021,7 @@ *) Исправление: в директиве "aio sendfile"; ошибка появилась в 0.8.12. - *) Исправление: nginx не собирался без параметра --with-file-aio на + *) Исправление: nginx не собирался без параметра --with-file-aio на FreeBSD; ошибка появилась в 0.8.12. @@ -992,16 +1029,16 @@ *) Добавление: параметр sendfile в директиве aio во FreeBSD. - *) Исправление: ошибки при использовании try_files; ошибка появилась в + *) Исправление: ошибки при использовании try_files; ошибка появилась в 0.8.11. - *) Исправление: ошибки при использовании memcached; ошибка появилась в + *) Исправление: ошибки при использовании memcached; ошибка появилась в 0.8.11. Изменения в nginx 0.8.11 28.08.2009 - *) Изменение: теперь директива "gzip_disable msie6" не запрещает сжатие + *) Изменение: теперь директива "gzip_disable msie6" не запрещает сжатие для MSIE 6.0 SV1. *) Добавление: поддержка файлового AIO во FreeBSD и Linux. @@ -1013,27 +1050,27 @@ *) Исправление: утечек памяти при использовании базы GeoIP City. - *) Исправление: ошибки при копировании временных файлов в постоянное + *) Исправление: ошибки при копировании временных файлов в постоянное место хранения; ошибка появилась в 0.8.9. Изменения в nginx 0.8.9 17.08.2009 - *) Добавление: теперь стартовый загрузчик кэша работает в отдельном + *) Добавление: теперь стартовый загрузчик кэша работает в отдельном процесс; это должно улучшить обработку больших кэшей. - *) Добавление: теперь временные файлы и постоянное место хранения могут + *) Добавление: теперь временные файлы и постоянное место хранения могут располагаться на разных файловых системах. Изменения в nginx 0.8.8 10.08.2009 - *) Исправление: в обработке заголовков ответа, разделённых в + *) Исправление: в обработке заголовков ответа, разделённых в FastCGI-записях. - *) Исправление: если запрос обрабатывался в двух проксированных или - FastCGI location'ах и в первом из них использовалось кэширование, то - в рабочем процессе происходил segmentation fault; ошибка появилась в + *) Исправление: если запрос обрабатывался в двух проксированных или + FastCGI location'ах и в первом из них использовалось кэширование, то + в рабочем процессе происходил segmentation fault; ошибка появилась в 0.8.7. @@ -1041,8 +1078,8 @@ *) Изменение: минимальная поддерживаемая версия OpenSSL - 0.9.7. - *) Изменение: параметр ask директивы ssl_verify_client изменён на - параметр optional и теперь он проверяет клиентский сертификат, если + *) Изменение: параметр ask директивы ssl_verify_client изменён на + параметр optional и теперь он проверяет клиентский сертификат, если он был предложен. Спасибо Brice Figureau. @@ -1054,24 +1091,23 @@ *) Добавление: параметр proxy директивы geo. - *) Добавление: директива image_filter поддерживает переменные для + *) Добавление: директива image_filter поддерживает переменные для задания размеров. - *) Исправление: использование переменной $ssl_client_cert портило + *) Исправление: использование переменной $ssl_client_cert портило память; ошибка появилась в 0.7.7. Спасибо Сергею Журавлёву. - *) Исправление: директивы proxy_pass_header и fastcgi_pass_header" не - передавали клиенту строки "X-Accel-Redirect", "X-Accel-Limit-Rate", - "X-Accel-Buffering" и "X-Accel-Charset" из заголовка ответа - бэкенда. + *) Исправление: директивы proxy_pass_header и fastcgi_pass_header" не + передавали клиенту строки "X-Accel-Redirect", "X-Accel-Limit-Rate", + "X-Accel-Buffering" и "X-Accel-Charset" из заголовка ответа бэкенда. Спасибо Максиму Дунину. - *) Исправление: в обработке строк "Last-Modified" и "Accept-Ranges" в + *) Исправление: в обработке строк "Last-Modified" и "Accept-Ranges" в заголовке ответа бэкенда; ошибка появилась в 0.7.44. Спасибо Максиму Дунину. - *) Исправление: ошибки "[alert] zero size buf" при получении пустых + *) Исправление: ошибки "[alert] zero size buf" при получении пустых ответы в подзапросах; ошибка появилась в 0.8.5. @@ -1079,18 +1115,18 @@ *) Добавление: модуль ngx_http_geoip_module. - *) Исправление: XSLT-фильтр мог выдавать ошибку "not well formed XML + *) Исправление: XSLT-фильтр мог выдавать ошибку "not well formed XML document" для правильного документа. Спасибо Kuramoto Eiji. - *) Исправление: в MacOSX, Cygwin и nginx/Windows при проверке - location'ов, заданных регулярным выражением, теперь всегда делается + *) Исправление: в MacOSX, Cygwin и nginx/Windows при проверке + location'ов, заданных регулярным выражением, теперь всегда делается сравнение без учёта регистра символов. *) Исправление: теперь nginx/Windows игнорирует точки в конце URI. Спасибо Hugo Leisink. - *) Исправление: имя файла указанного в --conf-path игнорировалось при + *) Исправление: имя файла указанного в --conf-path игнорировалось при установке; ошибка появилась в 0.6.6. Спасибо Максиму Дунину. @@ -1099,10 +1135,10 @@ *) Исправление: теперь nginx разрешает подчёркивания в методе запроса. - *) Исправление: при использовании HTTP Basic-аутентификации на Windows + *) Исправление: при использовании HTTP Basic-аутентификации на Windows для неверных имени/пароля возвращалась 500-ая ошибка. - *) Исправление: ответы модуля ngx_http_perl_module не работали в + *) Исправление: ответы модуля ngx_http_perl_module не работали в подзапросах. *) Исправление: в модуле ngx_http_limit_req_module. @@ -1111,7 +1147,7 @@ Изменения в nginx 0.8.4 22.06.2009 - *) Исправление: nginx не собирался с параметром --without-http-cache; + *) Исправление: nginx не собирался с параметром --without-http-cache; ошибка появилась в 0.8.3. @@ -1121,42 +1157,42 @@ *) Исправление: nginx не собирался на MacOSX 10.6. - *) Исправление: nginx не собирался с параметром --without-http-cache; + *) Исправление: nginx не собирался с параметром --without-http-cache; ошибка появилась в 0.8.2. - *) Исправление: если использовался перехват 401 ошибки от бэкенда и - бэкенд не возвращал строку "WWW-Authenticate" в заголовке ответа, то + *) Исправление: если использовался перехват 401 ошибки от бэкенда и + бэкенд не возвращал строку "WWW-Authenticate" в заголовке ответа, то в рабочем процессе происходил segmentation fault. Спасибо Евгению Мычло. Изменения в nginx 0.8.2 15.06.2009 - *) Исправление: во взаимодействии open_file_cache и proxy/fastcgi кэша + *) Исправление: во взаимодействии open_file_cache и proxy/fastcgi кэша на старте. - *) Исправление: open_file_cache мог кэшировать открытые файлы очень + *) Исправление: open_file_cache мог кэшировать открытые файлы очень долго; ошибка появилась в 0.7.4. Изменения в nginx 0.8.1 08.06.2009 - *) Добавление: параметр updating в директивах proxy_cache_use_stale и + *) Добавление: параметр updating в директивах proxy_cache_use_stale и fastcgi_cache_use_stale. - *) Исправление: строки "If-Modified-Since", "If-Range" и им подобные в - заголовке запроса клиента передавались бэкенду при кэшировании, если + *) Исправление: строки "If-Modified-Since", "If-Range" и им подобные в + заголовке запроса клиента передавались бэкенду при кэшировании, если не использовалась директива proxy_set_header с любыми параметрами. - *) Исправление: строки "Set-Cookie" и "P3P" в заголовке ответа бэкенда - не скрывались при кэшировании, если не использовались директивы + *) Исправление: строки "Set-Cookie" и "P3P" в заголовке ответа бэкенда + не скрывались при кэшировании, если не использовались директивы proxy_hide_header/fastcgi_hide_header с любыми параметрами. - *) Исправление: модуль ngx_http_image_filter_module не понимал формат + *) Исправление: модуль ngx_http_image_filter_module не понимал формат GIF87a. Спасибо Денису Ильиных. - *) Исправление: nginx не собирался на Solaris 10 и более ранних; ошибка + *) Исправление: nginx не собирался на Solaris 10 и более ранних; ошибка появилась в 0.7.56. @@ -1171,7 +1207,7 @@ *) Исправление: обработке относительных путей в nginx/Windows. - *) Исправление: в proxy_store, fastcgi_store, proxy_cache и + *) Исправление: в proxy_store, fastcgi_store, proxy_cache и fastcgi_cache в nginx/Windows. *) Исправление: в обработке ошибок выделения памяти. @@ -1185,23 +1221,23 @@ *) Исправление: утечки сокетов; ошибка появилась в 0.7.25. Спасибо Максиму Дунину. - *) Исправление: при использовании переменной $request_body в рабочем - процессе происходил segmentation fault, если в запросе не было тела; + *) Исправление: при использовании переменной $request_body в рабочем + процессе происходил segmentation fault, если в запросе не было тела; ошибка появилась в 0.7.58. - *) Исправление: SSL-модули могли не собираться на Solaris и Linux; + *) Исправление: SSL-модули могли не собираться на Solaris и Linux; ошибка появилась в 0.7.56. - *) Исправление: ответы модуля ngx_http_xslt_filter_module не + *) Исправление: ответы модуля ngx_http_xslt_filter_module не обрабатывались SSI-, charset- и gzip-фильтрами. - *) Исправление: директива charset не ставила кодировку для ответов + *) Исправление: директива charset не ставила кодировку для ответов модуля ngx_http_gzip_static_module. Изменения в nginx 0.7.58 18.05.2009 - *) Добавление: директива listen почтового прокси-сервера поддерживает + *) Добавление: директива listen почтового прокси-сервера поддерживает IPv6. *) Добавление: директива image_filter_jpeg_quality. @@ -1210,46 +1246,46 @@ *) Добавление: переменная $request_body. - *) Исправление: в модуле ngx_http_autoindex_module в ссылках на имена + *) Исправление: в модуле ngx_http_autoindex_module в ссылках на имена файлов, содержащих символ ":". - *) Исправление: процедура "make upgrade" не работала; ошибка появилась - в 0.7.53. + *) Исправление: процедура "make upgrade" не работала; ошибка появилась в + 0.7.53. Спасибо Денису Латыпову. Изменения в nginx 0.7.57 12.05.2009 - *) Исправление: при перенаправлении ошибок модуля - ngx_http_image_filter_module в именованный location в рабочем + *) Исправление: при перенаправлении ошибок модуля + ngx_http_image_filter_module в именованный location в рабочем процессе происходил floating-point fault; ошибка появилась в 0.7.56. Изменения в nginx 0.7.56 11.05.2009 - *) Добавление: nginx/Windows поддерживает IPv6 в директиве listen - модуля HTTP. + *) Добавление: nginx/Windows поддерживает IPv6 в директиве listen модуля + HTTP. *) Исправление: в модуле ngx_http_image_filter_module. Изменения в nginx 0.7.55 06.05.2009 - *) Исправление: параметры http_XXX в директивах proxy_cache_use_stale и + *) Исправление: параметры http_XXX в директивах proxy_cache_use_stale и fastcgi_cache_use_stale не работали. - *) Исправление: fastcgi кэш не кэшировал ответы, состоящие только из + *) Исправление: fastcgi кэш не кэшировал ответы, состоящие только из заголовка. - *) Исправление: ошибки "select() failed (9: Bad file descriptor)" в + *) Исправление: ошибки "select() failed (9: Bad file descriptor)" в nginx/Unix и "select() failed (10038: ...)" в nginx/Windows. - *) Исправление: при использовании директивы debug_connection в рабочем + *) Исправление: при использовании директивы debug_connection в рабочем процессе мог произойти segmentation fault; ошибка появилась в 0.7.54. *) Исправление: в сборке модуля ngx_http_image_filter_module. - *) Исправление: файлы больше 2G не передавались с использованием + *) Исправление: файлы больше 2G не передавались с использованием $r->sendfile. Спасибо Максиму Дунину. @@ -1260,31 +1296,31 @@ *) Добавление: директивы proxy_ignore_headers и fastcgi_ignore_headers. - *) Исправление: при использовании переменных "open_file_cache_errors - on" в рабочем процессе мог произойти segmentation fault; ошибка - появилась в 0.7.53. - - *) Исправление: директива "port_in_redirect off" не работала; ошибка + *) Исправление: при использовании переменных "open_file_cache_errors on" + в рабочем процессе мог произойти segmentation fault; ошибка появилась + в 0.7.53. + + *) Исправление: директива "port_in_redirect off" не работала; ошибка появилась в 0.7.39. *) Исправление: улучшение обработки ошибок метода select. *) Исправление: ошибки "select() failed (10022: ...)" в nginx/Windows. - *) Исправление: в текстовых сообщениях об ошибках в nginx/Windows; + *) Исправление: в текстовых сообщениях об ошибках в nginx/Windows; ошибка появилась в 0.7.53. Изменения в nginx 0.7.53 27.04.2009 - *) Изменение: теперь лог, указанный в --error-log-path, создаётся с + *) Изменение: теперь лог, указанный в --error-log-path, создаётся с самого начала работы. - *) Добавление: теперь ошибки и предупреждения при старте записываются в + *) Добавление: теперь ошибки и предупреждения при старте записываются в error_log и выводятся на stderr. - *) Добавление: при сборке с пустым параметром --prefix= nginx - использует как префикс каталог, в котором он был запущен. + *) Добавление: при сборке с пустым параметром --prefix= nginx использует + как префикс каталог, в котором он был запущен. *) Добавление: ключ -p. @@ -1295,20 +1331,20 @@ *) Добавление: теперь ключи можно задавать в сжатой форме. - *) Исправление: nginx/Windows не работал, если файл конфигурации был + *) Исправление: nginx/Windows не работал, если файл конфигурации был задан ключом -c. - *) Исправление: при использовании директив proxy_store, fastcgi_store, + *) Исправление: при использовании директив proxy_store, fastcgi_store, proxy_cache или fastcgi_cache временные файлы могли не удаляться. Спасибо Максиму Дунину. - *) Исправление: в заголовке Auth-Method запроса серверу аутентификации - почтового прокси-сервера передавалось неверное значение; ошибка + *) Исправление: в заголовке Auth-Method запроса серверу аутентификации + почтового прокси-сервера передавалось неверное значение; ошибка появилась в 0.7.34. Спасибо Simon Lecaille. - *) Исправление: при логгировании на Linux не писались текстовые - описания системных ошибок; ошибка появилась в 0.7.45. + *) Исправление: при логгировании на Linux не писались текстовые описания + системных ошибок; ошибка появилась в 0.7.45. *) Исправление: директива fastcgi_cache_min_uses не работала. Спасибо Андрею Воробьёву. @@ -1320,57 +1356,57 @@ *) Исправление: корректная обработка метода HEAD при кэшировании. - *) Исправление: корректная обработка строк "If-Modified-Since", + *) Исправление: корректная обработка строк "If-Modified-Since", "If-Range" и им подобных в заголовке запроса клиента при кэшировании. - *) Исправление: теперь строки "Set-Cookie" и "P3P" скрываются в + *) Исправление: теперь строки "Set-Cookie" и "P3P" скрываются в заголовке ответа для закэшированных ответов. - *) Исправление: если nginx был собран с модулем ngx_http_perl_module и - perl поддерживал потоки, то при выходе основного процесса могла + *) Исправление: если nginx был собран с модулем ngx_http_perl_module и + perl поддерживал потоки, то при выходе основного процесса могла выдаваться ошибка "panic: MUTEX_LOCK". - *) Исправление: nginx не собирался с параметром --without-http-cache; + *) Исправление: nginx не собирался с параметром --without-http-cache; ошибка появилась в 0.7.48. - *) Исправление: nginx не собирался на платформах, отличных от i386, + *) Исправление: nginx не собирался на платформах, отличных от i386, amd64, sparc и ppc; ошибка появилась в 0.7.42. Изменения в nginx 0.7.51 12.04.2009 - *) Добавление: директива try_files поддерживает код ответа в последнем + *) Добавление: директива try_files поддерживает код ответа в последнем параметре. - *) Добавление: теперь в директиве return можно использовать любой код + *) Добавление: теперь в директиве return можно использовать любой код ответа. - *) Исправление: директива error_page делала внешний редирект без строки + *) Исправление: директива error_page делала внешний редирект без строки запроса; ошибка появилась в 0.7.44. - *) Исправление: если сервера слушали на нескольких явно описанных - адресах, то виртуальные сервера могли не работать; ошибка появилась - в 0.7.39. + *) Исправление: если сервера слушали на нескольких явно описанных + адресах, то виртуальные сервера могли не работать; ошибка появилась в + 0.7.39. Изменения в nginx 0.7.50 06.04.2009 - *) Исправление: переменные $arg_... не работали; ошибка появилась в + *) Исправление: переменные $arg_... не работали; ошибка появилась в 0.7.49. Изменения в nginx 0.7.49 06.04.2009 - *) Исправление: при использовании переменных $arg_... в рабочем - процессе мог произойти segmentation fault; ошибка появилась в 0.7.48. + *) Исправление: при использовании переменных $arg_... в рабочем процессе + мог произойти segmentation fault; ошибка появилась в 0.7.48. Изменения в nginx 0.7.48 06.04.2009 *) Добавление: директива proxy_cache_key. - *) Исправление: теперь nginx учитывает при кэшировании строки - "X-Accel-Expires", "Expires" и "Cache-Control" в заголовке ответа + *) Исправление: теперь nginx учитывает при кэшировании строки + "X-Accel-Expires", "Expires" и "Cache-Control" в заголовке ответа бэкенда. *) Исправление: теперь nginx кэширует только ответы на запросы GET. @@ -1383,28 +1419,28 @@ *) Исправление: nginx не собирался с библиотекой uclibc. Спасибо Timothy Redaelli. - *) Исправление: nginx не собирался на OpenBSD; ошибка появилась + *) Исправление: nginx не собирался на OpenBSD; ошибка появилась в 0.7.46. Изменения в nginx 0.7.47 01.04.2009 - *) Исправление: nginx не собирался на FreeBSD 6 и более ранних версиях; + *) Исправление: nginx не собирался на FreeBSD 6 и более ранних версиях; ошибка появилась в 0.7.46. *) Исправление: nginx не собирался на MacOSX; ошибка появилась в 0.7.46. - *) Исправление: если использовался параметр max_size, то cache manager + *) Исправление: если использовался параметр max_size, то cache manager мог удалить весь кэш; ошибка появилась в 0.7.46. - *) Изменение: в рабочем процессе мог произойти segmentation fault, если - директивы proxy_cache/fastcgi_cache и proxy_cache_valid/ - fastcgi_cache_valid не были заданы на одном уровне; ошибка появилась + *) Изменение: в рабочем процессе мог произойти segmentation fault, если + директивы proxy_cache/fastcgi_cache и proxy_cache_valid/ + fastcgi_cache_valid не были заданы на одном уровне; ошибка появилась в 0.7.46. - *) Исправление: в рабочем процессе мог произойти segmentation fault при - перенаправлении запроса проксированному или FastCGI-серверу с - помощью error_page или try_files; ошибка появилась в 0.7.44. + *) Исправление: в рабочем процессе мог произойти segmentation fault при + перенаправлении запроса проксированному или FastCGI-серверу с помощью + error_page или try_files; ошибка появилась в 0.7.44. Изменения в nginx 0.7.46 30.03.2009 @@ -1414,118 +1450,118 @@ Изменения в nginx 0.7.45 30.03.2009 - *) Изменение: теперь директивы proxy_cache и proxy_cache_valid можно + *) Изменение: теперь директивы proxy_cache и proxy_cache_valid можно задавать на разных уровнях. *) Изменение: параметр clean_time в директиве proxy_cache_path удалён. *) Добавление: параметр max_size в директиве proxy_cache_path. - *) Добавление: предварительная поддержка кэширования в модуле + *) Добавление: предварительная поддержка кэширования в модуле ngx_http_fastcgi_module. - *) Добавление: теперь при ошибках выделения в разделяемой памяти в логе + *) Добавление: теперь при ошибках выделения в разделяемой памяти в логе указываются названия директивы и зоны. - *) Исправление: директива "add_header last-modified ''" не удаляла в + *) Исправление: директива "add_header last-modified ''" не удаляла в заголовке ответа строку "Last-Modified"; ошибка появилась в 0.7.44. - *) Исправление: в директиве auth_basic_user_file не работал - относительный путь, заданный строкой без переменных; ошибка - появилась в 0.7.44. + *) Исправление: в директиве auth_basic_user_file не работал + относительный путь, заданный строкой без переменных; ошибка появилась + в 0.7.44. Спасибо Jerome Loyet. - *) Исправление: в директиве alias, заданной переменными без ссылок на + *) Исправление: в директиве alias, заданной переменными без ссылок на выделения в регулярных выражениях; ошибка появилась в 0.7.42. Изменения в nginx 0.7.44 23.03.2009 - *) Добавление: предварительная поддержка кэширования в модуле + *) Добавление: предварительная поддержка кэширования в модуле ngx_http_proxy_module. *) Добавление: параметр --with-pcre в configure. - *) Добавление: теперь директива try_files может быть использована на + *) Добавление: теперь директива try_files может быть использована на уровне server. - *) Исправление: директива try_files неправильно обрабатывала строку + *) Исправление: директива try_files неправильно обрабатывала строку запроса в последнем параметре. *) Исправление: директива try_files могла неверно тестировать каталоги. - *) Исправление: если для пары адрес:порт описан только один сервер, то - выделения в регулярных выражениях в директиве server_name не + *) Исправление: если для пары адрес:порт описан только один сервер, то + выделения в регулярных выражениях в директиве server_name не работали. Изменения в nginx 0.7.43 18.03.2009 - *) Исправление: запрос обрабатывался неверно, если директива root + *) Исправление: запрос обрабатывался неверно, если директива root использовала переменные; ошибка появилась в 0.7.42. - *) Исправление: если сервер слушал на адресах типа "*", то значение + *) Исправление: если сервер слушал на адресах типа "*", то значение переменной $server_addr было "0.0.0.0"; ошибка появилась в 0.7.36. Изменения в nginx 0.7.42 16.03.2009 - *) Изменение: ошибка "Invalid argument", возвращаемая + *) Изменение: ошибка "Invalid argument", возвращаемая setsockopt(TCP_NODELAY) на Solaris, теперь игнорируется. - *) Изменение: при отсутствии файла, указанного в директиве + *) Изменение: при отсутствии файла, указанного в директиве auth_basic_user_file, теперь возвращается ошибка 403 вместо 500. - *) Добавление: директива auth_basic_user_file поддерживает переменные. + *) Добавление: директива auth_basic_user_file поддерживает переменные. Спасибо Кириллу Коринскому. *) Добавление: директива listen поддерживает параметр ipv6only. Спасибо Zhang Hua. - *) Исправление: в директиве alias со ссылками на выделения в регулярных + *) Исправление: в директиве alias со ссылками на выделения в регулярных выражениях; ошибка появилась в 0.7.40. *) Исправление: совместимость с Tru64 UNIX. Спасибо Dustin Marquess. - *) Исправление: nginx не собирался без библиотеки PCRE; ошибка - появилась в 0.7.41. + *) Исправление: nginx не собирался без библиотеки PCRE; ошибка появилась + в 0.7.41. Изменения в nginx 0.7.41 11.03.2009 - *) Исправление: в рабочем процессе мог произойти segmentation fault, - если в server_name или location были выделения в регулярных + *) Исправление: в рабочем процессе мог произойти segmentation fault, + если в server_name или location были выделения в регулярных выражениях; ошибка появилась в 0.7.40. Спасибо Владимиру Сопоту. Изменения в nginx 0.7.40 09.03.2009 - *) Добавление: директива location поддерживает выделения в регулярных + *) Добавление: директива location поддерживает выделения в регулярных выражениях. - *) Добавление: директиву alias с ссылками на выделения в регулярных - выражениях можно использовать внутри location'а, заданного - регулярным выражением с выделениями. - - *) Добавление: директива server_name поддерживает выделения в - регулярных выражениях. - - *) Изменение: модуль ngx_http_autoindex_module не показывал последний - слэш для каталогов на файловой системе XFS; ошибка появилась в + *) Добавление: директиву alias с ссылками на выделения в регулярных + выражениях можно использовать внутри location'а, заданного регулярным + выражением с выделениями. + + *) Добавление: директива server_name поддерживает выделения в регулярных + выражениях. + + *) Изменение: модуль ngx_http_autoindex_module не показывал последний + слэш для каталогов на файловой системе XFS; ошибка появилась в 0.7.15. Спасибо Дмитрию Кузьменко. Изменения в nginx 0.7.39 02.03.2009 - *) Исправление: при включённом сжатии большие ответы с использованием + *) Исправление: при включённом сжатии большие ответы с использованием SSI могли зависать; ошибка появилась в 0.7.28. Спасибо Артёму Бохану. - *) Исправление: при использовании коротких статических вариантов в - директиве try_files в рабочем процессе мог произойти segmentation + *) Исправление: при использовании коротких статических вариантов в + директиве try_files в рабочем процессе мог произойти segmentation fault. @@ -1533,42 +1569,42 @@ *) Добавление: логгирование ошибок аутентификации. - *) Исправление: имя/пароль, заданные в auth_basic_user_file, + *) Исправление: имя/пароль, заданные в auth_basic_user_file, игнорировались после нечётного числа пустых строк. Спасибо Александру Загребину. - *) Исправление: при использовании длинного пути в unix domain сокете в - главном процессе происходил segmentation fault; ошибка появилась в + *) Исправление: при использовании длинного пути в unix domain сокете в + главном процессе происходил segmentation fault; ошибка появилась в 0.7.36. Изменения в nginx 0.7.37 21.02.2009 - *) Исправление: директивы, использующие upstream'ы, не работали; ошибка + *) Исправление: директивы, использующие upstream'ы, не работали; ошибка появилась в 0.7.36. Изменения в nginx 0.7.36 21.02.2009 - *) Добавление: предварительная поддержка IPv6; директива listen модуля + *) Добавление: предварительная поддержка IPv6; директива listen модуля HTTP поддерживает IPv6. - *) Исправление: переменная $ancient_browser не работала для браузеров, + *) Исправление: переменная $ancient_browser не работала для браузеров, заданных директивами modern_browser. Изменения в nginx 0.7.35 16.02.2009 - *) Исправление: директива ssl_engine не использовала SSL-акселератор - для асимметричных шифров. + *) Исправление: директива ssl_engine не использовала SSL-акселератор для + асимметричных шифров. Спасибо Marcin Gozdalik. - *) Исправление: директива try_files выставляла MIME-type, исходя из + *) Исправление: директива try_files выставляла MIME-type, исходя из расширения первоначального запроса. - *) Исправление: в директивах server_name, valid_referers и map - неправильно обрабатывались имена вида "*domain.tld", если - использовались маски вида ".domain.tld" и ".subdomain.domain.tld"; + *) Исправление: в директивах server_name, valid_referers и map + неправильно обрабатывались имена вида "*domain.tld", если + использовались маски вида ".domain.tld" и ".subdomain.domain.tld"; ошибка появилась в 0.7.9. @@ -1576,15 +1612,15 @@ *) Добавление: параметр off в директиве if_modified_since. - *) Добавление: теперь после команды XCLIENT nginx посылает команду + *) Добавление: теперь после команды XCLIENT nginx посылает команду HELO/EHLO. Спасибо Максиму Дунину. - *) Добавление: поддержка Microsoft-специфичного режима + *) Добавление: поддержка Microsoft-специфичного режима "AUTH LOGIN with User Name" в почтовом прокси-сервере. Спасибо Максиму Дунину. - *) Исправление: в директиве rewrite, возвращающей редирект, старые + *) Исправление: в директиве rewrite, возвращающей редирект, старые аргументы присоединялись к новым через символ "?" вместо "&"; ошибка появилась в 0.1.18. Спасибо Максиму Дунину. @@ -1594,34 +1630,34 @@ Изменения в nginx 0.7.33 02.02.2009 - *) Исправление: если на запрос с телом возвращался редирект, то ответ + *) Исправление: если на запрос с телом возвращался редирект, то ответ мог быть двойным при использовании методов epoll или rtsig. Спасибо Eden Li. - *) Исправление: для некоторых типов редиректов в переменной + *) Исправление: для некоторых типов редиректов в переменной $sent_http_location было пустое значение. - *) Исправление: при использовании директивы resolver в SMTP + *) Исправление: при использовании директивы resolver в SMTP прокси-сервере в рабочем процессе мог произойти segmentation fault. Изменения в nginx 0.7.32 26.01.2009 - *) Добавление: теперь в директиве try_files можно явно указать проверку + *) Добавление: теперь в директиве try_files можно явно указать проверку каталога. *) Исправление: fastcgi_store не всегда сохранял файлы. *) Исправление: в гео-диапазонах. - *) Исправление: ошибки выделения больших блоков в разделяемой памяти, + *) Исправление: ошибки выделения больших блоков в разделяемой памяти, если nginx был собран без отладки. Спасибо Андрею Квасову. Изменения в nginx 0.7.31 19.01.2009 - *) Изменение: теперь директива try_files проверяет только файлы, + *) Изменение: теперь директива try_files проверяет только файлы, игнорируя каталоги. *) Добавление: директива fastcgi_split_path_info. @@ -1630,35 +1666,35 @@ *) Исправления в гео-диапазонах. - *) Исправление: при отсутствии ответа ngx_http_memcached_module - возвращал в теле ответа строку "END" вместо 404-ой страницы по + *) Исправление: при отсутствии ответа ngx_http_memcached_module + возвращал в теле ответа строку "END" вместо 404-ой страницы по умолчанию; ошибка появилась в 0.7.18. Спасибо Максиму Дунину. - *) Исправление: при проксировании SMPT nginx выдавал сообщение + *) Исправление: при проксировании SMPT nginx выдавал сообщение "250 2.0.0 OK" вместо "235 2.0.0 OK"; ошибка появилась в 0.7.22. Спасибо Максиму Дунину. Изменения в nginx 0.7.30 24.12.2008 - *) Исправление: в рабочем процессе происходил segmentation fault, если - в директивах fastcgi_pass или proxy_pass использовались переменные и + *) Исправление: в рабочем процессе происходил segmentation fault, если в + директивах fastcgi_pass или proxy_pass использовались переменные и имя хоста должно было резолвиться; ошибка появилась в 0.7.29. Изменения в nginx 0.7.29 24.12.2008 - *) Исправление: директивы fastcgi_pass и proxy_pass не поддерживали + *) Исправление: директивы fastcgi_pass и proxy_pass не поддерживали переменные при использовании unix domain сокетов. *) Исправления в обработке подзапросов; ошибки появились в 0.7.25. - *) Исправление: ответ "100 Continue" выдавался для запросов версии + *) Исправление: ответ "100 Continue" выдавался для запросов версии HTTP/1.0; Спасибо Максиму Дунину. - *) Исправление: в выделении памяти в модуле ngx_http_gzip_filter_module + *) Исправление: в выделении памяти в модуле ngx_http_gzip_filter_module под Cygwin. @@ -1666,7 +1702,7 @@ *) Изменение: в выделении памяти в модуле ngx_http_gzip_filter_module. - *) Изменение: значения по умолчанию для директивы gzip_buffers изменены + *) Изменение: значения по умолчанию для директивы gzip_buffers изменены с 4 4k/8k на 32 4k или 16 8k. @@ -1679,22 +1715,22 @@ *) Добавление: теперь директива geo может брать адрес из переменной. Спасибо Андрею Нигматулину. - *) Добавление: теперь модификатор location'а можно указывать без - пробела перед названием. + *) Добавление: теперь модификатор location'а можно указывать без пробела + перед названием. *) Добавление: переменная $upstream_response_length. - *) Исправление: теперь директива add_header не добавляет пустое + *) Исправление: теперь директива add_header не добавляет пустое значение. - *) Исправление: при запросе файла нулевой длины nginx закрывал + *) Исправление: при запросе файла нулевой длины nginx закрывал соединение, ничего не передав; ошибка появилась в 0.7.25. - *) Исправление: метод MOVE не мог перемещать файл в несуществующий + *) Исправление: метод MOVE не мог перемещать файл в несуществующий каталог. - *) Исправление: если в сервере не был описан ни один именованный - location, но такой location использовался в директиве error_page, то + *) Исправление: если в сервере не был описан ни один именованный + location, но такой location использовался в директиве error_page, то в рабочем процессе происходил segmentation fault. Спасибо Сергею Боченкову. @@ -1708,10 +1744,10 @@ *) Изменение: в обработке подзапросов. - *) Изменение: теперь разрешаются POST'ы без строки "Content-Length" в + *) Изменение: теперь разрешаются POST'ы без строки "Content-Length" в заголовке запроса. - *) Исправление: теперь директивы limit_req и limit_conn указывают + *) Исправление: теперь директивы limit_req и limit_conn указывают причину запрета запроса. *) Исправление: в параметре delete директивы geo. @@ -1721,10 +1757,10 @@ *) Добавление: директива if_modified_since. - *) Исправление: nginx не обрабатывал ответ FastCGI-сервера, если перед + *) Исправление: nginx не обрабатывал ответ FastCGI-сервера, если перед ответом сервер передавал много сообщений в stderr. - *) Исправление: переменные "$cookie_..." не работали в SSI and в + *) Исправление: переменные "$cookie_..." не работали в SSI and в перловом модуле. @@ -1760,7 +1796,7 @@ *) Изменение: совместимость с glibc 2.3. Спасибо Eric Benson и Максиму Дунину. - *) Исправление: nginx не запускался на MacOSX 10.4 и более ранних; + *) Исправление: nginx не запускался на MacOSX 10.4 и более ранних; ошибка появилась в 0.7.6. @@ -1770,17 +1806,17 @@ *) Добавление: модуль ngx_http_limit_req_module. - *) Исправление: на платформах sparc и ppc рабочие процессы могли + *) Исправление: на платформах sparc и ppc рабочие процессы могли выходить по сигналу SIGBUS; ошибка появилась в 0.7.3. Спасибо Максиму Дунину. - *) Исправление: директивы вида "proxy_pass http://host/some:uri" не + *) Исправление: директивы вида "proxy_pass http://host/some:uri" не работали; ошибка появилась в 0.7.12. - *) Исправление: при использовании HTTPS запросы могли завершаться с + *) Исправление: при использовании HTTPS запросы могли завершаться с ошибкой "bad write retry". - *) Исправление: модуль ngx_http_secure_link_module не работал внутри + *) Исправление: модуль ngx_http_secure_link_module не работал внутри location'ов с именами меньше 3 символов. *) Исправление: переменная $server_addr могла не иметь значения. @@ -1793,8 +1829,8 @@ Изменения в nginx 0.7.18 13.10.2008 - *) Изменение: директива underscores_in_headers; теперь nginx по - умолчанию не разрешает подчёркивания в именах строк в заголовке + *) Изменение: директива underscores_in_headers; теперь nginx по + умолчанию не разрешает подчёркивания в именах строк в заголовке запроса клиента. *) Добавление: модуль ngx_http_secure_link_module. @@ -1805,13 +1841,13 @@ *) Добавление: переменная $realpath_root. - *) Добавление: параметры http_502 и http_504 в директиве + *) Добавление: параметры http_502 и http_504 в директиве proxy_next_upstream. - *) Исправление: параметр http_503 в директивах proxy_next_upstream или + *) Исправление: параметр http_503 в директивах proxy_next_upstream или fastcgi_next_upstream не работал. - *) Исправление: nginx мог выдавать строку "Transfer-Encoding: chunked" + *) Исправление: nginx мог выдавать строку "Transfer-Encoding: chunked" для запросов HEAD. *) Исправление: теперь accept-лимит зависит от числа worker_connections. @@ -1823,19 +1859,19 @@ *) Добавление: переменная $pid. - *) Исправление: оптимизация directio, появившаяся в 0.7.15, не работала + *) Исправление: оптимизация directio, появившаяся в 0.7.15, не работала при использовании open_file_cache. - *) Исправление: access_log с переменными не работал на Linux; ошибка + *) Исправление: access_log с переменными не работал на Linux; ошибка появилась в 0.7.7. - *) Исправление: модуль ngx_http_charset_module не понимал название + *) Исправление: модуль ngx_http_charset_module не понимал название кодировки в кавычках, полученное от бэкенда. Изменения в nginx 0.7.16 08.09.2008 - *) Исправление: nginx не собирался на 64-битных платформах; ошибка + *) Исправление: nginx не собирался на 64-битных платформах; ошибка появилась в 0.7.15. @@ -1843,41 +1879,41 @@ *) Добавление: модуль ngx_http_random_index_module. - *) Добавление: директива directio оптимизирована для запросов файлов, + *) Добавление: директива directio оптимизирована для запросов файлов, начинающихся с произвольной позиции. - *) Добавление: директива directio при необходимости запрещает + *) Добавление: директива directio при необходимости запрещает использование sendfile. - *) Добавление: теперь nginx разрешает подчёркивания в именах строк в + *) Добавление: теперь nginx разрешает подчёркивания в именах строк в заголовке запроса клиента. Изменения в nginx 0.7.14 01.09.2008 - *) Изменение: теперь директивы ssl_certificate и ssl_certificate_key не + *) Изменение: теперь директивы ssl_certificate и ssl_certificate_key не имеют значений по умолчанию. *) Добавление: директива listen поддерживает параметр ssl. - *) Добавление: теперь при переконфигурации nginx учитывает изменение + *) Добавление: теперь при переконфигурации nginx учитывает изменение временной зоны на FreeBSD и Linux. - *) Исправление: параметры директивы listen, такие как backlog, rcvbuf и - прочие, не устанавливались, если сервером по умолчанию был не первый + *) Исправление: параметры директивы listen, такие как backlog, rcvbuf и + прочие, не устанавливались, если сервером по умолчанию был не первый сервер. - *) Исправление: при использовании в качестве аргументов части URI, - выделенного с помощью директивы rewrite, эти аргументы не + *) Исправление: при использовании в качестве аргументов части URI, + выделенного с помощью директивы rewrite, эти аргументы не экранировались. - *) Исправление: улучшения тестирования правильности конфигурационного + *) Исправление: улучшения тестирования правильности конфигурационного файла. Изменения в nginx 0.7.13 26.08.2008 - *) Исправление: nginx не собирался на Linux и Solaris; ошибка появилась + *) Исправление: nginx не собирался на Linux и Solaris; ошибка появилась в 0.7.12. @@ -1885,87 +1921,86 @@ *) Добавление: директива server_name поддерживает пустое имя "". - *) Добавление: директива gzip_disable поддерживает специальную маску + *) Добавление: директива gzip_disable поддерживает специальную маску msie6. - *) Исправление: при использовании параметра max_fails=0 в upstream'е с + *) Исправление: при использовании параметра max_fails=0 в upstream'е с несколькими серверами рабочий процесс выходил по сигналу SIGFPE. Спасибо Максиму Дунину. - *) Исправление: при перенаправлении запроса с помощью директивы + *) Исправление: при перенаправлении запроса с помощью директивы error_page терялось тело запроса. - *) Исправление: при перенаправлении запроса с методом HEAD с помощью + *) Исправление: при перенаправлении запроса с методом HEAD с помощью директивы error_page возвращался полный ответ. - *) Исправление: метод $r->header_in() не возвращал значения строк - "Host", "User-Agent", и "Connection" из заголовка запроса; ошибка + *) Исправление: метод $r->header_in() не возвращал значения строк + "Host", "User-Agent", и "Connection" из заголовка запроса; ошибка появилась в 0.7.0. Изменения в nginx 0.7.11 18.08.2008 - *) Изменение: теперь ngx_http_charset_module по умолчанию не работает + *) Изменение: теперь ngx_http_charset_module по умолчанию не работает MIME-типом text/css. - *) Добавление: теперь nginx возвращает код 405 для метода POST при + *) Добавление: теперь nginx возвращает код 405 для метода POST при запросе статического файла, только если файл существует. *) Добавление: директива proxy_ssl_session_reuse. - *) Исправление: после перенаправления запроса с помощью - "X-Accel-Redirect" директива proxy_pass без URI могла использовать + *) Исправление: после перенаправления запроса с помощью + "X-Accel-Redirect" директива proxy_pass без URI могла использовать оригинальный запрос. - *) Исправление: если у каталога были права доступа только на поиск - файлов и первый индексный файл отсутствовал, то nginx возвращал + *) Исправление: если у каталога были права доступа только на поиск + файлов и первый индексный файл отсутствовал, то nginx возвращал ошибку 500. - *) Исправление: ошибок во вложенных location'ах; ошибки появились в + *) Исправление: ошибок во вложенных location'ах; ошибки появились в 0.7.1. Изменения в nginx 0.7.10 13.08.2008 - *) Исправление: ошибок в директивах addition_types, charset_types, - gzip_types, ssi_types, sub_filter_types и xslt_types; ошибки + *) Исправление: ошибок в директивах addition_types, charset_types, + gzip_types, ssi_types, sub_filter_types и xslt_types; ошибки появились в 0.7.9. *) Исправление: рекурсивной error_page для 500 ошибки. - *) Исправление: теперь модуль ngx_http_realip_module устанавливает - адрес не для всего keepalive соединения, а для каждого запроса по - этому соединению. + *) Исправление: теперь модуль ngx_http_realip_module устанавливает адрес + не для всего keepalive соединения, а для каждого запроса по этому + соединению. Изменения в nginx 0.7.9 12.08.2008 - *) Изменение: теперь ngx_http_charset_module по умолчанию работает со - следующими MIME-типами: text/html, text/css, text/xml, text/plain, + *) Изменение: теперь ngx_http_charset_module по умолчанию работает со + следующими MIME-типами: text/html, text/css, text/xml, text/plain, text/vnd.wap.wml, application/x-javascript и application/rss+xml. *) Добавление: директивы charset_types и addition_types. - *) Добавление: теперь директивы gzip_types, ssi_types и - sub_filter_types используют хэш. + *) Добавление: теперь директивы gzip_types, ssi_types и sub_filter_types + используют хэш. *) Добавление: модуль ngx_cpp_test_module. *) Добавление: директива expires поддерживает суточное время. - *) Добавление: улучшения и исправления в модуле - ngx_http_xslt_module. + *) Добавление: улучшения и исправления в модуле ngx_http_xslt_module. Спасибо Денису Латыпову и Максиму Дунину. - *) Исправление: директива log_not_found не работала при поиске - индексных файлов. - - *) Исправление: HTTPS-соединения могли зависнуть, если использовались + *) Исправление: директива log_not_found не работала при поиске индексных + файлов. + + *) Исправление: HTTPS-соединения могли зависнуть, если использовались методы kqueue, epoll, rtsig или eventport; ошибка появилась в 0.7.7. - *) Исправление: если в директивах server_name, valid_referers и map - использовалась маска вида "*.domain.tld" и при этом полное имя вида - "domain.tld" не было описано, то это имя попадало под маску; ошибка + *) Исправление: если в директивах server_name, valid_referers и map + использовалась маска вида "*.domain.tld" и при этом полное имя вида + "domain.tld" не было описано, то это имя попадало под маску; ошибка появилась в 0.3.18. @@ -1978,20 +2013,20 @@ *) Добавление: поддержка directio в Solaris. Спасибо Ivan Debnar. - *) Исправление: теперь, если FastCGI-сервер присылает строку "Location" - в заголовке ответа без строки статуса, то nginx использует код + *) Исправление: теперь, если FastCGI-сервер присылает строку "Location" + в заголовке ответа без строки статуса, то nginx использует код статуса 302. Спасибо Максиму Дунину. Изменения в nginx 0.7.7 30.07.2008 - *) Изменение: теперь ошибка EAGAIN при вызове connect() не считается + *) Изменение: теперь ошибка EAGAIN при вызове connect() не считается временной. - *) Изменение: значением переменной $ssl_client_cert теперь является - сертификат, перед каждой строкой которого, кроме первой, вставляется - символ табуляции; неизменённый сертификат доступен через переменную + *) Изменение: значением переменной $ssl_client_cert теперь является + сертификат, перед каждой строкой которого, кроме первой, вставляется + символ табуляции; неизменённый сертификат доступен через переменную $ssl_client_raw_cert. *) Добавление: параметр ask директивы ssl_verify_client. @@ -2004,36 +2039,36 @@ *) Добавление: поддержка sendfile() в MacOSX 10.5. - *) Исправление: в MacOSX и Cygwin при проверке location'ов теперь - делается сравнение без учёта регистра символов; однако, сравнение + *) Исправление: в MacOSX и Cygwin при проверке location'ов теперь + делается сравнение без учёта регистра символов; однако, сравнение ограничено только однобайтными locale'ями. - *) Исправление: соединения почтового прокси-сервера зависали в режиме + *) Исправление: соединения почтового прокси-сервера зависали в режиме SSL, если использовались методы select, poll или /dev/poll. - *) Исправление: ошибки при использовании кодировки UTF-8 в + *) Исправление: ошибки при использовании кодировки UTF-8 в ngx_http_autoindex_module. Изменения в nginx 0.7.6 07.07.2008 - *) Исправление: теперь при использовании переменных в директиве + *) Исправление: теперь при использовании переменных в директиве access_log всегда проверяется существовании root'а для запроса. - *) Исправление: модуль ngx_http_flv_module не поддерживал несколько + *) Исправление: модуль ngx_http_flv_module не поддерживал несколько значений в аргументах запроса. Изменения в nginx 0.7.5 01.07.2008 - *) Исправления в поддержке переменных в директиве access_log; ошибки + *) Исправления в поддержке переменных в директиве access_log; ошибки появились в 0.7.4. - *) Исправление: nginx не собирался с параметром + *) Исправление: nginx не собирался с параметром --without-http_gzip_module; ошибка появилась в 0.7.3. Спасибо Кириллу Коринскому. - *) Исправление: при совместном использовании sub_filter и SSI ответы + *) Исправление: при совместном использовании sub_filter и SSI ответы могли передаваться неверно. @@ -2052,16 +2087,16 @@ Изменения в nginx 0.7.3 23.06.2008 - *) Изменение: MIME-тип для расширения rss изменён на + *) Изменение: MIME-тип для расширения rss изменён на "application/rss+xml". - *) Изменение: теперь директива "gzip_vary on" выдаёт строку + *) Изменение: теперь директива "gzip_vary on" выдаёт строку "Vary: Accept-Encoding" в заголовке ответа и для несжатых ответов. - *) Добавление: теперь при использовании протокола "https://" в - директиве rewrite автоматически делается редирект. - - *) Исправление: директива proxy_pass не работала с протоколом HTTPS; + *) Добавление: теперь при использовании протокола "https://" в директиве + rewrite автоматически делается редирект. + + *) Исправление: директива proxy_pass не работала с протоколом HTTPS; ошибка появилась в 0.6.9. @@ -2074,14 +2109,14 @@ *) Добавление: переменная $ssl_client_cert. Спасибо Manlio Perillo. - *) Исправление: после изменения URI с помощью директивы rewrite nginx - не искал новый location; ошибка появилась в 0.7.1. + *) Исправление: после изменения URI с помощью директивы rewrite nginx не + искал новый location; ошибка появилась в 0.7.1. Спасибо Максиму Дунину. - *) Исправление: nginx не собирался без библиотеки PCRE; ошибка - появилась в 0.7.1. - - *) Исправление: при редиректе запроса к каталогу с добавлением слэша + *) Исправление: nginx не собирался без библиотеки PCRE; ошибка появилась + в 0.7.1. + + *) Исправление: при редиректе запроса к каталогу с добавлением слэша nginx не добавлял аргументы из оригинального запроса. @@ -2089,17 +2124,17 @@ *) Изменение: теперь поиск location'а делается с помощью дерева. - *) Изменение: директива optimize_server_names упразднена в связи с + *) Изменение: директива optimize_server_names упразднена в связи с появлением директивы server_name_in_redirect. - *) Изменение: некоторые давно устаревшие директивы больше не + *) Изменение: некоторые давно устаревшие директивы больше не поддерживаются. - *) Изменение: параметр "none" в директиве ssl_session_cache; теперь - этот параметр используется по умолчанию. + *) Изменение: параметр "none" в директиве ssl_session_cache; теперь этот + параметр используется по умолчанию. Спасибо Rob Mueller. - *) Исправление: рабочие процессы могли не реагировать на сигналы + *) Исправление: рабочие процессы могли не реагировать на сигналы переконфигурации и ротации логов. *) Исправление: nginx не собирался на последних Fedora 9 Linux. @@ -2108,16 +2143,16 @@ Изменения в nginx 0.7.0 19.05.2008 - *) Изменение: теперь символы 0x00-0x1F, '"' и '\' в access_log + *) Изменение: теперь символы 0x00-0x1F, '"' и '\' в access_log записываются в виде \xXX. Спасибо Максиму Дунину. - *) Изменение: теперь nginx разрешает несколько строк "Host" в заголовке + *) Изменение: теперь nginx разрешает несколько строк "Host" в заголовке запроса. *) Добавление: директива expires поддерживает флаг modified. - *) Добавление: переменные $uid_got и $uid_set можно использовать на + *) Добавление: переменные $uid_got и $uid_set можно использовать на любой стадии обработки запроса. *) Добавление: переменная $hostname. @@ -2126,44 +2161,44 @@ *) Добавление: поддержка DESTDIR. Спасибо Todd A. Fisher и Andras Voroskoi. - *) Исправление: при использовании keepalive на Linux в рабочем процессе + *) Исправление: при использовании keepalive на Linux в рабочем процессе мог произойти segmentation fault. Изменения в nginx 0.6.31 12.05.2008 - *) Исправление: nginx не обрабатывал ответ FastCGI-сервера, если строка - заголовка ответ была в конце записи FastCGI; ошибка появилась в + *) Исправление: nginx не обрабатывал ответ FastCGI-сервера, если строка + заголовка ответ была в конце записи FastCGI; ошибка появилась в 0.6.2. Спасибо Сергею Серову. - *) Исправление: при удалении файла и использовании директивы - open_file_cache_errors off в рабочем процессе мог произойти + *) Исправление: при удалении файла и использовании директивы + open_file_cache_errors off в рабочем процессе мог произойти segmentation fault. Изменения в nginx 0.6.30 29.04.2008 - *) Изменение: теперь, если маске, заданной в директиве include, не + *) Изменение: теперь, если маске, заданной в директиве include, не соответствует ни один файл, то nginx не выдаёт ошибку. - *) Добавление: теперь время в директивах можно задавать без пробела, + *) Добавление: теперь время в директивах можно задавать без пробела, например, "1h50m". - *) Исправление: утечек памяти, если директива ssl_verify_client имела + *) Исправление: утечек памяти, если директива ssl_verify_client имела значение on. Спасибо Chavelle Vincent. - *) Исправление: директива sub_filter могла вставлять заменяемый текст в + *) Исправление: директива sub_filter могла вставлять заменяемый текст в вывод. - *) Исправление: директива error_page не воспринимала параметры в + *) Исправление: директива error_page не воспринимала параметры в перенаправляемом URI. - *) Исправление: теперь при сборке с Cygwin nginx всегда открывает файлы + *) Исправление: теперь при сборке с Cygwin nginx всегда открывает файлы в бинарном режиме. - *) Исправление: nginx не собирался под OpenBSD; ошибка появилась в + *) Исправление: nginx не собирался под OpenBSD; ошибка появилась в 0.6.15. @@ -2171,7 +2206,7 @@ *) Добавление: модуль ngx_google_perftools_module. - *) Исправление: модуль ngx_http_perl_module не собирался на 64-битных + *) Исправление: модуль ngx_http_perl_module не собирался на 64-битных платформах; ошибка появилась в 0.6.27. @@ -2182,128 +2217,126 @@ Изменения в nginx 0.6.27 12.03.2008 - *) Изменение: теперь на Linux 2.6.18+ по умолчанию не собирается метод + *) Изменение: теперь на Linux 2.6.18+ по умолчанию не собирается метод rtsig. - *) Изменение: теперь при перенаправлении запроса в именованный location + *) Изменение: теперь при перенаправлении запроса в именованный location с помощью директивы error_page метод запроса не изменяется. - *) Добавление: директивы resolver и resolver_timeout в SMTP + *) Добавление: директивы resolver и resolver_timeout в SMTP прокси-сервере. - *) Добавление: директива post_action поддерживает именованные + *) Добавление: директива post_action поддерживает именованные location'ы. - *) Исправление: при перенаправлении запроса из location'а c - обработчиком proxy, FastCGI или memcached в именованный location со - статическим обработчиком в рабочем процессе происходил segmentation - fault. - - *) Исправление: браузеры не повторяли SSL handshake, если при первом - handshake не оказалось правильного клиентского сертификата. + *) Исправление: при перенаправлении запроса из location'а c обработчиком + proxy, FastCGI или memcached в именованный location со статическим + обработчиком в рабочем процессе происходил segmentation fault. + + *) Исправление: браузеры не повторяли SSL handshake, если при первом + handshake не оказалось правильного клиентского сертификата. Спасибо Александру Инюхину. - *) Исправление: при перенаправлении ошибок 495-497 с помощью директивы - error_page без изменения кода ошибки nginx пытался выделить очень + *) Исправление: при перенаправлении ошибок 495-497 с помощью директивы + error_page без изменения кода ошибки nginx пытался выделить очень много памяти. - *) Исправление: утечки памяти в долгоживущих небуфферизированных + *) Исправление: утечки памяти в долгоживущих небуфферизированных соединениях. *) Исправление: утечки памяти в resolver'е. - *) Исправление: при перенаправлении запроса из location'а c - обработчиком proxy в другой location с обработчиком proxy в рабочем - процессе происходил segmentation fault. - - *) Исправление: ошибки в кэшировании переменных $proxy_host и + *) Исправление: при перенаправлении запроса из location'а c обработчиком + proxy в другой location с обработчиком proxy в рабочем процессе + происходил segmentation fault. + + *) Исправление: ошибки в кэшировании переменных $proxy_host и $proxy_port. Спасибо Сергею Боченкову. - *) Исправление: директива proxy_pass с переменными использовала порт, - описанной в другой директиве proxy_pass без переменных, но с таким - же именем хоста. + *) Исправление: директива proxy_pass с переменными использовала порт, + описанной в другой директиве proxy_pass без переменных, но с таким же + именем хоста. Спасибо Сергею Боченкову. - *) Исправление: во время переконфигурации на некоторых 64-битном - платформах в лог записывался alert "sendmsg() failed (9: Bad file + *) Исправление: во время переконфигурации на некоторых 64-битном + платформах в лог записывался alert "sendmsg() failed (9: Bad file descriptor)". - *) Исправление: при повторном использовании в SSI пустого block'а в + *) Исправление: при повторном использовании в SSI пустого block'а в качестве заглушки в рабочем процессе происходил segmentation fault. - *) Исправление: ошибки при копировании части URI, содержащего + *) Исправление: ошибки при копировании части URI, содержащего экранированные символы, в аргументы. Изменения в nginx 0.6.26 11.02.2008 - *) Исправление: директивы proxy_store и fastcgi_store не проверяли - длину ответа. - - *) Исправление: при использовании большого значения в директиве expires + *) Исправление: директивы proxy_store и fastcgi_store не проверяли длину + ответа. + + *) Исправление: при использовании большого значения в директиве expires в рабочем процессе происходил segmentation fault. Спасибо Joaquin Cuenca Abela. - *) Исправление: nginx неверно определял длину строки кэша на - Pentium 4. + *) Исправление: nginx неверно определял длину строки кэша на Pentium 4. Спасибо Геннадию Махомеду. - *) Исправление: в проксированных подзапросах и подзапросах к - FastCGI-серверу вместо метода GET использовался оригинальный метод + *) Исправление: в проксированных подзапросах и подзапросах к + FastCGI-серверу вместо метода GET использовался оригинальный метод клиента. - *) Исправление: утечки сокетов в режиме HTTPS при использовании + *) Исправление: утечки сокетов в режиме HTTPS при использовании отложенного accept'а. Спасибо Ben Maurer. - *) Исправление: nginx выдавал ошибочное сообщение "SSL_shutdown() - failed (SSL: )"; ошибка появилась в 0.6.23. - - *) Исправление: при использовании HTTPS запросы могли завершаться с + *) Исправление: nginx выдавал ошибочное сообщение "SSL_shutdown() failed + (SSL: )"; ошибка появилась в 0.6.23. + + *) Исправление: при использовании HTTPS запросы могли завершаться с ошибкой "bad write retry"; ошибка появилась в 0.6.23. Изменения в nginx 0.6.25 08.01.2008 - *) Изменение: вместо специального параметра "*" в директиве server_name + *) Изменение: вместо специального параметра "*" в директиве server_name теперь используется директива server_name_in_redirect. - *) Изменение: в качестве основного имени в директиве server_name теперь + *) Изменение: в качестве основного имени в директиве server_name теперь можно использовать имена с масками и регулярными выражениями. *) Изменение: директива satisfy_any заменена директивой satisfy. - *) Изменение: после переконфигурации старые рабочие процесс могли - сильно нагружать процессор при запуске под Linux OpenVZ. + *) Изменение: после переконфигурации старые рабочие процесс могли сильно + нагружать процессор при запуске под Linux OpenVZ. *) Добавление: директива min_delete_depth. *) Исправление: методы COPY и MOVE не работали с одиночными файлами. - *) Исправление: модуль ngx_http_gzip_static_module не позволял работать + *) Исправление: модуль ngx_http_gzip_static_module не позволял работать модулю ngx_http_dav_module; ошибка появилась в 0.6.23. - *) Исправление: утечки сокетов в режиме HTTPS при использовании + *) Исправление: утечки сокетов в режиме HTTPS при использовании отложенного accept'а. Спасибо Ben Maurer. - *) Исправление: nginx не собирался без библиотеки PCRE; ошибка - появилась в 0.6.23. + *) Исправление: nginx не собирался без библиотеки PCRE; ошибка появилась + в 0.6.23. Изменения в nginx 0.6.24 27.12.2007 - *) Исправление: при использовании HTTPS в рабочем процессе мог - произойти segmentation fault; ошибка появилась в 0.6.23. + *) Исправление: при использовании HTTPS в рабочем процессе мог произойти + segmentation fault; ошибка появилась в 0.6.23. Изменения в nginx 0.6.23 27.12.2007 - *) Изменение: параметр "off" в директиве ssl_session_cache; теперь этот + *) Изменение: параметр "off" в директиве ssl_session_cache; теперь этот параметр используется по умолчанию. - *) Изменение: директива open_file_cache_retest переименована в + *) Изменение: директива open_file_cache_retest переименована в open_file_cache_valid. *) Добавление: директива open_file_cache_min_uses. @@ -2312,97 +2345,96 @@ *) Добавление: директива gzip_disable. - *) Добавление: директиву memcached_pass можно использовать внутри блока + *) Добавление: директиву memcached_pass можно использовать внутри блока if. - *) Исправление: если внутри одного location'а использовались директивы - "memcached_pass" и "if", то в рабочем процессе происходил + *) Исправление: если внутри одного location'а использовались директивы + "memcached_pass" и "if", то в рабочем процессе происходил segmentation fault. - *) Исправление: если при использовании директивы satisfy_any on" были - заданы директивы не всех модулей доступа, то заданные директивы не + *) Исправление: если при использовании директивы satisfy_any on" были + заданы директивы не всех модулей доступа, то заданные директивы не проверялись. - *) Исправление: параметры, заданные регулярным выражением в директиве + *) Исправление: параметры, заданные регулярным выражением в директиве valid_referers, не наследовалась с предыдущего уровня. - *) Исправление: директива post_action не работала, если запрос + *) Исправление: директива post_action не работала, если запрос завершался с кодом 499. - *) Исправление: оптимизация использования 16K буфера для - SSL-соединения. + *) Исправление: оптимизация использования 16K буфера для SSL-соединения. Спасибо Ben Maurer. *) Исправление: STARTTLS в режиме SMTP не работал. Спасибо Олегу Мотиенко. - *) Исправление: при использовании HTTPS запросы могли завершаться с + *) Исправление: при использовании HTTPS запросы могли завершаться с ошибкой "bad write retry"; ошибка появилась в 0.5.13. Изменения в nginx 0.6.22 19.12.2007 - *) Изменение: теперь все методы модуля ngx_http_perl_module возвращают + *) Изменение: теперь все методы модуля ngx_http_perl_module возвращают значения, скопированные в память, выделенную perl'ом. - *) Исправление: если nginx был собран с модулем ngx_http_perl_module, - использовался perl до версии 5.8.6 и perl поддерживал потоки, то во - время переконфигурации основной процесс аварийно выходил; ошибка + *) Исправление: если nginx был собран с модулем ngx_http_perl_module, + использовался perl до версии 5.8.6 и perl поддерживал потоки, то во + время переконфигурации основной процесс аварийно выходил; ошибка появилась в 0.5.9. Спасибо Борису Жмурову. - *) Исправление: в методы модуля ngx_http_perl_module могли передаваться + *) Исправление: в методы модуля ngx_http_perl_module могли передаваться неверные результаты выделения в регулярных выражениях. - *) Исправление: если метод $r->has_request_body() вызывался для - запроса, у которого небольшое тело запроса было уже полностью - получено, то в рабочем процессе происходил segmentation fault. - - *) Исправление: large_client_header_buffers не освобождались перед + *) Исправление: если метод $r->has_request_body() вызывался для запроса, + у которого небольшое тело запроса было уже полностью получено, то в + рабочем процессе происходил segmentation fault. + + *) Исправление: large_client_header_buffers не освобождались перед переходом в состояние keep-alive. Спасибо Олександру Штепе. - *) Исправление: в переменной $upstream_addr не записывался последний + *) Исправление: в переменной $upstream_addr не записывался последний адрес; ошибка появилась в 0.6.18. - *) Исправление: директива fastcgi_catch_stderr не возвращала ошибку; - теперь она возвращает ошибку 502, которую можно направить на + *) Исправление: директива fastcgi_catch_stderr не возвращала ошибку; + теперь она возвращает ошибку 502, которую можно направить на следующий сервер с помощью "fastcgi_next_upstream invalid_header". - *) Исправление: при использовании директивы fastcgi_catch_stderr в - основном процессе происходил segmentation fault; ошибка появилась в + *) Исправление: при использовании директивы fastcgi_catch_stderr в + основном процессе происходил segmentation fault; ошибка появилась в 0.6.10. Спасибо Manlio Perillo. Изменения в nginx 0.6.21 03.12.2007 - *) Изменение: если в значениях переменных директивы proxy_pass + *) Изменение: если в значениях переменных директивы proxy_pass используются только IP-адреса, то указывать resolver не нужно. - *) Исправление: при использовании директивы proxy_pass c URI-частью в - рабочем процессе мог произойти segmentation fault; ошибка появилась - в 0.6.19. - - *) Исправление: если resolver использовался на платформах, не - поддерживающих метод kqueue, то nginx выдавал alert "name is out of + *) Исправление: при использовании директивы proxy_pass c URI-частью в + рабочем процессе мог произойти segmentation fault; ошибка появилась в + 0.6.19. + + *) Исправление: если resolver использовался на платформах, не + поддерживающих метод kqueue, то nginx выдавал alert "name is out of response". Спасибо Андрею Нигматулину. - *) Исправление: При использовании переменной $server_protocol в - FastCGI-параметрах и запросе, длина которого была близка к значению - директивы client_header_buffer_size, nginx выдавал alert "fastcgi: + *) Исправление: При использовании переменной $server_protocol в + FastCGI-параметрах и запросе, длина которого была близка к значению + директивы client_header_buffer_size, nginx выдавал alert "fastcgi: the request record is too big". - *) Исправление: при обычном запросе версии HTTP/0.9 к HTTPS серверу + *) Исправление: при обычном запросе версии HTTP/0.9 к HTTPS серверу nginx возвращал обычный ответ. Изменения в nginx 0.6.20 28.11.2007 - *) Исправление: при использовании директивы proxy_pass c URI-частью в - рабочем процессе мог произойти segmentation fault; ошибка появилась - в 0.6.19. + *) Исправление: при использовании директивы proxy_pass c URI-частью в + рабочем процессе мог произойти segmentation fault; ошибка появилась в + 0.6.19. Изменения в nginx 0.6.19 27.11.2007 @@ -2412,20 +2444,20 @@ Изменения в nginx 0.6.18 27.11.2007 - *) Изменение: теперь модуль ngx_http_userid_module в поле куки с - номером процесса добавляет микросекунды на время старта. - - *) Изменение: в error_log теперь записывается полная строка запроса + *) Изменение: теперь модуль ngx_http_userid_module в поле куки с номером + процесса добавляет микросекунды на время старта. + + *) Изменение: в error_log теперь записывается полная строка запроса вместо только URI. *) Добавление: директива proxy_pass поддерживает переменные. *) Добавление: директивы resolver и resolver_timeout. - *) Добавление: теперь директива "add_header last-modified ''" удаляет в + *) Добавление: теперь директива "add_header last-modified ''" удаляет в заголовке ответа строку "Last-Modified". - *) Исправление: директива limit_rate не позволяла передавать на полной + *) Исправление: директива limit_rate не позволяла передавать на полной скорости, даже если был указан очень большой лимит. @@ -2434,19 +2466,19 @@ *) Добавление: поддержка строки "If-Range" в заголовке запроса. Спасибо Александру Инюхину. - *) Исправление: при использовании директивы msie_refresh повторно + *) Исправление: при использовании директивы msie_refresh повторно экранировались уже экранированные символы; ошибка появилась в 0.6.4. - *) Исправление: директива autoindex не работала при использовании - "alias /". - - *) Исправление: при использовании подзапросов в рабочем процессе мог + *) Исправление: директива autoindex не работала при использовании "alias + /". + + *) Исправление: при использовании подзапросов в рабочем процессе мог произойти segmentation fault. - *) Исправление: при использовании SSL и gzip большие ответы могли + *) Исправление: при использовании SSL и gzip большие ответы могли передаваться не полностью. - *) Исправление: если ответ проксированного сервера был версии HTTP/0.9, + *) Исправление: если ответ проксированного сервера был версии HTTP/0.9, то переменная $status была равна 0. @@ -2455,8 +2487,8 @@ *) Изменение: теперь на Linux используется uname(2) вместо procfs. Спасибо Илье Новикову. - *) Исправление: если в директиве error_page использовался символ "?", - то он экранировался при проксировании запроса; ошибка появилась в + *) Исправление: если в директиве error_page использовался символ "?", то + он экранировался при проксировании запроса; ошибка появилась в 0.6.11. *) Исправление: совместимость с mget. @@ -2475,54 +2507,54 @@ *) Исправление: nginx не раскодировал URI в команде SSI include. - *) Исправление: при использовании переменной в директивах charset или - source_charset на старте или во время переконфигурации происходил + *) Исправление: при использовании переменной в директивах charset или + source_charset на старте или во время переконфигурации происходил segmentation fault, - *) Исправление: nginx возвращал ошибку 400 на запросы вида + *) Исправление: nginx возвращал ошибку 400 на запросы вида "GET http://www.domain.com HTTP/1.0". Спасибо James Oakley. - *) Исправление: после перенаправления запроса с телом запроса с помощью - директивы error_page nginx пытался снова прочитать тело запроса; + *) Исправление: после перенаправления запроса с телом запроса с помощью + директивы error_page nginx пытался снова прочитать тело запроса; ошибка появилась в 0.6.7. - *) Исправление: в рабочем процессе происходил segmentation fault, если - у сервера, обрабатывающему запрос, не был явно определён - server_name; ошибка появилась в 0.6.7. + *) Исправление: в рабочем процессе происходил segmentation fault, если у + сервера, обрабатывающему запрос, не был явно определён server_name; + ошибка появилась в 0.6.7. Изменения в nginx 0.6.14 15.10.2007 - *) Изменение: теперь по умолчанию команда SSI echo использует + *) Изменение: теперь по умолчанию команда SSI echo использует кодирование entity. *) Добавление: параметр encoding в команде SSI echo. - *) Добавление: директиву access_log можно использовать внутри блока + *) Добавление: директиву access_log можно использовать внутри блока limit_except. - *) Исправление: если все сервера апстрима оказывались недоступными, то - до восстановления работоспособности у всех серверов вес становился + *) Исправление: если все сервера апстрима оказывались недоступными, то + до восстановления работоспособности у всех серверов вес становился равным одному; ошибка появилась в 0.6.6. - *) Исправление: при использовании переменных $date_local и $date_gmt - вне модуля ngx_http_ssi_filter_module в рабочем процессе происходил + *) Исправление: при использовании переменных $date_local и $date_gmt вне + модуля ngx_http_ssi_filter_module в рабочем процессе происходил segmentation fault. - *) Исправление: при использовании включённом отладочном логе в рабочем + *) Исправление: при использовании включённом отладочном логе в рабочем процессе мог произойти segmentation fault. Спасибо Андрею Нигматулину. - *) Исправление: ngx_http_memcached_module не устанавливал + *) Исправление: ngx_http_memcached_module не устанавливал $upstream_response_time. Спасибо Максиму Дунину. - *) Исправление: рабочий процесс мог зациклиться при использовании + *) Исправление: рабочий процесс мог зациклиться при использовании memcached. - *) Исправление: nginx распознавал параметры "close" и "keep-alive" в - строке "Connection" в заголовке запроса только, если они были в + *) Исправление: nginx распознавал параметры "close" и "keep-alive" в + строке "Connection" в заголовке запроса только, если они были в нижнем регистре; ошибка появилась в 0.6.11. *) Исправление: sub_filter не работал с пустой строкой замены. @@ -2532,74 +2564,74 @@ Изменения в nginx 0.6.13 24.09.2007 - *) Исправление: nginx не закрывал файл каталога для запроса HEAD, если + *) Исправление: nginx не закрывал файл каталога для запроса HEAD, если использовался autoindex Спасибо Arkadiusz Patyk. Изменения в nginx 0.6.12 21.09.2007 - *) Изменение: почтовый прокси-сервер разделён на три модуля: pop3, imap + *) Изменение: почтовый прокси-сервер разделён на три модуля: pop3, imap и smtp. - *) Добавление: параметры конфигурации --without-mail_pop3_module, + *) Добавление: параметры конфигурации --without-mail_pop3_module, --without-mail_imap_module и --without-mail_smtp_module. - *) Добавление: директивы smtp_greeting_delay и smtp_client_buffer - модуля ngx_mail_smtp_module. - - *) Исправление: wildcard в конце имени сервера не работали; ошибка + *) Добавление: директивы smtp_greeting_delay и smtp_client_buffer модуля + ngx_mail_smtp_module. + + *) Исправление: wildcard в конце имени сервера не работали; ошибка появилась в 0.6.9. - *) Исправление: при использовании разделяемой библиотеки PCRE, + *) Исправление: при использовании разделяемой библиотеки PCRE, расположенной в нестандартном месте, nginx не запускался на Solaris. - *) Исправление: директивы proxy_hide_header и fastcgi_hide_header не + *) Исправление: директивы proxy_hide_header и fastcgi_hide_header не скрывали строки заголовка ответа с именем больше 32 символов. Спасибо Manlio Perillo. Изменения в nginx 0.6.11 11.09.2007 - *) Исправление: счётчик активных соединений всегда рос при - использовании почтового прокси-сервера. - - *) Исправление: если бэкенд возвращал только заголовок ответа при - небуферизированном проксировании, то nginx закрывал соединение с + *) Исправление: счётчик активных соединений всегда рос при использовании + почтового прокси-сервера. + + *) Исправление: если бэкенд возвращал только заголовок ответа при + небуферизированном проксировании, то nginx закрывал соединение с бэкендом по таймауту. - *) Исправление: nginx не поддерживал несколько строк "Connection" в + *) Исправление: nginx не поддерживал несколько строк "Connection" в заголовке запроса. - *) Исправление: если в сервере апстрима был задан max_fails, то после - первой же неудачной попытки вес сервера навсегда становился равным + *) Исправление: если в сервере апстрима был задан max_fails, то после + первой же неудачной попытки вес сервера навсегда становился равным одному; ошибка появилась в 0.6.6. Изменения в nginx 0.6.10 03.09.2007 - *) Добавление: директивы open_file_cache, open_file_cache_retest и + *) Добавление: директивы open_file_cache, open_file_cache_retest и open_file_cache_errors. *) Исправление: утечки сокетов; ошибка появилась в 0.6.7. - *) Исправление: В строку заголовка ответа "Content-Type", указанную в - методе $r->send_http_header(), не добавлялась кодировка, указанная в + *) Исправление: В строку заголовка ответа "Content-Type", указанную в + методе $r->send_http_header(), не добавлялась кодировка, указанная в директиве charset. - *) Исправление: при использовании метода /dev/poll в рабочем процессе + *) Исправление: при использовании метода /dev/poll в рабочем процессе мог произойти segmentation fault. Изменения в nginx 0.6.9 28.08.2007 - *) Исправление: рабочий процесс мог зациклиться при использовании + *) Исправление: рабочий процесс мог зациклиться при использовании протокола HTTPS; ошибка появилась в 0.6.7. - *) Исправление: если сервер слушал на двух адресах или портах, то nginx + *) Исправление: если сервер слушал на двух адресах или портах, то nginx не запускался при использовании wildcard в конце имени сервера. - *) Исправление: директива ip_hash могла неверно помечать сервера как + *) Исправление: директива ip_hash могла неверно помечать сервера как нерабочие. *) Исправление: nginx не собирался на amd64; ошибка появилась в 0.6.8. @@ -2607,63 +2639,63 @@ Изменения в nginx 0.6.8 20.08.2007 - *) Изменение: теперь nginx пытается установить директивы - worker_priority, worker_rlimit_nofile, worker_rlimit_core, + *) Изменение: теперь nginx пытается установить директивы + worker_priority, worker_rlimit_nofile, worker_rlimit_core, worker_rlimit_sigpending без привилегий root'а. - *) Изменение: теперь nginx экранирует символы пробела и "%" при - передаче запроса серверу аутентификации почтового прокси-сервера. - - *) Изменение: теперь nginx экранирует символ "%" в переменной + *) Изменение: теперь nginx экранирует символы пробела и "%" при передаче + запроса серверу аутентификации почтового прокси-сервера. + + *) Изменение: теперь nginx экранирует символ "%" в переменной $memcached_key. - *) Исправление: при указании относительного пути к конфигурационному - файлу в качестве параметра ключа -c nginx определял путь - относительно конфигурационного префикса; ошибка появилась в 0.6.6. + *) Исправление: при указании относительного пути к конфигурационному + файлу в качестве параметра ключа -c nginx определял путь относительно + конфигурационного префикса; ошибка появилась в 0.6.6. *) Исправление: nginx не работал на FreeBSD/sparc64. Изменения в nginx 0.6.7 15.08.2007 - *) Изменение: теперь пути, указанные в директивах include, - auth_basic_user_file, perl_modules, ssl_certificate, - ssl_certificate_key и ssl_client_certificate, определяются - относительно каталога конфигурационного файла nginx.conf, а не + *) Изменение: теперь пути, указанные в директивах include, + auth_basic_user_file, perl_modules, ssl_certificate, + ssl_certificate_key и ssl_client_certificate, определяются + относительно каталога конфигурационного файла nginx.conf, а не относительно префикса. *) Изменение: параметр --sysconfdir=PATH в configure упразднён. - *) Изменение: для обновления на лету версий 0.1.x создан специальный + *) Изменение: для обновления на лету версий 0.1.x создан специальный сценарий make upgrade1. - *) Добавление: директивы server_name и valid_referers поддерживают + *) Добавление: директивы server_name и valid_referers поддерживают регулярные выражения. - *) Добавление: директива server в блоке upstream поддерживает параметр + *) Добавление: директива server в блоке upstream поддерживает параметр backup. - *) Добавление: модуль ngx_http_perl_module поддерживает метод + *) Добавление: модуль ngx_http_perl_module поддерживает метод $r->discard_request_body. - *) Добавление: директива "add_header Last-Modified ..." меняет строку + *) Добавление: директива "add_header Last-Modified ..." меняет строку "Last-Modified" в заголовке ответа. - *) Исправление: если на запрос с телом возвращался ответ с кодом HTTP - отличным от 200, и после этого запроса соединение переходило в + *) Исправление: если на запрос с телом возвращался ответ с кодом HTTP + отличным от 200, и после этого запроса соединение переходило в состояние keep-alive, то на следующий запрос nginx возвращал 400. - *) Исправление: если в директиве auth_http был задан неправильный - адрес, то в рабочем процессе происходил segmentation fault. - - *) Исправление: теперь по умолчанию nginx использует значение 511 для + *) Исправление: если в директиве auth_http был задан неправильный адрес, + то в рабочем процессе происходил segmentation fault. + + *) Исправление: теперь по умолчанию nginx использует значение 511 для listen backlog на всех платформах, кроме FreeBSD. Спасибо Jiang Hong. - *) Исправление: рабочий процесс мог зациклиться, если server в блоке + *) Исправление: рабочий процесс мог зациклиться, если server в блоке upstream был помечен как down; ошибка появилась в 0.6.6. - *) Исправление: sendfilev() в Solaris теперь не используется при + *) Исправление: sendfilev() в Solaris теперь не используется при передаче тела запроса FastCGI-серверу через unix domain сокет. @@ -2677,17 +2709,17 @@ *) Добавление: переменная $is_args. - *) Исправление: равномерное распределение запросов к апстримам с + *) Исправление: равномерное распределение запросов к апстримам с большими весами. - *) Исправление: если клиент в почтовом прокси-сервере закрывал + *) Исправление: если клиент в почтовом прокси-сервере закрывал соединение, то nginx мог не закрывать соединение с бэкендом. - *) Исправление: при использовании одного хоста в качестве бэкендов для - протоколов HTTP и HTTPS без явного указания портов, nginx - использовал только один порт - 80 или 443. - - *) Исправление: nginx не собирался на Solaris/amd64 Sun Studio 11 и + *) Исправление: при использовании одного хоста в качестве бэкендов для + протоколов HTTP и HTTPS без явного указания портов, nginx использовал + только один порт - 80 или 443. + + *) Исправление: nginx не собирался на Solaris/amd64 Sun Studio 11 и более ранними версиями; ошибка появилась в 0.6.4. @@ -2696,19 +2728,18 @@ *) Добавление: переменная $nginx_version. Спасибо Николаю Гречуху. - *) Добавление: почтовый прокси-сервер поддерживает AUTHENTICATE в - режиме IMAP. + *) Добавление: почтовый прокси-сервер поддерживает AUTHENTICATE в режиме + IMAP. Спасибо Максиму Дунину. - *) Добавление: почтовый прокси-сервер поддерживает STARTTLS в режиме + *) Добавление: почтовый прокси-сервер поддерживает STARTTLS в режиме SMTP. Спасибо Максиму Дунину. - *) Исправление: теперь nginx экранирует пробел в переменной + *) Исправление: теперь nginx экранирует пробел в переменной $memcached_key. - *) Исправление: nginx неправильно собирался Sun Studio на - Solaris/amd64. + *) Исправление: nginx неправильно собирался Sun Studio на Solaris/amd64. Спасибо Jiang Hong. *) Исправление: незначительных потенциальных ошибок. @@ -2717,7 +2748,7 @@ Изменения в nginx 0.6.4 17.07.2007 - *) Безопасность: при использовании директивы msie_refresh был возможен + *) Безопасность: при использовании директивы msie_refresh был возможен XSS. Спасибо Максиму Богуку. @@ -2725,8 +2756,8 @@ *) Добавление: директивы proxy_store_access и fastcgi_store_access. - *) Исправление: nginx не работал на Solaris/sparc64, если был собран - Sun Studio. + *) Исправление: nginx не работал на Solaris/sparc64, если был собран Sun + Studio. Спасибо Андрею Нигматулину. *) Изменение: обход ошибки в Sun Studio 12. @@ -2737,79 +2768,79 @@ *) Добавление: директивы proxy_store и fastcgi_store. - *) Исправление: при использовании директивы auth_http_header в рабочем + *) Исправление: при использовании директивы auth_http_header в рабочем процессе мог произойти segmentation fault. Спасибо Максиму Дунину. - *) Исправление: если использовался метод аутентификации CRAM-MD5, но он + *) Исправление: если использовался метод аутентификации CRAM-MD5, но он не был разрешён, то в рабочем процессе происходил segmentation fault. - *) Исправление: при использовании протокола HTTPS в директиве - proxy_pass в рабочем процессе мог произойти segmentation fault. - - *) Исправление: в рабочем процессе мог произойти segmentation fault, + *) Исправление: при использовании протокола HTTPS в директиве proxy_pass + в рабочем процессе мог произойти segmentation fault. + + *) Исправление: в рабочем процессе мог произойти segmentation fault, если использовался метод eventport. - *) Исправление: директивы proxy_ignore_client_abort и + *) Исправление: директивы proxy_ignore_client_abort и fastcgi_ignore_client_abort не работали; ошибка появилась в 0.5.13. Изменения в nginx 0.6.2 09.07.2007 - *) Исправление: если заголовок ответа был разделён в FastCGI-записях, - то nginx передавал клиенту мусор в таких заголовках. + *) Исправление: если заголовок ответа был разделён в FastCGI-записях, то + nginx передавал клиенту мусор в таких заголовках. Изменения в nginx 0.6.1 17.06.2007 *) Исправление: в парсинге SSI. - *) Исправление: при использовании удалённого подзапроса в SSI - последующий подзапрос локального файла мог отдаваться клиенту в + *) Исправление: при использовании удалённого подзапроса в SSI + последующий подзапрос локального файла мог отдаваться клиенту в неверном порядке. - *) Исправление: большие включения в SSI, сохранённые во временные - файлы, передавались не полностью. - - *) Исправление: значение perl'овой переменной $$ модуля + *) Исправление: большие включения в SSI, сохранённые во временные файлы, + передавались не полностью. + + *) Исправление: значение perl'овой переменной $$ модуля ngx_http_perl_module было равно номеру главного процесса. Изменения в nginx 0.6.0 14.06.2007 - *) Добавление: директивы "server_name", "map", and "valid_referers" + *) Добавление: директивы "server_name", "map", and "valid_referers" поддерживают маски вида "www.example.*". Изменения в nginx 0.5.25 11.06.2007 - *) Исправление: nginx не собирался с параметром + *) Исправление: nginx не собирался с параметром --without-http_rewrite_module; ошибка появилась в 0.5.24. Изменения в nginx 0.5.24 06.06.2007 - *) Безопасность: директива ssl_verify_client не работала, если запрос + *) Безопасность: директива ssl_verify_client не работала, если запрос выполнялся по протоколу HTTP/0.9. - *) Исправление: при использовании сжатия часть ответа могла - передаваться несжатой; ошибка появилась в 0.5.23. + *) Исправление: при использовании сжатия часть ответа могла передаваться + несжатой; ошибка появилась в 0.5.23. Изменения в nginx 0.5.23 04.06.2007 - *) Добавление: модуль ngx_http_ssl_module поддерживает расширение TLS + *) Добавление: модуль ngx_http_ssl_module поддерживает расширение TLS Server Name Indication. *) Добавление: директива fastcgi_catch_stderr. Спасибо Николаю Гречуху, проект OWOX. - *) Исправление: на Линуксе в основном процессе происходил segmentation - fault, если два виртуальных сервера должны bind()ится к + *) Исправление: на Линуксе в основном процессе происходил segmentation + fault, если два виртуальных сервера должны bind()ится к пересекающимся портам. - *) Исправление: если nginx был собран с модулем ngx_http_perl_module и - perl поддерживал потоки, то во время второй переконфигурации + *) Исправление: если nginx был собран с модулем ngx_http_perl_module и + perl поддерживал потоки, то во время второй переконфигурации выдавались ошибки "panic: MUTEX_LOCK" и "perl_parse() failed". *) Исправление: в использовании протокола HTTPS в директиве proxy_pass. @@ -2817,22 +2848,22 @@ Изменения в nginx 0.5.22 29.05.2007 - *) Исправление: большое тело запроса могло не передаваться бэкенду; + *) Исправление: большое тело запроса могло не передаваться бэкенду; ошибка появилась в 0.5.21. Изменения в nginx 0.5.21 28.05.2007 - *) Исправление: если внутри сервера описано больше примерно десяти - location'ов, то location'ы, заданные с помощью регулярного - выражения, могли выполняться не в том, порядке, в каком они описаны. - - *) Исправление: на 64-битной платформе рабочий процесс мог зациклиться, + *) Исправление: если внутри сервера описано больше примерно десяти + location'ов, то location'ы, заданные с помощью регулярного выражения, + могли выполняться не в том, порядке, в каком они описаны. + + *) Исправление: на 64-битной платформе рабочий процесс мог зациклиться, если 33-тий по счёту или последующий бэкенд упал. Спасибо Антону Поварову. - *) Исправление: при использовании библиотеки PCRE на Solaris/sparc64 - мог произойти bus error. + *) Исправление: при использовании библиотеки PCRE на Solaris/sparc64 мог + произойти bus error. Спасибо Андрею Нигматулину. *) Исправление: в использовании протокола HTTPS в директиве proxy_pass. @@ -2842,43 +2873,42 @@ *) Добавление: директива sendfile_max_chunk. - *) Добавление: переменные "$http_...", "$sent_http_..." и + *) Добавление: переменные "$http_...", "$sent_http_..." и "$upstream_http_..." можно менять директивой set. - *) Исправление: при использовании SSI-команды 'if expr="$var = /"' в + *) Исправление: при использовании SSI-команды 'if expr="$var = /"' в рабочем процессе мог произойти segmentation fault. - *) Исправление: завершающая строка multipart range ответа передавалась + *) Исправление: завершающая строка multipart range ответа передавалась неверно. Спасибо Evan Miller. - *) Исправление: nginx не работал на Solaris/sparc64, если был собран - Sun Studio. + *) Исправление: nginx не работал на Solaris/sparc64, если был собран Sun + Studio. Спасибо Андрею Нигматулину. - *) Исправление: модуль ngx_http_perl_module не собирался make в - Solaris. + *) Исправление: модуль ngx_http_perl_module не собирался make в Solaris. Спасибо Андрею Нигматулину. Изменения в nginx 0.5.19 24.04.2007 - *) Изменение: значение переменной $request_time теперь записывается с + *) Изменение: значение переменной $request_time теперь записывается с точностью до миллисекунд. - *) Изменение: метод $r->rflush в модуле ngx_http_perl_module + *) Изменение: метод $r->rflush в модуле ngx_http_perl_module переименован в $r->flush. *) Добавление: переменная $upstream_addr. - *) Добавление: директивы proxy_headers_hash_max_size и + *) Добавление: директивы proxy_headers_hash_max_size и proxy_headers_hash_bucket_size. Спасибо Володымыру Костырко. - *) Исправление: при использовании sendfile и limit_rate на 64-битных + *) Исправление: при использовании sendfile и limit_rate на 64-битных платформах нельзя было передавать файлы больше 2G. - *) Исправление: при использовании sendfile на 64-битном Linux нельзя + *) Исправление: при использовании sendfile на 64-битном Linux нельзя было передавать файлы больше 2G. @@ -2888,16 +2918,16 @@ *) Добавление: переменные "$upstream_http_...". - *) Добавление: теперь переменные $upstream_status и - $upstream_response_time содержат данные о всех обращениях к + *) Добавление: теперь переменные $upstream_status и + $upstream_response_time содержат данные о всех обращениях к апстримам, сделанным до X-Accel-Redirect. - *) Исправление: если nginx был собран с модулем ngx_http_perl_module и - perl не поддерживал multiplicity, то после первой переконфигурации и - после получения любого сигнала в основном процессе происходил + *) Исправление: если nginx был собран с модулем ngx_http_perl_module и + perl не поддерживал multiplicity, то после первой переконфигурации и + после получения любого сигнала в основном процессе происходил segmentation fault; ошибка появилась в 0.5.9. - *) Исправление: если perl не поддерживал multiplicity, то после + *) Исправление: если perl не поддерживал multiplicity, то после переконфигурации перловый код не работал; ошибка появилась в 0.3.38. @@ -2905,69 +2935,68 @@ *) Изменение: теперь nginx для метода TRACE всегда возвращает код 405. - *) Добавление: теперь nginx поддерживает директиву include внутри блока + *) Добавление: теперь nginx поддерживает директиву include внутри блока types. - *) Исправление: использование переменной $document_root в директиве - root и alias запрещено: оно вызывало рекурсивное переполнение стека. + *) Исправление: использование переменной $document_root в директиве root + и alias запрещено: оно вызывало рекурсивное переполнение стека. *) Исправление: в использовании протокола HTTPS в директиве proxy_pass. - *) Исправление: в некоторых случаях некэшируемые переменные (такие, как + *) Исправление: в некоторых случаях некэшируемые переменные (такие, как $uri) возвращали старое закэшированное значение. Изменения в nginx 0.5.16 26.03.2007 - *) Исправление: в качестве ключа для хэша в директиве ip_hash не + *) Исправление: в качестве ключа для хэша в директиве ip_hash не использовалась сеть класса С. Спасибо Павлу Ярковому. - *) Исправление: если в строке "Content-Type" в заголовке ответа бэкенда - был указан charset и строка завершалась символом ";", то в рабочем + *) Исправление: если в строке "Content-Type" в заголовке ответа бэкенда + был указан charset и строка завершалась символом ";", то в рабочем процессе мог произойти segmentation fault; ошибка появилась в 0.3.50. - *) Исправление: ошибки "[alert] zero size buf" при работе с - FastCGI-сервером, если тело запроса, записанное во временный файл, + *) Исправление: ошибки "[alert] zero size buf" при работе с + FastCGI-сервером, если тело запроса, записанное во временный файл, было кратно 32K. - *) Исправление: nginx не собирался на Solaris без параметра + *) Исправление: nginx не собирался на Solaris без параметра --with-debug; ошибка появилась в 0.5.15. Изменения в nginx 0.5.15 19.03.2007 - *) Добавление: почтовый прокси-сервер поддерживает аутентифицированное - SMTP-проксирование и директивы smtp_auth, smtp_capablities и - xclient. + *) Добавление: почтовый прокси-сервер поддерживает аутентифицированное + SMTP-проксирование и директивы smtp_auth, smtp_capablities и xclient. Спасибо Антону Южанинову и Максиму Дунину. - *) Добавление: теперь keep-alive соединения закрываются сразу же по + *) Добавление: теперь keep-alive соединения закрываются сразу же по получении сигнала переконфигурации. - *) Изменение: директивы imap и auth переименованы соответственно в mail + *) Изменение: директивы imap и auth переименованы соответственно в mail и pop3_auth. - *) Исправление: если использовался метод аутентификации CRAM-MD5 и не - был разрешён метод APOP, то в рабочем процессе происходил + *) Исправление: если использовался метод аутентификации CRAM-MD5 и не + был разрешён метод APOP, то в рабочем процессе происходил segmentation fault. - *) Исправление: при использовании директивы starttls only в протоколе + *) Исправление: при использовании директивы starttls only в протоколе POP3 nginx разрешал аутентификацию без перехода в режим SSL. - *) Исправление: рабочие процессы не выходили после переконфигурации и - не переоткрывали логи, если использовался метод eventport. - - *) Исправление: при использовании директивы ip_hash рабочий процесс мог + *) Исправление: рабочие процессы не выходили после переконфигурации и не + переоткрывали логи, если использовался метод eventport. + + *) Исправление: при использовании директивы ip_hash рабочий процесс мог зациклиться. - *) Исправление: теперь nginx не пишет в лог некоторые alert'ы, если + *) Исправление: теперь nginx не пишет в лог некоторые alert'ы, если используются методы eventport или /dev/poll. Изменения в nginx 0.5.14 23.02.2007 - *) Исправление: nginx игнорировал лишние закрывающие скобки "}" в конце + *) Исправление: nginx игнорировал лишние закрывающие скобки "}" в конце конфигурационного файла. @@ -2975,71 +3004,70 @@ *) Добавление: методы COPY и MOVE. - *) Исправление: модуль ngx_http_realip_module устанавливал мусор для + *) Исправление: модуль ngx_http_realip_module устанавливал мусор для запросов, переданных по keep-alive соединению. *) Исправление: nginx не работал на 64-битном big-endian Linux. Спасибо Андрею Нигматулину. - *) Исправление: при получении слишком длинной команды IMAP/POP3-прокси + *) Исправление: при получении слишком длинной команды IMAP/POP3-прокси теперь сразу закрывает соединение, а не по таймауту. - *) Исправление: если при использовании метода epoll клиент закрывал - преждевременно соединение со своей стороны, то nginx закрывал это + *) Исправление: если при использовании метода epoll клиент закрывал + преждевременно соединение со своей стороны, то nginx закрывал это соединение только по истечении таймаута на передачу. - *) Исправление: nginx не собирался на платформах, отличных от i386, + *) Исправление: nginx не собирался на платформах, отличных от i386, amd64, sparc и ppc; ошибка появилась в 0.5.8. Изменения в nginx 0.5.12 12.02.2007 - *) Исправление: nginx не собирался на платформах, отличных от i386, + *) Исправление: nginx не собирался на платформах, отличных от i386, amd64, sparc и ppc; ошибка появилась в 0.5.8. - *) Исправление: при использовании временных файлов в время работы с - FastCGI-сервером в рабочем процессе мог произойти segmentation - fault; ошибка появилась в 0.5.8. - - *) Исправление: если переменная $fastcgi_script_name записывалась в - лог, то в рабочем процессе мог произойти segmentation fault. + *) Исправление: при использовании временных файлов в время работы с + FastCGI-сервером в рабочем процессе мог произойти segmentation fault; + ошибка появилась в 0.5.8. + + *) Исправление: если переменная $fastcgi_script_name записывалась в лог, + то в рабочем процессе мог произойти segmentation fault. *) Исправление: ngx_http_perl_module не собирался на Solaris. Изменения в nginx 0.5.11 05.02.2007 - *) Добавление: теперь configure определяет библиотеку PCRE в - MacPorts. + *) Добавление: теперь configure определяет библиотеку PCRE в MacPorts. Спасибо Chris McGrath. - *) Исправление: ответ был неверным, если запрашивалось несколько + *) Исправление: ответ был неверным, если запрашивалось несколько диапазонов; ошибка появилась в 0.5.6. - *) Исправление: директива create_full_put_path не могла создавать - промежуточные каталоги, если не была установлена директива + *) Исправление: директива create_full_put_path не могла создавать + промежуточные каталоги, если не была установлена директива dav_access. Спасибо Evan Miller. - *) Исправление: вместо кодов ошибок "400" и "408" в access_log мог + *) Исправление: вместо кодов ошибок "400" и "408" в access_log мог записываться код "0". - *) Исправление: при сборке с оптимизацией -O2 в рабочем процессе мог + *) Исправление: при сборке с оптимизацией -O2 в рабочем процессе мог произойти segmentation fault. Изменения в nginx 0.5.10 26.01.2007 - *) Исправление: во время обновления исполняемого файла новый процесс не + *) Исправление: во время обновления исполняемого файла новый процесс не наследовал слушающие сокеты; ошибка появилась в 0.5.9. - *) Исправление: при сборке с оптимизацией -O2 в рабочем процессе мог + *) Исправление: при сборке с оптимизацией -O2 в рабочем процессе мог произойти segmentation fault; ошибка появилась в 0.5.1. Изменения в nginx 0.5.9 25.01.2007 - *) Изменение: модуль ngx_http_memcached_module теперь в качестве ключа + *) Изменение: модуль ngx_http_memcached_module теперь в качестве ключа использует значение переменной $memcached_key. *) Добавление: переменная $memcached_key. @@ -3050,34 +3078,33 @@ *) Добавление: директива sendfile работает внутри блока if. - *) Добавление: теперь при ошибке записи в access_log nginx записывает + *) Добавление: теперь при ошибке записи в access_log nginx записывает сообщение в error_log, но не чаще одного раза в минуту. - *) Исправление: директива "access_log off" не всегда запрещала запись в + *) Исправление: директива "access_log off" не всегда запрещала запись в лог. Изменения в nginx 0.5.8 19.01.2007 - *) Исправление: если использовалась директива - "client_body_in_file_only on" и тело запроса было небольшое, то мог + *) Исправление: если использовалась директива + "client_body_in_file_only on" и тело запроса было небольшое, то мог произойти segmentation fault. - *) Исправление: происходил segmentation fault, если использовались - директивы "client_body_in_file_only on" и - "proxy_pass_request_body off" или "fastcgi_pass_request_body off", и + *) Исправление: происходил segmentation fault, если использовались + директивы "client_body_in_file_only on" и + "proxy_pass_request_body off" или "fastcgi_pass_request_body off", и делался переход к следующему бэкенду. - *) Исправление: если при использовании директивы "proxy_buffering off" - соединение с клиентом было неактивно, то оно закрывалось по - таймауту, заданному директивой send_timeout; ошибка появилась в - 0.4.7. - - *) Исправление: если при использовании метода epoll клиент закрывал - преждевременно соединение со своей стороны, то nginx закрывал это + *) Исправление: если при использовании директивы "proxy_buffering off" + соединение с клиентом было неактивно, то оно закрывалось по таймауту, + заданному директивой send_timeout; ошибка появилась в 0.4.7. + + *) Исправление: если при использовании метода epoll клиент закрывал + преждевременно соединение со своей стороны, то nginx закрывал это соединение только по истечении таймаута на передачу. - *) Исправление: ошибки "[alert] zero size buf" при работе с + *) Исправление: ошибки "[alert] zero size buf" при работе с FastCGI-сервером. *) Исправление ошибок в директиве limit_zone. @@ -3089,15 +3116,15 @@ *) Исправление ошибок в директивах ssl_session_cache и limit_zone. - *) Исправление: на старте или во время переконфигурации происходил - segmentation fault, если директивы ssl_session_cache или limit_zone + *) Исправление: на старте или во время переконфигурации происходил + segmentation fault, если директивы ssl_session_cache или limit_zone использовались на 64-битных платформах. - *) Исправление: при использовании директив add_before_body или - add_after_body происходил segmentation fault, если в заголовке - ответа нет строки "Content-Type". - - *) Исправление: библиотека OpenSSL всегда собиралась с поддержкой + *) Исправление: при использовании директив add_before_body или + add_after_body происходил segmentation fault, если в заголовке ответа + нет строки "Content-Type". + + *) Исправление: библиотека OpenSSL всегда собиралась с поддержкой потоков. Спасибо Дену Иванову. @@ -3106,19 +3133,19 @@ Изменения в nginx 0.5.6 09.01.2007 - *) Изменение: теперь модуль ngx_http_index_module игнорирует все - методы, кроме GET, HEAD и POST. + *) Изменение: теперь модуль ngx_http_index_module игнорирует все методы, + кроме GET, HEAD и POST. *) Добавление: модуль ngx_http_limit_zone_module. *) Добавление: переменная $binary_remote_addr. - *) Добавление: директивы ssl_session_cache модулей ngx_http_ssl_module - и ngx_imap_ssl_module. + *) Добавление: директивы ssl_session_cache модулей ngx_http_ssl_module и + ngx_imap_ssl_module. *) Добавление: метод DELETE поддерживает рекурсивное удаление. - *) Исправление: при использовании $r->sendfile() byte-ranges + *) Исправление: при использовании $r->sendfile() byte-ranges передавались неверно. @@ -3128,13 +3155,13 @@ *) Добавление: ключ -V. - *) Добавление: директива worker_rlimit_core поддерживает указание + *) Добавление: директива worker_rlimit_core поддерживает указание размера в K, M и G. - *) Исправление: модуль nginx.pm теперь может устанавливаться + *) Исправление: модуль nginx.pm теперь может устанавливаться непривилегированным пользователем. - *) Исправление: при использовании методов $r->request_body или + *) Исправление: при использовании методов $r->request_body или $r->request_body_file мог произойти segmentation fault. *) Исправление: ошибок, специфичных для платформы ppc. @@ -3142,86 +3169,85 @@ Изменения в nginx 0.5.4 15.12.2006 - *) Добавление: директиву perl можно использовать внутри блока + *) Добавление: директиву perl можно использовать внутри блока limit_except. - *) Исправление: модуль ngx_http_dav_module требовал строку "Date" в + *) Исправление: модуль ngx_http_dav_module требовал строку "Date" в заголовке запроса для метода DELETE. - *) Исправление: при использовании одного параметра в директиве + *) Исправление: при использовании одного параметра в директиве dav_access nginx мог сообщить об ошибке в конфигурации. - *) Исправление: при использовании переменной $host мог произойти + *) Исправление: при использовании переменной $host мог произойти segmentation fault; ошибка появилась в 0.4.14. Изменения в nginx 0.5.3 13.12.2006 - *) Добавление: модуль ngx_http_perl_module поддерживает методы + *) Добавление: модуль ngx_http_perl_module поддерживает методы $r->status, $r->log_error и $r->sleep. - *) Добавление: метод $r->variable поддерживает переменные, неописанные - в конфигурации nginx'а. + *) Добавление: метод $r->variable поддерживает переменные, неописанные в + конфигурации nginx'а. *) Исправление: метод $r->has_request_body не работал. Изменения в nginx 0.5.2 11.12.2006 - *) Исправление: если в директивах proxy_pass использовалось имя, - указанное в upstream, то nginx пытался найти IP-адрес этого имени; + *) Исправление: если в директивах proxy_pass использовалось имя, + указанное в upstream, то nginx пытался найти IP-адрес этого имени; ошибка появилась в 0.5.1. Изменения в nginx 0.5.1 11.12.2006 - *) Исправление: директива post_action могла не работать после - неудачного завершения запроса. - - *) Изменение: обход ошибки в Eudora для Mac; ошибка появилась в - 0.4.11. + *) Исправление: директива post_action могла не работать после неудачного + завершения запроса. + + *) Изменение: обход ошибки в Eudora для Mac; ошибка появилась в 0.4.11. Спасибо Bron Gondwana. - *) Исправление: при указании в директиве fastcgi_pass имени описанного - upstream'а выдавалось сообщение "no port in upstream"; ошибка + *) Исправление: при указании в директиве fastcgi_pass имени описанного + upstream'а выдавалось сообщение "no port in upstream"; ошибка появилась в 0.5.0. - *) Исправление: если в директивах proxy_pass и fastcgi_pass - использовались одинаковых имена серверов, но с разными портами, то - эти директивы использовали первый описанный порт; ошибка появилась в + *) Исправление: если в директивах proxy_pass и fastcgi_pass + использовались одинаковых имена серверов, но с разными портами, то + эти директивы использовали первый описанный порт; ошибка появилась в 0.5.0. - *) Исправление: если в директивах proxy_pass и fastcgi_pass - использовались unix domain сокеты, то эти директивы использовали + *) Исправление: если в директивах proxy_pass и fastcgi_pass + использовались unix domain сокеты, то эти директивы использовали первый описанный сокет; ошибка появилась в 0.5.0. - *) Исправление: ngx_http_auth_basic_module игнорировал пользователя, - если он был указан в последней строке файла паролей и после пароля - не было перевода строки, возврата каретки или символа ":". - - *) Исправление: переменная $upstream_response_time могла быть равна + *) Исправление: ngx_http_auth_basic_module игнорировал пользователя, + если он был указан в последней строке файла паролей и после пароля не + было перевода строки, возврата каретки или символа ":". + + *) Исправление: переменная $upstream_response_time могла быть равна "0.000", хотя время обработки было больше 1 миллисекунды. Изменения в nginx 0.5.0 04.12.2006 - *) Изменение: параметры в виде "%name" в директиве log_format больше не + *) Изменение: параметры в виде "%name" в директиве log_format больше не поддерживаются. - *) Изменение: директивы proxy_upstream_max_fails, - proxy_upstream_fail_timeout, fastcgi_upstream_max_fails, и - fastcgi_upstream_fail_timeout, memcached_upstream_max_fails и + *) Изменение: директивы proxy_upstream_max_fails, + proxy_upstream_fail_timeout, fastcgi_upstream_max_fails, и + fastcgi_upstream_fail_timeout, memcached_upstream_max_fails и memcached_upstream_fail_timeout больше не поддерживаются. - *) Добавление: директива server в блоке upstream поддерживает параметры + *) Добавление: директива server в блоке upstream поддерживает параметры max_fails, fail_timeout и down. *) Добавление: директива ip_hash в блоке upstream. - *) Добавление: статус WAIT в строке "Auth-Status" в заголовка ответа + *) Добавление: статус WAIT в строке "Auth-Status" в заголовка ответа сервера аутентификации IMAP/POP3 прокси. - *) Исправление: nginx не собирался на 64-битных платформах; ошибка + *) Исправление: nginx не собирался на 64-битных платформах; ошибка появилась в 0.4.14. @@ -3229,62 +3255,62 @@ *) Добавление: директива proxy_pass_error_message в IMAP/POP3 прокси. - *) Добавление: теперь configure определяет библиотеку PCRE на FreeBSD, + *) Добавление: теперь configure определяет библиотеку PCRE на FreeBSD, Linux и NetBSD. - *) Исправление: ngx_http_perl_module не работал с перлом, собранным с + *) Исправление: ngx_http_perl_module не работал с перлом, собранным с поддержкой потоков; ошибка появилась в 0.3.38. - *) Исправление: ngx_http_perl_module не работал корректно, если перл + *) Исправление: ngx_http_perl_module не работал корректно, если перл вызывался рекурсивно. *) Исправление: nginx игнорировал имя сервера в строке запроса. - *) Исправление: если FastCGI сервер передавал много в stderr, то - рабочий процесс мог зациклиться. - - *) Исправление: при изменении системного времени переменная + *) Исправление: если FastCGI сервер передавал много в stderr, то рабочий + процесс мог зациклиться. + + *) Исправление: при изменении системного времени переменная $upstream_response_time могла быть отрицательной. - *) Исправление: при использовании POP3 серверу аутентификации IMAP/POP3 + *) Исправление: при использовании POP3 серверу аутентификации IMAP/POP3 прокси не передавался параметр Auth-Login-Attempt. - *) Исправление: при ошибке соединения с сервером аутентификации + *) Исправление: при ошибке соединения с сервером аутентификации IMAP/POP3 прокси мог произойти segmentation fault. Изменения в nginx 0.4.13 15.11.2006 - *) Добавление: директиву proxy_pass можно использовать внутри блока + *) Добавление: директиву proxy_pass можно использовать внутри блока limit_except. *) Добавление: директива limit_except поддерживает все WebDAV методы. - *) Исправление: при использовании директивы add_before_body без + *) Исправление: при использовании директивы add_before_body без директивы add_after_body ответ передавался не полностью. - *) Исправление: большое тело запроса не принималось, если - использовались метод epoll и deferred accept(). - - *) Исправление: для ответов модуля ngx_http_autoindex_module не + *) Исправление: большое тело запроса не принималось, если использовались + метод epoll и deferred accept(). + + *) Исправление: для ответов модуля ngx_http_autoindex_module не выставлялась кодировка; ошибка появилась в 0.3.50. - *) Исправление: ошибки "[alert] zero size buf" при работе с + *) Исправление: ошибки "[alert] zero size buf" при работе с FastCGI-сервером; *) Исправление: параметр конфигурации --group= игнорировался. Спасибо Thomas Moschny. - *) Исправление: 50-й подзапрос в SSI ответе не работал; ошибка - появилась в 0.3.50. + *) Исправление: 50-й подзапрос в SSI ответе не работал; ошибка появилась + в 0.3.50. Изменения в nginx 0.4.12 31.10.2006 - *) Добавление: модуль ngx_http_perl_module поддерживает метод + *) Добавление: модуль ngx_http_perl_module поддерживает метод $r->variable. - *) Исправление: при включении в ответ большого статического файла с + *) Исправление: при включении в ответ большого статического файла с помощью SSI ответ мог передаваться не полностью. *) Исправление: nginx не убирал "#fragment" в URI. @@ -3294,10 +3320,10 @@ *) Добавление: POP3 прокси поддерживает AUTH LOIGN PLAIN и CRAM-MD5. - *) Добавление: модуль ngx_http_perl_module поддерживает метод + *) Добавление: модуль ngx_http_perl_module поддерживает метод $r->allow_ranges. - *) Исправление: при включённой поддержке команды APOP в POP3 прокси + *) Исправление: при включённой поддержке команды APOP в POP3 прокси могли не работать команды USER/PASS; ошибка появилась в 0.4.10. @@ -3305,17 +3331,17 @@ *) Добавление: POP3 прокси поддерживает APOP. - *) Исправление: при использовании методов select, poll и /dev/poll во - время ожидания ответа от сервера аутентификации IMAP/POP3 прокси + *) Исправление: при использовании методов select, poll и /dev/poll во + время ожидания ответа от сервера аутентификации IMAP/POP3 прокси нагружал процессор. - *) Исправление: при использовании переменной $server_addr в директиве + *) Исправление: при использовании переменной $server_addr в директиве map мог произойти segmentation fault. - *) Исправление: модуль ngx_http_flv_module не поддерживал byte ranges + *) Исправление: модуль ngx_http_flv_module не поддерживал byte ranges для полных ответов; ошибка появилась в 0.4.7. - *) Исправление: nginx не собирался на Debian amd64; ошибка появилась в + *) Исправление: nginx не собирался на Debian amd64; ошибка появилась в 0.4.9. @@ -3323,17 +3349,17 @@ *) Добавление: параметр set в команде SSI include. - *) Добавление: модуль ngx_http_perl_module теперь проверяет версию + *) Добавление: модуль ngx_http_perl_module теперь проверяет версию модуля nginx.pm. Изменения в nginx 0.4.8 11.10.2006 - *) Исправление: если до команды SSI include с параметром wait - выполнялась ещё одна команда SSI include, то параметр wait мог не + *) Исправление: если до команды SSI include с параметром wait + выполнялась ещё одна команда SSI include, то параметр wait мог не работать. - *) Исправление: модуль ngx_http_flv_module добавлял FLV-заголовок для + *) Исправление: модуль ngx_http_flv_module добавлял FLV-заголовок для полных ответов. Спасибо Алексею Ковырину. @@ -3344,37 +3370,37 @@ *) Добавление: переменная $request_body_file. - *) Добавление: директивы charset и source_charset поддерживают + *) Добавление: директивы charset и source_charset поддерживают переменные. - *) Исправление: если до команды SSI include с параметром wait - выполнялась ещё одна команда SSI include, то параметр wait мог не + *) Исправление: если до команды SSI include с параметром wait + выполнялась ещё одна команда SSI include, то параметр wait мог не работать. - *) Исправление: при использовании директивы "proxy_buffering off" или + *) Исправление: при использовании директивы "proxy_buffering off" или при работе с memcached соединения могли не закрываться по таймауту. - *) Исправление: nginx не запускался на 64-битных платформах, отличных - от amd64, sparc64 и ppc64. + *) Исправление: nginx не запускался на 64-битных платформах, отличных от + amd64, sparc64 и ppc64. Изменения в nginx 0.4.6 06.10.2006 - *) Исправление: nginx не запускался на 64-битных платформах, отличных - от amd64, sparc64 и ppc64. - - *) Исправление: при запросе версии HTTP/1.1 nginx передавал ответ - chunk'ами, если длина ответа в методе + *) Исправление: nginx не запускался на 64-битных платформах, отличных от + amd64, sparc64 и ppc64. + + *) Исправление: при запросе версии HTTP/1.1 nginx передавал ответ + chunk'ами, если длина ответа в методе $r->headers_out("Content-Length", ...) была задана текстовой строкой. - *) Исправление: после перенаправления ошибки с помощью директивы - error_page любая директива модуля ngx_http_rewrite_module возвращала + *) Исправление: после перенаправления ошибки с помощью директивы + error_page любая директива модуля ngx_http_rewrite_module возвращала эту ошибку; ошибка появилась в 0.4.4. Изменения в nginx 0.4.5 02.10.2006 - *) Исправление: nginx не собирался на Linux и Solaris; ошибка появилась + *) Исправление: nginx не собирался на Linux и Solaris; ошибка появилась в 0.4.4. @@ -3387,33 +3413,33 @@ *) Добавление: директива include поддерживает маску "*". Спасибо Jonathan Dance. - *) Исправление: директива return всегда изменяла код ответа, + *) Исправление: директива return всегда изменяла код ответа, перенаправленного директивой error_page. - *) Исправление: происходил segmentation fault, если в методе PUT + *) Исправление: происходил segmentation fault, если в методе PUT передавалось тело нулевой длины. - *) Исправление: при использовании переменных в директиве proxy_redirect + *) Исправление: при использовании переменных в директиве proxy_redirect редирект изменялся неверно. Изменения в nginx 0.4.3 26.09.2006 - *) Изменение: ошибку 499 теперь нельзя перенаправить с помощью - директивы error_page. + *) Изменение: ошибку 499 теперь нельзя перенаправить с помощью директивы + error_page. *) Добавление: поддержка Solaris 10 event ports. *) Добавление: модуль ngx_http_browser_module. - *) Исправление: при перенаправлении ошибки 400 проксированному серверу + *) Исправление: при перенаправлении ошибки 400 проксированному серверу помощью директивы error_page мог произойти segmentation fault. - *) Исправление: происходил segmentation fault, если в директиве - proxy_pass использовался unix domain сокет; ошибка появилась в + *) Исправление: происходил segmentation fault, если в директиве + proxy_pass использовался unix domain сокет; ошибка появилась в 0.3.47. - *) Исправление: SSI не работал с ответами memcached и + *) Исправление: SSI не работал с ответами memcached и небуферизированными проксированными ответами. *) Изменение: обход ошибки PAUSE hardware capability в Sun Studio. @@ -3421,7 +3447,7 @@ Изменения в nginx 0.4.2 14.09.2006 - *) Исправление: убрана поддержка флага O_NOATIME на Linux; ошибка + *) Исправление: убрана поддержка флага O_NOATIME на Linux; ошибка появилась в 0.4.1. @@ -3430,34 +3456,34 @@ *) Исправление: совместимость с DragonFlyBSD. Спасибо Павлу Назарову. - *) Изменение: обход ошибки в sendfile() в 64-битном Linux при передаче + *) Изменение: обход ошибки в sendfile() в 64-битном Linux при передаче файлов больше 2G. - *) Добавление: теперь на Linux nginx для статических запросов - использует флаг O_NOATIME. + *) Добавление: теперь на Linux nginx для статических запросов использует + флаг O_NOATIME. Спасибо Yusuf Goolamabbas. Изменения в nginx 0.4.0 30.08.2006 - *) Изменение во внутреннем API: инициализация модулей HTTP перенесена - из фазы init module в фазу HTTP postconfiguration. - - *) Изменение: теперь тело запроса в модуле ngx_http_perl_module не - считывается заранее: нужно явно инициировать чтение с помощью метода + *) Изменение во внутреннем API: инициализация модулей HTTP перенесена из + фазы init module в фазу HTTP postconfiguration. + + *) Изменение: теперь тело запроса в модуле ngx_http_perl_module не + считывается заранее: нужно явно инициировать чтение с помощью метода $r->has_request_body. - *) Добавление: модуль ngx_http_perl_module поддерживает код возврата + *) Добавление: модуль ngx_http_perl_module поддерживает код возврата DECLINED. - *) Добавление: модуль ngx_http_dav_module поддерживает входящую строку + *) Добавление: модуль ngx_http_dav_module поддерживает входящую строку заголовка "Date" для метода PUT. *) Добавление: директива ssi работает внутри блока if. - *) Исправление: происходил segmentation fault, если в директиве index - использовалась переменные и при этом первое имя индексного файла - было без переменных; ошибка появилась в 0.1.29. + *) Исправление: происходил segmentation fault, если в директиве index + использовалась переменные и при этом первое имя индексного файла было + без переменных; ошибка появилась в 0.1.29. Изменения в nginx 0.3.61 28.08.2006 @@ -3468,26 +3494,26 @@ *) Добавление: директива recursive_error_pages. - *) Исправление: директива rewrite возвращала неправильный редирект, - если редирект включал в себя выделенные закодированные символы из + *) Исправление: директива rewrite возвращала неправильный редирект, если + редирект включал в себя выделенные закодированные символы из оригинального URI. Изменения в nginx 0.3.60 18.08.2006 - *) Исправление: во время перенаправления ошибки рабочий процесс мог + *) Исправление: во время перенаправления ошибки рабочий процесс мог зациклиться; ошибка появилась в 0.3.59. Изменения в nginx 0.3.59 16.08.2006 - *) Добавление: теперь можно делать несколько перенаправлений через + *) Добавление: теперь можно делать несколько перенаправлений через директиву error_page. *) Исправление: директива dav_access не поддерживала три параметра. - *) Исправление: директива error_page не изменяла строку "Content-Type" - после перенаправления с помощью "X-Accel-Redirect"; ошибка появилась + *) Исправление: директива error_page не изменяла строку "Content-Type" + после перенаправления с помощью "X-Accel-Redirect"; ошибка появилась в 0.3.58. @@ -3495,15 +3521,15 @@ *) Добавление: директива error_page поддерживает переменные. - *) Изменение: теперь на Linux используется интерфейс procfs вместо + *) Изменение: теперь на Linux используется интерфейс procfs вместо sysctl. - *) Изменение: теперь при использовании "X-Accel-Redirect" строка + *) Изменение: теперь при использовании "X-Accel-Redirect" строка "Content-Type" наследуется из первоначального ответа. *) Исправление: директива error_page не перенаправляла ошибку 413. - *) Исправление: завершающий "?" не удалял старые аргументы, если в + *) Исправление: завершающий "?" не удалял старые аргументы, если в переписанном URI не было новых аргументов. *) Исправление: nginx не запускался на 64-битной FreeBSD 7.0-CURRENT. @@ -3516,10 +3542,10 @@ *) Исправление: в операторе "!-e" в директиве if. Спасибо Андриану Буданцову. - *) Исправление: при проверке клиентского сертификата nginx не передавал + *) Исправление: при проверке клиентского сертификата nginx не передавал клиенту информацию о требуемых сертификатах. - *) Исправление: переменная $document_root не поддерживала переменные в + *) Исправление: переменная $document_root не поддерживала переменные в директиве root. @@ -3527,12 +3553,12 @@ *) Добавление: директива dav_access. - *) Добавление: директива if поддерживает операторы "-d", "!-d", "-e", + *) Добавление: директива if поддерживает операторы "-d", "!-d", "-e", "!-e", "-x" и "!-x". - *) Исправление: при записи в access_log некоторых передаваемых клиенту - строк заголовков происходил segmentation fault, если запрос - возвращал редирект. + *) Исправление: при записи в access_log некоторых передаваемых клиенту + строк заголовков происходил segmentation fault, если запрос возвращал + редирект. Изменения в nginx 0.3.55 28.07.2006 @@ -3543,22 +3569,22 @@ *) Добавление: скрипт unicode2nginx добавлен в contrib. - *) Исправление: если root был задан только переменной, то корень + *) Исправление: если root был задан только переменной, то корень задавался относительно префикса сервера. - *) Исправление: если в запросе был "//" или "/.", и после этого - закодированные символы в виде "%XX", то проксируемый запрос + *) Исправление: если в запросе был "//" или "/.", и после этого + закодированные символы в виде "%XX", то проксируемый запрос передавался незакодированным. - *) Исправление: метод $r->header_in("Cookie") модуля - ngx_http_perl_module теперь возвращает все строки "Cookie" в + *) Исправление: метод $r->header_in("Cookie") модуля + ngx_http_perl_module теперь возвращает все строки "Cookie" в заголовке запроса. - *) Исправление: происходил segmentation fault, если использовался + *) Исправление: происходил segmentation fault, если использовался "client_body_in_file_only on" и делался переход к следующему бэкенду. - *) Исправление: при некоторых условиях во время переконфигурации коды - символов внутри директивы charset_map могли считаться неверными; + *) Исправление: при некоторых условиях во время переконфигурации коды + символов внутри директивы charset_map могли считаться неверными; ошибка появилась в 0.3.50. @@ -3566,116 +3592,116 @@ *) Добавление: nginx теперь записывает в лог информацию о подзапросах. - *) Добавление: директивы proxy_next_upstream, fastcgi_next_upstream и + *) Добавление: директивы proxy_next_upstream, fastcgi_next_upstream и memcached_next_upstream поддерживают параметр off. - *) Добавление: директива debug_connection поддерживает запись адресов в + *) Добавление: директива debug_connection поддерживает запись адресов в формате CIDR. - *) Исправление: при перекодировании ответа проксированного сервера или - сервера FastCGI в UTF-8 или наоборот ответ мог передаваться не + *) Исправление: при перекодировании ответа проксированного сервера или + сервера FastCGI в UTF-8 или наоборот ответ мог передаваться не полностью. - *) Исправление: переменная $upstream_response_time содержала время + *) Исправление: переменная $upstream_response_time содержала время только первого обращения к бэкенду. - *) Исправление: nginx не собирался на платформе amd64; ошибка появилась + *) Исправление: nginx не собирался на платформе amd64; ошибка появилась в 0.3.53. Изменения в nginx 0.3.53 07.07.2006 - *) Изменение: директива add_header добавляет строки в ответы с кодом + *) Изменение: директива add_header добавляет строки в ответы с кодом 204, 301 и 302. - *) Добавление: директива server в блоке upstream поддерживает параметр + *) Добавление: директива server в блоке upstream поддерживает параметр weight. *) Добавление: директива server_name поддерживает маску "*". *) Добавление: nginx поддерживает тело запроса больше 2G. - *) Исправление: если при использовании "satisfy_any on" клиент успешно - проходил аутентификацию, в лог всё равно записалоcь сообщение - "access forbidden by rule". - - *) Исправление: метод PUT мог ошибочно не создать файл и вернуть код + *) Исправление: если при использовании "satisfy_any on" клиент успешно + проходил аутентификацию, в лог всё равно записалоcь сообщение "access + forbidden by rule". + + *) Исправление: метод PUT мог ошибочно не создать файл и вернуть код 409. - *) Исправление: если во время аутентификации IMAP/POP3 бэкенд возвращал + *) Исправление: если во время аутентификации IMAP/POP3 бэкенд возвращал ошибку, nginx продолжал проксирование. Изменения в nginx 0.3.52 03.07.2006 - *) Изменение: восстановлено поведение модуля ngx_http_index_module для - запросов "POST /": как в версии до 0.3.40, модуль теперь не выдаёт + *) Изменение: восстановлено поведение модуля ngx_http_index_module для + запросов "POST /": как в версии до 0.3.40, модуль теперь не выдаёт ошибку 405. - *) Исправление: при использовании ограничения скорости рабочий процесс + *) Исправление: при использовании ограничения скорости рабочий процесс мог зациклиться; ошибка появилась в 0.3.37. - *) Исправление: модуль ngx_http_charset_module записывал в лог ошибку - "unknown charset", даже если перекодировка не требовалась; ошибка + *) Исправление: модуль ngx_http_charset_module записывал в лог ошибку + "unknown charset", даже если перекодировка не требовалась; ошибка появилась в 0.3.50. - *) Исправление: если в результате запроса PUT возвращался код 409, то + *) Исправление: если в результате запроса PUT возвращался код 409, то временный файл не удалялся. Изменения в nginx 0.3.51 30.06.2006 - *) Исправление: при некоторых условиях в SSI мог пропадать символы "<"; + *) Исправление: при некоторых условиях в SSI мог пропадать символы "<"; ошибка появилась в 0.3.50. Изменения в nginx 0.3.50 28.06.2006 - *) Изменение: директивы proxy_redirect_errors и fastcgi_redirect_errors - переименованы соответственно в proxy_intercept_errors и + *) Изменение: директивы proxy_redirect_errors и fastcgi_redirect_errors + переименованы соответственно в proxy_intercept_errors и fastcgi_intercept_errors. - *) Добавление: модуль ngx_http_charset_module поддерживает + *) Добавление: модуль ngx_http_charset_module поддерживает перекодирование из однобайтных кодировок в UTF-8 и обратно. - *) Добавление: в режиме прокси и FastCGI поддерживается строка - заголовка "X-Accel-Charset" в ответе бэкенда. - - *) Исправление: символ "\" в парах "\"" и "\'" в SSI командах убирался, + *) Добавление: в режиме прокси и FastCGI поддерживается строка заголовка + "X-Accel-Charset" в ответе бэкенда. + + *) Исправление: символ "\" в парах "\"" и "\'" в SSI командах убирался, только если также использовался символ "$". - *) Исправление: при некоторых условиях в SSI после вставки могла быть + *) Исправление: при некоторых условиях в SSI после вставки могла быть добавлена строка "<!--". - *) Исправление: если в заголовке ответа была строка - "Content-Length: 0", то при использовании небуферизированного - проксировании не закрывалось соединение с клиентом. + *) Исправление: если в заголовке ответа была строка "Content-Length: 0", + то при использовании небуферизированного проксировании не закрывалось + соединение с клиентом. Изменения в nginx 0.3.49 31.05.2006 *) Исправление: в директиве set. - *) Исправление: при включении в ssi двух и более подзапросов, - обрабатываемых через FastCGI, вместо вывода второго и остальных + *) Исправление: при включении в ssi двух и более подзапросов, + обрабатываемых через FastCGI, вместо вывода второго и остальных подзапросов в ответ включался вывод первого подзапроса. Изменения в nginx 0.3.48 29.05.2006 - *) Изменение: теперь модуль ngx_http_charset_module работает для + *) Изменение: теперь модуль ngx_http_charset_module работает для подзапросов, в ответах которых нет строки заголовка "Content-Type". - *) Исправление: если в директиве proxy_pass не было URI, то директива - "proxy_redirect default" добавляла в переписанный редирект в начало + *) Исправление: если в директиве proxy_pass не было URI, то директива + "proxy_redirect default" добавляла в переписанный редирект в начало лишний слэш. - *) Исправление: внутренний редирект всегда превращал любой HTTP-метод в - GET, теперь это делается только для редиректов, выполняемых с - помощью X-Accel-Redirect, и у которых метод не равен HEAD; ошибка - появилась в 0.3.42. - - *) Исправление: модуль ngx_http_perl_module не собирался, если перл был + *) Исправление: внутренний редирект всегда превращал любой HTTP-метод в + GET, теперь это делается только для редиректов, выполняемых с помощью + X-Accel-Redirect, и у которых метод не равен HEAD; ошибка появилась в + 0.3.42. + + *) Исправление: модуль ngx_http_perl_module не собирался, если перл был с поддержкой потоков; ошибка появилась в 0.3.46. @@ -3683,42 +3709,42 @@ *) Добавление: директива upstream. - *) Изменение: символ "\" в парах "\"" и "\'" в SSI командах теперь + *) Изменение: символ "\" в парах "\"" и "\'" в SSI командах теперь всегда убирается. Изменения в nginx 0.3.46 11.05.2006 - *) Добавление: директивы proxy_hide_header, proxy_pass_header, + *) Добавление: директивы proxy_hide_header, proxy_pass_header, fastcgi_hide_header и fastcgi_pass_header. - *) Изменение: директивы proxy_pass_x_powered_by, fastcgi_x_powered_by и + *) Изменение: директивы proxy_pass_x_powered_by, fastcgi_x_powered_by и proxy_pass_server упразднены. - *) Добавление: в режиме прокси поддерживается строка заголовка + *) Добавление: в режиме прокси поддерживается строка заголовка "X-Accel-Buffering" в ответе бэкенда. - *) Исправление: ошибок и утечек памяти при переконфигурации в модуле + *) Исправление: ошибок и утечек памяти при переконфигурации в модуле ngx_http_perl_module. Изменения в nginx 0.3.45 06.05.2006 - *) Добавление: директивы ssl_verify_client, ssl_verify_depth и + *) Добавление: директивы ssl_verify_client, ssl_verify_depth и ssl_client_certificate. - *) Изменение: теперь переменная $request_method возвращает метод только + *) Изменение: теперь переменная $request_method возвращает метод только основного запроса. - *) Изменение: в таблице перекодировки koi-win изменены коды символа + *) Изменение: в таблице перекодировки koi-win изменены коды символа °. - *) Добавление: в таблицу перекодировки koi-win добавлены символы евро и + *) Добавление: в таблицу перекодировки koi-win добавлены символы евро и номера. - *) Исправление: если nginx распределял запросы на несколько машин, то - при падении одной из них запросы, предназначенные для этой машины, - перенаправлялись только на одну машину вместо того, чтобы равномерно + *) Исправление: если nginx распределял запросы на несколько машин, то + при падении одной из них запросы, предназначенные для этой машины, + перенаправлялись только на одну машину вместо того, чтобы равномерно распределяться между остальными. @@ -3726,7 +3752,7 @@ *) Добавление: параметр wait в команде SSI include. - *) Добавление: в таблицу перекодировки koi-win добавлены украинские и + *) Добавление: в таблицу перекодировки koi-win добавлены украинские и белорусские символы. *) Исправление: в SSI. @@ -3741,15 +3767,15 @@ *) Добавление: параметр bind в директиве listen в IMAP/POP3 прокси. - *) Исправление: ошибки при использовании в директиве rewrite одного и + *) Исправление: ошибки при использовании в директиве rewrite одного и того же выделения более одного раза. - *) Исправление: в лог не записывались переменные - $sent_http_content_type, $sent_http_content_length, - $sent_http_last_modified, $sent_http_connection, + *) Исправление: в лог не записывались переменные + $sent_http_content_type, $sent_http_content_length, + $sent_http_last_modified, $sent_http_connection, $sent_http_keep_alive и $sent_http_transfer_encoding. - *) Исправление: переменная $sent_http_cache_control возвращала + *) Исправление: переменная $sent_http_cache_control возвращала содержимое только одной строки "Cache-Control" в заголовке ответа. @@ -3757,13 +3783,13 @@ *) Добавление: ключ -v. - *) Исправление: при включении в SSI удалённых подзапросов мог произойти + *) Исправление: при включении в SSI удалённых подзапросов мог произойти segmentation fault. *) Исправление: в обработке FastCGI. - *) Исправление: если путь к перловым модулям не был указан с помощью - --with-perl_modules_path=PATH или директивы perl_modules, то на + *) Исправление: если путь к перловым модулям не был указан с помощью + --with-perl_modules_path=PATH или директивы perl_modules, то на старте происходил segmentation fault. @@ -3778,21 +3804,21 @@ Изменения в nginx 0.3.39 17.04.2006 - *) Добавление: директива uninitialized_variable_warn; уровень - логгирования сообщения о неинициализированной переменной понижен с + *) Добавление: директива uninitialized_variable_warn; уровень + логгирования сообщения о неинициализированной переменной понижен с уровня alert на warn. *) Добавление: директива override_charset. - *) Изменение: при использовании неизвестной переменной в SSI-командах - echo и if expr='$name' теперь не записывается в лог сообщение о + *) Изменение: при использовании неизвестной переменной в SSI-командах + echo и if expr='$name' теперь не записывается в лог сообщение о неизвестной переменной. - *) Исправление: счётчик активных соединений рос при превышении лимита - соединений, заданного директивой worker_connections; ошибка - появилась в 0.2.0. - - *) Исправление: при некоторых условия ограничение скорости соединения + *) Исправление: счётчик активных соединений рос при превышении лимита + соединений, заданного директивой worker_connections; ошибка появилась + в 0.2.0. + + *) Исправление: при некоторых условия ограничение скорости соединения могло не работать; ошибка появилась в 0.3.38. @@ -3803,20 +3829,20 @@ *) Изменение: оптимизация модуля ngx_http_perl_module. Спасибо Сергею Скворцову. - *) Добавление: модуль ngx_http_perl_module поддерживает метод + *) Добавление: модуль ngx_http_perl_module поддерживает метод $r->request_body_file. *) Добавление: директива client_body_in_file_only. - *) Изменение: теперь при переполнении диска nginx пытается писать + *) Изменение: теперь при переполнении диска nginx пытается писать access_log'и только раз в секунду. Спасибо Антону Южанинову и Максиму Дунину. - *) Исправление: теперь директива limit_rate точнее ограничивает - скорость при значениях больше 100 Kbyte/s. + *) Исправление: теперь директива limit_rate точнее ограничивает скорость + при значениях больше 100 Kbyte/s. Спасибо ForJest. - *) Исправление: IMAP/POP3 прокси теперь передаёт серверу авторизации + *) Исправление: IMAP/POP3 прокси теперь передаёт серверу авторизации символы "\r" и "\n" в логине и пароле в закодированном виде. Спасибо Максиму Дунину. @@ -3825,10 +3851,10 @@ *) Добавление: директива limit_except. - *) Добавление: директива if поддерживает операторы "!~", "!~*", "-f" и + *) Добавление: директива if поддерживает операторы "!~", "!~*", "-f" и "!-f". - *) Добавление: модуль ngx_http_perl_module поддерживает метод + *) Добавление: модуль ngx_http_perl_module поддерживает метод $r->request_body. *) Исправление: в модуле ngx_http_addition_filter_module. @@ -3838,37 +3864,37 @@ *) Добавление: модуль ngx_http_addition_filter_module. - *) Добавление: директивы proxy_pass и fastcgi_pass можно использовать + *) Добавление: директивы proxy_pass и fastcgi_pass можно использовать внутри блока if. - *) Добавление: директивы proxy_ignore_client_abort и + *) Добавление: директивы proxy_ignore_client_abort и fastcgi_ignore_client_abort. *) Добавление: переменная $request_completion. - *) Добавление: модуль ngx_http_perl_module поддерживает методы + *) Добавление: модуль ngx_http_perl_module поддерживает методы $r->request_method и $r->remote_addr. *) Добавление: модуль ngx_http_ssi_module поддерживает команду elif. - *) Исправление: строка "\/" в начале выражения команды if модуля + *) Исправление: строка "\/" в начале выражения команды if модуля ngx_http_ssi_module воспринималась неверно. - *) Исправление: в использовании регулярных выражениях в команде if + *) Исправление: в использовании регулярных выражениях в команде if модуля ngx_http_ssi_module. - *) Исправление: при задании относительного пути в директивах - client_body_temp_path, proxy_temp_path, fastcgi_temp_path и - perl_modules использовался каталог относительно текущего каталога, а + *) Исправление: при задании относительного пути в директивах + client_body_temp_path, proxy_temp_path, fastcgi_temp_path и + perl_modules использовался каталог относительно текущего каталога, а не относительно префикса сервера. Изменения в nginx 0.3.35 22.03.2006 - *) Исправление: accept-фильтр и TCP_DEFER_ACCEPT устанавливались только + *) Исправление: accept-фильтр и TCP_DEFER_ACCEPT устанавливались только для первой директивы listen; ошибка появилась в 0.3.31. - *) Исправление: в директиве proxy_pass без URI при использовании в + *) Исправление: в директиве proxy_pass без URI при использовании в подзапросе. @@ -3879,10 +3905,10 @@ Изменения в nginx 0.3.33 15.03.2006 - *) Добавление: параметр http_503 в директивах proxy_next_upstream или + *) Добавление: параметр http_503 в директивах proxy_next_upstream или fastcgi_next_upstream. - *) Исправление: ngx_http_perl_module не работал со встроенным в + *) Исправление: ngx_http_perl_module не работал со встроенным в конфигурационный файл кодом, если он не начинался сразу же с "sub". *) Исправление: в директиве post_action. @@ -3890,59 +3916,58 @@ Изменения в nginx 0.3.32 11.03.2006 - *) Исправление: удаление отладочного логгирования на старте и при + *) Исправление: удаление отладочного логгирования на старте и при переконфигурации; ошибка появилась в 0.3.31. Изменения в nginx 0.3.31 10.03.2006 - *) Изменение: теперь nginx передаёт неверные ответы проксированного + *) Изменение: теперь nginx передаёт неверные ответы проксированного бэкенда. *) Добавление: директивы listen поддерживают адрес в виде "*:порт". *) Добавление: поддержка EVFILER_TIMER в MacOSX 10.4. - *) Изменение: обход ошибки обработки миллисекундных таймаутов kqueue в + *) Изменение: обход ошибки обработки миллисекундных таймаутов kqueue в 64-битном ядре MacOSX. Спасибо Андрею Нигматулину. - *) Исправление: если внутри одного сервера описаны несколько директив - listen, слушающих на разных адресах, то имена серверов вида - "*.domain.tld" работали только для первого адреса; ошибка появилась - в 0.3.18. - - *) Исправление: при использовании протокола HTTPS в директиве - proxy_pass не передавались запросы с телом, записанным во временный - файл. + *) Исправление: если внутри одного сервера описаны несколько директив + listen, слушающих на разных адресах, то имена серверов вида + "*.domain.tld" работали только для первого адреса; ошибка появилась в + 0.3.18. + + *) Исправление: при использовании протокола HTTPS в директиве proxy_pass + не передавались запросы с телом, записанным во временный файл. *) Исправление: совместимость с perl 5.8.8. Изменения в nginx 0.3.30 22.02.2006 - *) Изменение: уровень записи в лог ошибки ECONNABORTED изменён на error + *) Изменение: уровень записи в лог ошибки ECONNABORTED изменён на error с уровня crit. - *) Исправление: модуль ngx_http_perl_module не собирался без модуля + *) Исправление: модуль ngx_http_perl_module не собирался без модуля ngx_http_ssi_filter_module. - *) Исправление: nginx не собирался на i386 платформе, если - использовался PIC; ошибка появилась в 0.3.27. + *) Исправление: nginx не собирался на i386 платформе, если использовался + PIC; ошибка появилась в 0.3.27. Изменения в nginx 0.3.29 20.02.2006 - *) Добавление: теперь nginx использует меньше памяти, если PHP в режиме + *) Добавление: теперь nginx использует меньше памяти, если PHP в режиме FastCGI передаёт большое количество предупреждений перед ответом. - *) Исправление: в ответах 204 для запросов версии HTTP/1.1 выдавалась + *) Исправление: в ответах 204 для запросов версии HTTP/1.1 выдавалась строка заголовка "Transfer-Encoding: chunked". - *) Исправление: nginx возвращал 502 код ответа, если FastCGI сервер + *) Исправление: nginx возвращал 502 код ответа, если FastCGI сервер передавал полные строки заголовка ответа в отдельных FastCGI записях. - *) Исправление: если в директиве post_action был указан проксируемый + *) Исправление: если в директиве post_action был указан проксируемый URI, то он выполнялся только после успешного завершения запроса. @@ -3952,56 +3977,56 @@ *) Добавление: параметр конфигурации --with-cpu-opt=ppc64. - *) Исправление: при некоторых условиях проксированное соединение с + *) Исправление: при некоторых условиях проксированное соединение с клиентом завершалось преждевременно. Спасибо Владимиру Шутову. - *) Исправление: строка заголовка "X-Accel-Limit-Rate" не учитывалась - для запросов, перенаправленных с помощью строки "X-Accel-Redirect". - - *) Исправление: директива post_action работала только после успешного + *) Исправление: строка заголовка "X-Accel-Limit-Rate" не учитывалась для + запросов, перенаправленных с помощью строки "X-Accel-Redirect". + + *) Исправление: директива post_action работала только после успешного завершения запроса. - *) Исправление: тело проксированного ответа, создаваемого директивой + *) Исправление: тело проксированного ответа, создаваемого директивой post_action, передавалось клиенту. Изменения в nginx 0.3.27 08.02.2006 - *) Изменение: директивы variables_hash_max_size и + *) Изменение: директивы variables_hash_max_size и variables_hash_bucket_size. - *) Добавление: переменная $body_bytes_sent доступна не только в + *) Добавление: переменная $body_bytes_sent доступна не только в директиве log_format. *) Добавление: переменные $ssl_protocol и $ssl_cipher. - *) Добавление: определение размера строки кэша распространённых + *) Добавление: определение размера строки кэша распространённых процессоров при старте. - *) Добавление: директива accept_mutex теперь поддерживается посредством + *) Добавление: директива accept_mutex теперь поддерживается посредством fcntl(2) на платформах, отличных от i386, amd64, sparc64 и ppc. - *) Добавление: директива lock_file и параметр автоконфигурации + *) Добавление: директива lock_file и параметр автоконфигурации --with-lock-path=PATH. - *) Исправление: при использовании протокола HTTPS в директиве - proxy_pass не передавались запросы с телом. + *) Исправление: при использовании протокола HTTPS в директиве proxy_pass + не передавались запросы с телом. Изменения в nginx 0.3.26 03.02.2006 - *) Изменение: директива optimize_host_names переименована в + *) Изменение: директива optimize_host_names переименована в optimize_server_names. - *) Исправление: при проксировании подзапроса в SSI бэкенду передавался + *) Исправление: при проксировании подзапроса в SSI бэкенду передавался URI основного запроса, если в директиве proxy_pass отсутствовал URI. Изменения в nginx 0.3.25 01.02.2006 - *) Исправление: при неверной конфигурации на старте или во время - переконфигурации происходил segmentation fault; ошибка появилась в + *) Исправление: при неверной конфигурации на старте или во время + переконфигурации происходил segmentation fault; ошибка появилась в 0.3.24. @@ -4009,17 +4034,17 @@ *) Изменение: обход ошибки в kqueue во FreeBSD. - *) Исправление: ответ, создаваемый директивой post_action, теперь не + *) Исправление: ответ, создаваемый директивой post_action, теперь не передаётся клиенту. - *) Исправление: при использовании большого количества лог-файлов + *) Исправление: при использовании большого количества лог-файлов происходила утечка памяти. - *) Исправление: внутри одного location работала только первая директива + *) Исправление: внутри одного location работала только первая директива proxy_redirect. - *) Исправление: на 64-битных платформах при старте мог произойти - segmentation fault, если использовалось большое количество имён в + *) Исправление: на 64-битных платформах при старте мог произойти + segmentation fault, если использовалось большое количество имён в директивах server_name; ошибка появилась в 0.3.18. @@ -4027,22 +4052,22 @@ *) Добавление: директива optimize_host_names. - *) Исправление: ошибки при использовании переменных в директивах path и + *) Исправление: ошибки при использовании переменных в директивах path и alias. - *) Исправление: модуль ngx_http_perl_module неправильно собирался на + *) Исправление: модуль ngx_http_perl_module неправильно собирался на Linux и Solaris. Изменения в nginx 0.3.22 17.01.2006 - *) Добавление: модуль ngx_http_perl_module поддерживает методы $r->args + *) Добавление: модуль ngx_http_perl_module поддерживает методы $r->args и $r->unescape. - *) Добавление: метод $r->query_string в модуле ngx_http_perl_module + *) Добавление: метод $r->query_string в модуле ngx_http_perl_module упразднён. - *) Исправление: если в директиве valid_referers указаны только none или + *) Исправление: если в директиве valid_referers указаны только none или blocked, то происходил segmentation fault; ошибка появилась в 0.3.18. @@ -4050,7 +4075,7 @@ *) Добавление: модуль ngx_http_perl_module. - *) Изменение: директива valid_referers разрешает использовать рефереры + *) Изменение: директива valid_referers разрешает использовать рефереры совсем без URI. @@ -4058,7 +4083,7 @@ *) Исправление: ошибки в обработке SSI. - *) Исправление: модуль ngx_http_memcached_module не поддерживал ключи в + *) Исправление: модуль ngx_http_memcached_module не поддерживал ключи в виде /uri?args. @@ -4073,48 +4098,48 @@ Изменения в nginx 0.3.18 26.12.2005 - *) Добавление: директива server_names поддерживает имена вида + *) Добавление: директива server_names поддерживает имена вида ".domain.tld". - *) Добавление: директива server_names использует хэш для имён вида + *) Добавление: директива server_names использует хэш для имён вида "*.domain.tld" и более эффективный хэш для обычных имён. - *) Изменение: директивы server_names_hash_max_size и + *) Изменение: директивы server_names_hash_max_size и server_names_hash_bucket_size. - *) Изменение: директивы server_names_hash и server_names_hash_threshold + *) Изменение: директивы server_names_hash и server_names_hash_threshold упразднены. *) Добавление: директива valid_referers использует хэш для имён сайтов. - *) Изменение: теперь директива valid_referers проверяет только имена + *) Изменение: теперь директива valid_referers проверяет только имена сайтов без учёта URI. - *) Исправление: некоторые имена вида ".domain.tld" неверно + *) Исправление: некоторые имена вида ".domain.tld" неверно обрабатывались модулем ngx_http_map_module. - *) Исправление: если конфигурационного файла не было, то происходил + *) Исправление: если конфигурационного файла не было, то происходил segmentation fault; ошибка появилась в 0.3.12. - *) Исправление: на 64-битных платформах при старте мог произойти + *) Исправление: на 64-битных платформах при старте мог произойти segmentation fault; ошибка появилась в 0.3.16. Изменения в nginx 0.3.17 18.12.2005 - *) Изменение: на Linux configure теперь проверяет наличие epoll и + *) Изменение: на Linux configure теперь проверяет наличие epoll и sendfile64() в ядре. - *) Добавление: директива map поддерживает доменные имена в формате + *) Добавление: директива map поддерживает доменные имена в формате ".domain.tld". - *) Исправление: во время SSL handshake не иcпользовались таймауты; + *) Исправление: во время SSL handshake не иcпользовались таймауты; ошибка появилась в 0.2.4. *) Исправление: в использовании протокола HTTPS в директиве proxy_pass. - *) Исправление: при использовании протокола HTTPS в директиве - proxy_pass по умолчанию использовался порт 80. + *) Исправление: при использовании протокола HTTPS в директиве proxy_pass + по умолчанию использовался порт 80. Изменения в nginx 0.3.16 16.12.2005 @@ -4127,17 +4152,17 @@ *) Добавление: директива worker_rlimit_core. - *) Изменение: при сборке компиляторами icc 8.1 и 9.0 с оптимизацией для + *) Изменение: при сборке компиляторами icc 8.1 и 9.0 с оптимизацией для Pentium 4 номер соединения в логах всегда был равен 1. - *) Исправление: команда config timefmt в SSI задавала неверный формат + *) Исправление: команда config timefmt в SSI задавала неверный формат времени. - *) Исправление: nginx не закрывал соединения с IMAP/POP3 бэкендом при + *) Исправление: nginx не закрывал соединения с IMAP/POP3 бэкендом при использовании SSL соединений; ошибка появилась в 0.3.13. Спасибо Rob Mueller. - *) Исправление: segmentation fault мог произойти во время SSL shutdown; + *) Исправление: segmentation fault мог произойти во время SSL shutdown; ошибка появилась в 0.3.13. @@ -4147,14 +4172,14 @@ *) Добавление: директива so_keepalive в IMAP/POP3 прокси. - *) Исправление: nginx теперь вызывает abort() при обнаружении - незакрытых соединений только при планом выходе и включённой - директиве debug_points. + *) Исправление: nginx теперь вызывает abort() при обнаружении незакрытых + соединений только при планом выходе и включённой директиве + debug_points. Изменения в nginx 0.3.14 05.12.2005 - *) Исправление: в ответе 304 передавалось тело ответа; ошибка появилась + *) Исправление: в ответе 304 передавалось тело ответа; ошибка появилась в 0.3.13. @@ -4162,69 +4187,69 @@ *) Добавление: IMAP/POP3 прокси поддерживает STARTTLS и STLS. - *) Исправление: IMAP/POP3 прокси не работала с методами select, poll и + *) Исправление: IMAP/POP3 прокси не работала с методами select, poll и /dev/poll. *) Исправление: ошибки в обработке SSI. - *) Исправление: sendfilev() в Solaris теперь не используется при + *) Исправление: sendfilev() в Solaris теперь не используется при передаче тела запроса FastCGI-серверу через unix domain сокет. - *) Исправление: директива auth_basic не запрещала аутентификацию; - ошибка появилась в 0.3.11. + *) Исправление: директива auth_basic не запрещала аутентификацию; ошибка + появилась в 0.3.11. Изменения в nginx 0.3.12 26.11.2005 - *) Безопасность: если nginx был собран с модулем - ngx_http_realip_module, то при использовании директивы "satisfy_any - on" директивы доступа и аутентификации не работали. Модуль - ngx_http_realip_module не собирался и не собирается по умолчанию. + *) Безопасность: если nginx был собран с модулем ngx_http_realip_module, + то при использовании директивы "satisfy_any on" директивы доступа и + аутентификации не работали. Модуль ngx_http_realip_module не + собирался и не собирается по умолчанию. *) Изменение: имя переменной "$time_gmt" изменено на "$time_local". - *) Изменение: директивы proxy_header_buffer_size и - fastcgi_header_buffer_size переименованы соответственно в + *) Изменение: директивы proxy_header_buffer_size и + fastcgi_header_buffer_size переименованы соответственно в proxy_buffer_size и fastcgi_buffer_size. *) Добавление: модуль ngx_http_memcached_module. *) Добавление: директива proxy_buffering. - *) Исправление: изменение в работе с accept mutex при использовании + *) Исправление: изменение в работе с accept mutex при использовании метода rtsig; ошибка появилась в 0.3.0. - *) Исправление: если клиент передал строку "Transfer-Encoding: chunked" + *) Исправление: если клиент передал строку "Transfer-Encoding: chunked" в заголовке запроса, то nginx теперь выдаёт ошибку 411. - *) Исправление: при наследовании директивы auth_basic с уровня http в - строке "WWW-Authenticate" заголовка ответа выводился realm без - текста "Basic realm". - - *) Исправление: если в директиве access_log был явно указан формат - combined, то в лог записывались пустые строки; ошибка появилась в + *) Исправление: при наследовании директивы auth_basic с уровня http в + строке "WWW-Authenticate" заголовка ответа выводился realm без текста + "Basic realm". + + *) Исправление: если в директиве access_log был явно указан формат + combined, то в лог записывались пустые строки; ошибка появилась в 0.3.8. - *) Исправление: nginx не работал на платформе sparc под любыми OS, - кроме Solaris. - - *) Исправление: в директиве if теперь не нужно разделять пробелом - строку в кавычках и закрывающую скобку. + *) Исправление: nginx не работал на платформе sparc под любыми OS, кроме + Solaris. + + *) Исправление: в директиве if теперь не нужно разделять пробелом строку + в кавычках и закрывающую скобку. Изменения в nginx 0.3.11 15.11.2005 - *) Исправление: nginx не передавал при проксировании тело запроса и + *) Исправление: nginx не передавал при проксировании тело запроса и строки заголовка клиента; ошибка появилась в 0.3.10. Изменения в nginx 0.3.10 15.11.2005 - *) Изменение: директива valid_referers и переменная $invalid_referer - перенесены из модуля ngx_http_rewrite_module в новый модуль + *) Изменение: директива valid_referers и переменная $invalid_referer + перенесены из модуля ngx_http_rewrite_module в новый модуль ngx_http_referer_module. - *) Изменение: имя переменной "$apache_bytes_sent" изменено на + *) Изменение: имя переменной "$apache_bytes_sent" изменено на "$body_bytes_sent". *) Добавление: переменные "$sent_http_...". @@ -4241,73 +4266,73 @@ *) Добавление: директива worker_cpu_affinity для Linux. - *) Исправление: директива rewrite не раскодировала символы в редиректах - в URI, теперь символы раскодируются, кроме символов %00-%25 и + *) Исправление: директива rewrite не раскодировала символы в редиректах + в URI, теперь символы раскодируются, кроме символов %00-%25 и %7F-%FF. *) Исправление: nginx не собирался компилятором icc 9.0. - *) Исправление: если для статического файла нулевого размера был + *) Исправление: если для статического файла нулевого размера был разрешён SSI, то ответ передавался неверно при кодировании chunk'ами. Изменения в nginx 0.3.9 10.11.2005 - *) Исправление: nginx считал небезопасными URI, в которых между двумя + *) Исправление: nginx считал небезопасными URI, в которых между двумя слэшами находилось два любых символа; ошибка появилась в 0.3.8. Изменения в nginx 0.3.8 09.11.2005 - *) Безопасность: nginx теперь проверят URI, полученные от бэкенда в - строке "X-Accel-Redirect" в заголовке ответа, или в SSI файле на + *) Безопасность: nginx теперь проверят URI, полученные от бэкенда в + строке "X-Accel-Redirect" в заголовке ответа, или в SSI файле на наличие путей "/../" и нулей. - *) Изменение: nginx теперь не воспринимает пустое имя как правильное в + *) Изменение: nginx теперь не воспринимает пустое имя как правильное в строке "Authorization" в заголовке запроса. - *) Добавление: директива ssl_session_timeout модулей - ngx_http_ssl_module и ngx_imap_ssl_module. - - *) Добавление: директива auth_http_header модуля + *) Добавление: директива ssl_session_timeout модулей ngx_http_ssl_module + и ngx_imap_ssl_module. + + *) Добавление: директива auth_http_header модуля ngx_imap_auth_http_module. *) Добавление: директива add_header. *) Добавление: модуль ngx_http_realip_module. - *) Добавление: новые переменные для использования в директиве - log_format: $bytes_sent, $apache_bytes_sent, $status, $time_gmt, - $uri, $request_time, $request_length, $upstream_status, - $upstream_response_time, $gzip_ratio, $uid_got, $uid_set, - $connection, $pipe и $msec. Параметры в виде "%name" скоро будут + *) Добавление: новые переменные для использования в директиве + log_format: $bytes_sent, $apache_bytes_sent, $status, $time_gmt, + $uri, $request_time, $request_length, $upstream_status, + $upstream_response_time, $gzip_ratio, $uid_got, $uid_set, + $connection, $pipe и $msec. Параметры в виде "%name" скоро будут упразднены. - *) Изменение: в директиве "if" ложными значениями переменных теперь + *) Изменение: в директиве "if" ложными значениями переменных теперь являются пустая строка "" и строки, начинающиеся на "0". - *) Исправление: при работает с проксированными или FastCGI-серверами - nginx мог оставлять открытыми соединения и временные файлы с + *) Исправление: при работает с проксированными или FastCGI-серверами + nginx мог оставлять открытыми соединения и временные файлы с запросами клиентов. - *) Исправление: рабочие процессы не сбрасывали буферизированные логи - при плавном выходе. - - *) Исправление: если URI запроса изменялось с помощью rewrite, а затем - запрос проксировался в location, заданном регулярным выражением, то + *) Исправление: рабочие процессы не сбрасывали буферизированные логи при + плавном выходе. + + *) Исправление: если URI запроса изменялось с помощью rewrite, а затем + запрос проксировался в location, заданном регулярным выражением, то бэкенду передавался неверный запрос; ошибка появилась в 0.2.6. - *) Исправление: директива expires не удаляла уже установленную строку + *) Исправление: директива expires не удаляла уже установленную строку заголовка "Expires". - *) Исправление: при использовании метода rtsig и нескольких рабочих + *) Исправление: при использовании метода rtsig и нескольких рабочих процессах nginx мог перестать принимать запросы. - *) Исправление: в SSI командах неверно обрабатывались строки "\"" и + *) Исправление: в SSI командах неверно обрабатывались строки "\"" и "\'". - *) Исправление: если ответ заканчивался сразу же после SSI команды, то - при использовании сжатия ответ передавался не до конца или не + *) Исправление: если ответ заканчивался сразу же после SSI команды, то + при использовании сжатия ответ передавался не до конца или не передавался вообще. @@ -4315,79 +4340,78 @@ *) Добавление: директива access_log поддерживает параметр buffer=. - *) Исправление: nginx не собирался на платформах, отличных от i386, + *) Исправление: nginx не собирался на платформах, отличных от i386, amd64, sparc и ppc; ошибка появилась в 0.3.2. Изменения в nginx 0.3.6 24.10.2005 - *) Изменение: IMAP/POP3 прокси теперь не передаёт серверу авторизации + *) Изменение: IMAP/POP3 прокси теперь не передаёт серверу авторизации пустой логин. - *) Добавление: директива log_format поддерживает переменные в виде + *) Добавление: директива log_format поддерживает переменные в виде $name. - *) Исправление: если хотя бы в одном сервере не было описано ни одной - директивы listen, то nginx не слушал на 80 порту; ошибка появилась в + *) Исправление: если хотя бы в одном сервере не было описано ни одной + директивы listen, то nginx не слушал на 80 порту; ошибка появилась в 0.3.3. - *) Исправление: если в директиве proxy_pass отсутствовал URI, то всегда + *) Исправление: если в директиве proxy_pass отсутствовал URI, то всегда использовался порт 80. Изменения в nginx 0.3.5 21.10.2005 - *) Исправление: если логин IMAP/POP3 менялся сервером авторизации, то + *) Исправление: если логин IMAP/POP3 менялся сервером авторизации, то мог произойти segmentation fault; ошибка появилась в 0.2.2. - *) Исправление: accept mutex не работал, все соединения обрабатывались + *) Исправление: accept mutex не работал, все соединения обрабатывались одним рабочим процессом; ошибка появилась в 0.3.3. - *) Исправление: при использовании метода rtsig и директивы + *) Исправление: при использовании метода rtsig и директивы timer_resolution не работали таймауты. Изменения в nginx 0.3.4 19.10.2005 - *) Исправление: nginx не собирался на Linux 2.4+ и MacOS X; ошибка + *) Исправление: nginx не собирался на Linux 2.4+ и MacOS X; ошибка появилась в 0.3.3. Изменения в nginx 0.3.3 19.10.2005 - *) Изменение: параметры "bl" и "af" директивы listen переименованы в + *) Изменение: параметры "bl" и "af" директивы listen переименованы в "backlog" и "accept_filter". *) Добавление: параметры "rcvbuf" и "sndbuf" в директиве listen. - *) Изменение: параметр лога $msec теперь не требует дополнительного + *) Изменение: параметр лога $msec теперь не требует дополнительного системного вызова gettimeofday(). *) Добавление: ключ -t теперь проверяет директивы listen. - *) Исправление: если в директиве listen был указан неверный адрес, то + *) Исправление: если в директиве listen был указан неверный адрес, то nginx после сигнала -HUP оставлял открытый сокет в состоянии CLOSED. - *) Исправление: для индексных файлов, содержащих в имени переменную, - мог неверно выставляться тип mime по умолчанию; ошибка появилась в - 0.3.0. + *) Исправление: для индексных файлов, содержащих в имени переменную, мог + неверно выставляться тип mime по умолчанию; ошибка появилась в 0.3.0. *) Добавление: директива timer_resolution. *) Добавление: параметр лога $upstream_response_time в миллисекундах. - *) Исправление: временный файл с телом запроса клиента теперь удаляется + *) Исправление: временный файл с телом запроса клиента теперь удаляется сразу после того, как клиенту передан заголовок ответа. *) Исправление: совместимость с OpenSSL 0.9.6. - *) Исправление: пути к файлам с SSL сертификатом и ключом не могли быть + *) Исправление: пути к файлам с SSL сертификатом и ключом не могли быть относительными. - *) Исправление: директива ssl_prefer_server_ciphers не работала для + *) Исправление: директива ssl_prefer_server_ciphers не работала для модуля ngx_imap_ssl_module. - *) Исправление: директива ssl_protocols позволяла задать только один + *) Исправление: директива ssl_protocols позволяла задать только один протокол. @@ -4395,84 +4419,81 @@ *) Добавление: поддержка Sun Studio 10 C compiler. - *) Добавление: директивы proxy_upstream_max_fails, - proxy_upstream_fail_timeout, fastcgi_upstream_max_fails и + *) Добавление: директивы proxy_upstream_max_fails, + proxy_upstream_fail_timeout, fastcgi_upstream_max_fails и fastcgi_upstream_fail_timeout. Изменения в nginx 0.3.1 10.10.2005 - *) Исправление: во время переполнения очереди сигналов при - использовании метода rtsig происходил segmentation fault; ошибка - появилась в 0.2.0. + *) Исправление: во время переполнения очереди сигналов при использовании + метода rtsig происходил segmentation fault; ошибка появилась в 0.2.0. *) Изменение: корректная обработка пар "\\", "\"", "\'" и "\$" в SSI. Изменения в nginx 0.3.0 07.10.2005 - *) Изменение: убрано десятидневное ограничение времени работы рабочего - процесса. Ограничение было введено из-за переполнения миллисекундных + *) Изменение: убрано десятидневное ограничение времени работы рабочего + процесса. Ограничение было введено из-за переполнения миллисекундных таймеров. Изменения в nginx 0.2.6 05.10.2005 - *) Изменение: с 60 до 10 секунд уменьшено время повторного обращения к + *) Изменение: с 60 до 10 секунд уменьшено время повторного обращения к бэкенду при использовании распределения нагрузки. - *) Изменение: директива proxy_pass_unparsed_uri упразднена, - оригинальный запрос теперь передаётся, если в директиве proxy_pass - отсутствует URI. - - *) Добавление: директива error_page поддерживает редиректы и позволяет + *) Изменение: директива proxy_pass_unparsed_uri упразднена, оригинальный + запрос теперь передаётся, если в директиве proxy_pass отсутствует + URI. + + *) Добавление: директива error_page поддерживает редиректы и позволяет более гибко менять код ошибки. - *) Изменение: в проксированных подзапросах теперь игнорируется + *) Изменение: в проксированных подзапросах теперь игнорируется переданный charset. - *) Исправление: если после изменения URI в блоке if для запроса не - находилась новая конфигурация, то правила модуля + *) Исправление: если после изменения URI в блоке if для запроса не + находилась новая конфигурация, то правила модуля ngx_http_rewrite_module выполнялись снова. - *) Исправление: если директива set устанавливала переменную модуля - ngx_http_geo_module в какой-либо части конфигурации, то эта - переменная не была доступна в других частях конфигурации и - выдавалась ошибка "using uninitialized variable"; ошибка появилась в - 0.2.2. + *) Исправление: если директива set устанавливала переменную модуля + ngx_http_geo_module в какой-либо части конфигурации, то эта + переменная не была доступна в других частях конфигурации и выдавалась + ошибка "using uninitialized variable"; ошибка появилась в 0.2.2. Изменения в nginx 0.2.5 04.10.2005 - *) Изменение: дублирующее значение переменной модуля - ngx_http_geo_module теперь выдаёт предупреждение и изменяет старое - значение. + *) Изменение: дублирующее значение переменной модуля ngx_http_geo_module + теперь выдаёт предупреждение и изменяет старое значение. *) Добавление: модуль ngx_http_ssi_module поддерживает команду set. - *) Добавление: модуль ngx_http_ssi_module поддерживает параметр file в + *) Добавление: модуль ngx_http_ssi_module поддерживает параметр file в команде include. - *) Добавление: модуль ngx_http_ssi_module поддерживает подстановку + *) Добавление: модуль ngx_http_ssi_module поддерживает подстановку значений переменных в выражениях команды if. Изменения в nginx 0.2.4 03.10.2005 - *) Добавление: модуль ngx_http_ssi_module поддерживает выражения - "$var=text", "$var!=text", "$var=/text/" и "$var!=/text/" в команде + *) Добавление: модуль ngx_http_ssi_module поддерживает выражения + "$var=text", "$var!=text", "$var=/text/" и "$var!=/text/" в команде if. - *) Исправление: ошибки при проксировании location без слэша в конце; + *) Исправление: ошибки при проксировании location без слэша в конце; ошибка появилась в 0.1.44. - *) Исправление: при использовании метода rtsig мог произойти + *) Исправление: при использовании метода rtsig мог произойти segmentation fault; ошибка появилась в 0.2.0. Изменения в nginx 0.2.3 30.09.2005 - *) Исправление: nginx не собирался без параметра --with-debug; ошибка + *) Исправление: nginx не собирался без параметра --with-debug; ошибка появилась в 0.2.2. @@ -4480,62 +4501,62 @@ *) Добавление: команда config errmsg в модуле ngx_http_ssi_module. - *) Изменение: переменные модуля ngx_http_geo_module можно - переопределять директивой set. - - *) Добавление: директивы ssl_protocols и ssl_prefer_server_ciphers + *) Изменение: переменные модуля ngx_http_geo_module можно переопределять + директивой set. + + *) Добавление: директивы ssl_protocols и ssl_prefer_server_ciphers модулей ngx_http_ssl_module и ngx_imap_ssl_module. - *) Исправление: ошибка в модуле ngx_http_autoindex_module при показе + *) Исправление: ошибка в модуле ngx_http_autoindex_module при показе длинных имён файлов; - *) Исправление: модуль ngx_http_autoindex_module теперь не показывает + *) Исправление: модуль ngx_http_autoindex_module теперь не показывает файлы, начинающиеся на точку. - *) Исправление: если SSL handshake завершался с ошибкой, то это могло + *) Исправление: если SSL handshake завершался с ошибкой, то это могло привести также к закрытию другого соединения. Спасибо Rob Mueller. - *) Исправление: экспортные версии MSIE 5.x не могли соединиться по + *) Исправление: экспортные версии MSIE 5.x не могли соединиться по HTTPS. Изменения в nginx 0.2.1 23.09.2005 - *) Исправление: если все бэкенды, используемые для балансировки - нагрузки, оказывались в нерабочем состоянии после одной ошибки, то + *) Исправление: если все бэкенды, используемые для балансировки + нагрузки, оказывались в нерабочем состоянии после одной ошибки, то nginx мог зациклится; ошибка появилась в 0.2.0. Изменения в nginx 0.2.0 23.09.2005 - *) Изменились имена pid-файлов, используемые во время обновления - исполняемого файла. Ручное переименование теперь не нужно. Старый - основной процесс добавляет к своему pid-файл суффикс ".oldbin" и - запускает новый исполняемый файл. Новый основной процесс создаёт - обычный pid-файл без суффикса ".newbin". Если новый основной процесс - выходит, то старый процесс переименовывает свой pid-файл c суффиксом - ".oldbin" в pid-файл без суффикса. При обновлении с версии 0.1.х до - 0.2.0 нужно учитывать, что оба процесса - старый 0.1.x и новый + *) Изменились имена pid-файлов, используемые во время обновления + исполняемого файла. Ручное переименование теперь не нужно. Старый + основной процесс добавляет к своему pid-файл суффикс ".oldbin" и + запускает новый исполняемый файл. Новый основной процесс создаёт + обычный pid-файл без суффикса ".newbin". Если новый основной процесс + выходит, то старый процесс переименовывает свой pid-файл c суффиксом + ".oldbin" в pid-файл без суффикса. При обновлении с версии 0.1.х до + 0.2.0 нужно учитывать, что оба процесса - старый 0.1.x и новый 0.2.0 - используют pid-файл без суффиксов. - *) Изменение: директива worker_connections, новое название директивы - connections; директива теперь задаёт максимальное число соединений, - а не максимально возможный номер дескриптора для сокета. - - *) Добавление: SSL поддерживает кэширование сессий в пределах одного + *) Изменение: директива worker_connections, новое название директивы + connections; директива теперь задаёт максимальное число соединений, а + не максимально возможный номер дескриптора для сокета. + + *) Добавление: SSL поддерживает кэширование сессий в пределах одного рабочего процесса. *) Добавление: директива satisfy_any. - *) Изменение: модули ngx_http_access_module и - ngx_http_auth_basic_module не работают для подзапросов. - - *) Добавление: директивы worker_rlimit_nofile и + *) Изменение: модули ngx_http_access_module и ngx_http_auth_basic_module + не работают для подзапросов. + + *) Добавление: директивы worker_rlimit_nofile и worker_rlimit_sigpending. - *) Исправление: если все бэкенды, используемые для балансировки - нагрузки, оказывались в нерабочем состоянии после одной ошибки, то + *) Исправление: если все бэкенды, используемые для балансировки + нагрузки, оказывались в нерабочем состоянии после одной ошибки, то nginx не обращался к ним в течение 60 секунд. *) Исправление: в парсинге аргументов IMAP/POP3 команд. @@ -4545,17 +4566,17 @@ *) Исправление: ошибки при использовании SSI и сжатия. - *) Исправление: в ответах 304 не добавлялись строки заголовка ответа + *) Исправление: в ответах 304 не добавлялись строки заголовка ответа "Expires" и "Cache-Control". Спасибо Александру Кукушкину. Изменения в nginx 0.1.45 08.09.2005 - *) Изменение: директива ssl_engine упразднена в модуле + *) Изменение: директива ssl_engine упразднена в модуле ngx_http_ssl_module и перенесена на глобальный уровень. - *) Исправление: ответы с подзапросами, включённые с помощью SSI, не + *) Исправление: ответы с подзапросами, включённые с помощью SSI, не передавались через SSL соединение. *) Разные исправления в IMAP/POP3 прокси. @@ -4569,126 +4590,126 @@ *) Добавление: директива userid_mark. - *) Добавление: значение переменной $remote_user определяется независимо + *) Добавление: значение переменной $remote_user определяется независимо от того, используется ли авторизация или нет. Изменения в nginx 0.1.43 30.08.2005 - *) Добавление: listen(2) backlog в директиве listen можно менять по + *) Добавление: listen(2) backlog в директиве listen можно менять по сигналу -HUP. *) Добавление: скрипт geo2nginx.pl добавлен в contrib. - *) Изменение: параметры FastCGI с пустым значениями теперь передаются + *) Изменение: параметры FastCGI с пустым значениями теперь передаются серверу. - *) Исправление: если в ответе проксированного сервера или FastCGI - сервера была строка "Cache-Control", то при использовании директивы - expires происходил segmentation fault или рабочий процесс мог + *) Исправление: если в ответе проксированного сервера или FastCGI + сервера была строка "Cache-Control", то при использовании директивы + expires происходил segmentation fault или рабочий процесс мог зациклится; в режиме прокси ошибка появилась в 0.1.29. Изменения в nginx 0.1.42 23.08.2005 - *) Исправление: если URI запроса получался нулевой длины после - обработки модулем ngx_http_rewrite_module, то в модуле - ngx_http_proxy_module происходил segmentation fault или bus error. - - *) Исправление: директива limit_rate не работала внутри блока if; - ошибка появилась в 0.1.38. + *) Исправление: если URI запроса получался нулевой длины после обработки + модулем ngx_http_rewrite_module, то в модуле ngx_http_proxy_module + происходил segmentation fault или bus error. + + *) Исправление: директива limit_rate не работала внутри блока if; ошибка + появилась в 0.1.38. Изменения в nginx 0.1.41 25.07.2005 - *) Исправление: если переменная использовалась в файле конфигурации, то + *) Исправление: если переменная использовалась в файле конфигурации, то она не могла использоваться в SSI. Изменения в nginx 0.1.40 22.07.2005 - *) Исправление: если клиент слал очень длинную строку заголовка, то в + *) Исправление: если клиент слал очень длинную строку заголовка, то в логе не помещалась информация, связанная с этим запросом. - *) Исправление: при использовании "X-Accel-Redirect" не передавалась + *) Исправление: при использовании "X-Accel-Redirect" не передавалась строка "Set-Cookie"; ошибка появилась в 0.1.39. - *) Исправление: при использовании "X-Accel-Redirect" не передавалась + *) Исправление: при использовании "X-Accel-Redirect" не передавалась строка "Content-Disposition". - *) Исправление: по сигналу SIGQUIT основной процесс не закрывал сокеты, + *) Исправление: по сигналу SIGQUIT основной процесс не закрывал сокеты, на которых он слушал. - *) Исправление: после обновления исполняемого файла на лету на Linux и + *) Исправление: после обновления исполняемого файла на лету на Linux и Solaris название процесса в команде ps становилось короче. Изменения в nginx 0.1.39 14.07.2005 - *) Изменения в модуле ngx_http_charset_module: директива - default_charset упразднена; директива charset задаёт кодировку - ответа; директива source_charset задаёт только исходную кодировку. - - *) Исправление: при перенаправлении ошибки 401, полученной от бэкенда, + *) Изменения в модуле ngx_http_charset_module: директива default_charset + упразднена; директива charset задаёт кодировку ответа; директива + source_charset задаёт только исходную кодировку. + + *) Исправление: при перенаправлении ошибки 401, полученной от бэкенда, не передавалась строка заголовка "WWW-Authenticate". - *) Исправление: модули ngx_http_proxy_module и ngx_http_fastcgi_module - могли закрыть соединение до того, как что-нибудь было передано + *) Исправление: модули ngx_http_proxy_module и ngx_http_fastcgi_module + могли закрыть соединение до того, как что-нибудь было передано клиенту; ошибка появилась в 0.1.38. *) Изменение: обработка ошибки инициализации в crypt_r() в Linux glibc. - *) Исправление: модуль ngx_http_ssi_module не поддерживал относительные + *) Исправление: модуль ngx_http_ssi_module не поддерживал относительные URI в команде include virtual. - *) Исправление: если в строке заголовка ответа бэкенда была строка - "Location", которую nginx не должен был изменять, то в ответе + *) Исправление: если в строке заголовка ответа бэкенда была строка + "Location", которую nginx не должен был изменять, то в ответе передавалось тело 500 ошибки; ошибка появилась в 0.1.29. - *) Исправление: некоторые директивы модулей ngx_http_proxy_module и - ngx_http_fastcgi_module не наследовались с уровня server на уровень + *) Исправление: некоторые директивы модулей ngx_http_proxy_module и + ngx_http_fastcgi_module не наследовались с уровня server на уровень location; ошибка появилась в 0.1.29. - *) Исправление: модуль ngx_http_ssl_module не поддерживал цепочки + *) Исправление: модуль ngx_http_ssl_module не поддерживал цепочки сертификатов. - *) Исправление: ошибка в модуле ngx_http_autoindex_module при показе + *) Исправление: ошибка в модуле ngx_http_autoindex_module при показе длинных имён файлов; ошибка появилась в 0.1.38. - *) Исправления в IMAP/POP3 прокси при взаимодействии с бэкендом на + *) Исправления в IMAP/POP3 прокси при взаимодействии с бэкендом на стадии login. Изменения в nginx 0.1.38 08.07.2005 - *) Добавление: директива limit_rate поддерживается в режиме прокси и + *) Добавление: директива limit_rate поддерживается в режиме прокси и FastCGI. - *) Добавление: в режиме прокси и FastCGI поддерживается строка - заголовка "X-Accel-Limit-Rate" в ответе бэкенда. + *) Добавление: в режиме прокси и FastCGI поддерживается строка заголовка + "X-Accel-Limit-Rate" в ответе бэкенда. *) Добавление: директива break. *) Добавление: директива log_not_found. - *) Исправление: при перенаправлении запроса с помощью строки заголовка + *) Исправление: при перенаправлении запроса с помощью строки заголовка "X-Accel-Redirect" не изменялся код ответа. - *) Исправление: переменные, установленные директивой set не могли + *) Исправление: переменные, установленные директивой set не могли использоваться в SSI. - *) Исправление: при включении в SSI более одного удалённого подзапроса + *) Исправление: при включении в SSI более одного удалённого подзапроса мог произойти segmentation fault. - *) Исправление: если статусная строка в ответе бэкенда передавалась в - двух пакетах, то nginx считал ответ неверным; ошибка появилась в + *) Исправление: если статусная строка в ответе бэкенда передавалась в + двух пакетах, то nginx считал ответ неверным; ошибка появилась в 0.1.29. *) Добавление: директива ssi_types. *) Добавление: директива autoindex_exact_size. - *) Исправление: модуль ngx_http_autoindex_module не поддерживал длинные + *) Исправление: модуль ngx_http_autoindex_module не поддерживал длинные имена файлов в UTF-8. *) Добавление: IMAP/POP3 прокси. @@ -4698,36 +4719,34 @@ *) Изменение: в конце файла nginx.pid теперь добавляется "\n". - *) Исправление: при включении большого количества вставок или - нескольких больших вставок с помощью SSI ответ мог передаваться не - полностью. - - *) Исправление: если все бэкенды возвращали ответ 404, то при - использовании параметра http_404 в директивах proxy_next_upstream - или fastcgi_next_upstream, nginx начинал запрашивать все бэкенды - снова. + *) Исправление: при включении большого количества вставок или нескольких + больших вставок с помощью SSI ответ мог передаваться не полностью. + + *) Исправление: если все бэкенды возвращали ответ 404, то при + использовании параметра http_404 в директивах proxy_next_upstream или + fastcgi_next_upstream, nginx начинал запрашивать все бэкенды снова. Изменения в nginx 0.1.36 15.06.2005 - *) Изменение: если в заголовке запросе есть дублирующиеся строки - "Host", "Connection", "Content-Length" и "Authorization", то nginx - теперь выдаёт ошибку 400. + *) Изменение: если в заголовке запросе есть дублирующиеся строки "Host", + "Connection", "Content-Length" и "Authorization", то nginx теперь + выдаёт ошибку 400. *) Изменение: директива post_accept_timeout упразднена. - *) Добавление: параметры default, af=, bl=, deferred и bind в директиве + *) Добавление: параметры default, af=, bl=, deferred и bind в директиве listen. *) Добавление: поддержка accept фильтров во FreeBSD. *) Добавление: поддержка TCP_DEFER_ACCEPT в Linux. - *) Исправление: модуль ngx_http_autoindex_module не поддерживал имена + *) Исправление: модуль ngx_http_autoindex_module не поддерживал имена файлов в UTF-8. - *) Исправление: после добавления новый лог-файл ротация этого лога по - сигналу -USR1 выполнялась, только если переконфигурировать nginx два + *) Исправление: после добавления новый лог-файл ротация этого лога по + сигналу -USR1 выполнялась, только если переконфигурировать nginx два раза по сигналу -HUP. @@ -4737,91 +4756,91 @@ *) Добавление: директива port_in_redirect. - *) Исправление: если заголовок ответа бэкенда не помещался в один - пакет, то происходил segmentation fault; ошибка появилась в 0.1.29. - - *) Исправление: если было сконфигурировано более 10 серверов или в - сервере не описана директива "listen", то при запуске мог произойти + *) Исправление: если заголовок ответа бэкенда не помещался в один пакет, + то происходил segmentation fault; ошибка появилась в 0.1.29. + + *) Исправление: если было сконфигурировано более 10 серверов или в + сервере не описана директива "listen", то при запуске мог произойти segmentation fault. - *) Исправление: если ответ не помещался во временный файл, то мог + *) Исправление: если ответ не помещался во временный файл, то мог произойти segmentation fault. - *) Исправление: nginx возвращал ошибку 400 на запросы вида + *) Исправление: nginx возвращал ошибку 400 на запросы вида "GET http://www.domain.com/uri HTTP/1.0"; ошибка появилась в 0.1.28. Изменения в nginx 0.1.34 26.05.2005 - *) Исправление: при включении больших ответов с помощью SSI рабочий + *) Исправление: при включении больших ответов с помощью SSI рабочий процесс мог зациклиться. - *) Исправление: переменные, устанавливаемые директивой "set", не были + *) Исправление: переменные, устанавливаемые директивой "set", не были доступны в SSI. *) Добавление: директива autoindex_localtime. - *) Исправление: пустое значение в директиве proxy_set_header запрещает + *) Исправление: пустое значение в директиве proxy_set_header запрещает передачу заголовка. Изменения в nginx 0.1.33 23.05.2005 - *) Исправление: nginx не собирался с параметром --without-pcre; ошибка + *) Исправление: nginx не собирался с параметром --without-pcre; ошибка появилась в 0.1.29. - *) Исправление: 3, 5, 7 и 8 директив proxy_set_header на одном уровне + *) Исправление: 3, 5, 7 и 8 директив proxy_set_header на одном уровне вызывали bus fault при запуске. - *) Исправление: в редиректах внутри HTTPS сервера был указан протокол + *) Исправление: в редиректах внутри HTTPS сервера был указан протокол HTTP. - *) Исправление: если директива rewrite использовала выделения внутри + *) Исправление: если директива rewrite использовала выделения внутри директивы if, то возвращалась ошибка 500. Изменения в nginx 0.1.32 19.05.2005 - *) Исправление: в редиректах, выдаваемых с помощью директивы rewrite, - не передавались аргументы; ошибка появилась в 0.1.29. - - *) Добавление: директива if поддерживает выделения в регулярных + *) Исправление: в редиректах, выдаваемых с помощью директивы rewrite, не + передавались аргументы; ошибка появилась в 0.1.29. + + *) Добавление: директива if поддерживает выделения в регулярных выражениях. - *) Добавление: директива set поддерживает переменные и выделения из + *) Добавление: директива set поддерживает переменные и выделения из регулярных выражений. - *) Добавление: в режиме прокси и FastCGI поддерживается строка - заголовка "X-Accel-Redirect" в ответе бэкенда. + *) Добавление: в режиме прокси и FastCGI поддерживается строка заголовка + "X-Accel-Redirect" в ответе бэкенда. Изменения в nginx 0.1.31 16.05.2005 - *) Исправление: при использовании SSL ответ мог передаваться не до + *) Исправление: при использовании SSL ответ мог передаваться не до конца. - *) Исправление: ошибки при обработке SSI в ответе, полученного от + *) Исправление: ошибки при обработке SSI в ответе, полученного от FastCGI-сервера. *) Исправление: ошибки при использовании SSI и сжатия. - *) Исправление: редирект с кодом 301 передавался без тела ответа; - ошибка появилась в 0.1.30. + *) Исправление: редирект с кодом 301 передавался без тела ответа; ошибка + появилась в 0.1.30. Изменения в nginx 0.1.30 14.05.2005 *) Исправление: при использовании SSI рабочий процесс мог зациклиться. - *) Исправление: при использовании SSL ответ мог передаваться не до + *) Исправление: при использовании SSL ответ мог передаваться не до конца. - *) Исправление: если длина части ответа, полученного за один раз от - проксируемого или FastCGI сервера была равна 500 байт, то nginx - возвращал код ответа 500; в режиме прокси ошибка появилась только в + *) Исправление: если длина части ответа, полученного за один раз от + проксируемого или FastCGI сервера была равна 500 байт, то nginx + возвращал код ответа 500; в режиме прокси ошибка появилась только в 0.1.29. - *) Исправление: nginx не считал неверными директивы с 8-ю или 9-ю + *) Исправление: nginx не считал неверными директивы с 8-ю или 9-ю параметрами. *) Добавление: директива return может возвращать код ответа 204. @@ -4831,87 +4850,87 @@ Изменения в nginx 0.1.29 12.05.2005 - *) Добавление: модуль ngx_http_ssi_module поддерживает команду include + *) Добавление: модуль ngx_http_ssi_module поддерживает команду include virtual. - *) Добавление: модуль ngx_http_ssi_module поддерживает условную команду - вида 'if expr="$NAME"' и команды else и endif. Допускается только + *) Добавление: модуль ngx_http_ssi_module поддерживает условную команду + вида 'if expr="$NAME"' и команды else и endif. Допускается только один уровень вложенности. - *) Добавление: модуль ngx_http_ssi_module поддерживает две переменные + *) Добавление: модуль ngx_http_ssi_module поддерживает две переменные DATE_LOCAL и DATE_GMT и команду config timefmt. *) Добавление: директива ssi_ignore_recycled_buffers. - *) Исправление: если переменная QUERY_STRING не была определена, то в + *) Исправление: если переменная QUERY_STRING не была определена, то в команде echo не ставилось значение по умолчанию. *) Изменение: модуль ngx_http_proxy_module полностью переписан. - *) Добавление: директивы proxy_redirect, proxy_pass_request_headers, + *) Добавление: директивы proxy_redirect, proxy_pass_request_headers, proxy_pass_request_body и proxy_method. - *) Добавление: директива proxy_set_header. Директива proxy_x_var + *) Добавление: директива proxy_set_header. Директива proxy_x_var упразднена и должна быть заменена директивой proxy_set_header. - *) Изменение: директива proxy_preserve_host упразднена и должна быть - заменена директивами "proxy_set_header Host $host" и "proxy_redirect - off" или директивой "proxy_set_header Host $host:$proxy_port" и + *) Изменение: директива proxy_preserve_host упразднена и должна быть + заменена директивами "proxy_set_header Host $host" и "proxy_redirect + off" или директивой "proxy_set_header Host $host:$proxy_port" и соответствующими ей директивами proxy_redirect. - *) Изменение: директива proxy_set_x_real_ip упразднена и должна быть + *) Изменение: директива proxy_set_x_real_ip упразднена и должна быть заменена директивой "proxy_set_header X-Real-IP $remote_addr". - *) Изменение: директива proxy_add_x_forwarded_for упразднена и должна - быть заменена директивой + *) Изменение: директива proxy_add_x_forwarded_for упразднена и должна + быть заменена директивой "proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for". - *) Изменение: директива proxy_set_x_url упразднена и должна быть - заменена директивой + *) Изменение: директива proxy_set_x_url упразднена и должна быть + заменена директивой "proxy_set_header X-URL http://$host:$server_port$request_uri". *) Добавление: директива fastcgi_param. - *) Изменение: директивы fastcgi_root, fastcgi_set_var и fastcgi_params + *) Изменение: директивы fastcgi_root, fastcgi_set_var и fastcgi_params упразднены и должны быть замены директивами fastcgi_param. *) Добавление: директива index может использовать переменные. - *) Добавление: директива index может быть указана на уровне http и + *) Добавление: директива index может быть указана на уровне http и server. - *) Изменение: только последний параметр в директиве index может быть + *) Изменение: только последний параметр в директиве index может быть абсолютным. *) Добавление: в директиве rewrite могут использоваться переменные. *) Добавление: директива internal. - *) Добавление: переменные CONTENT_LENGTH, CONTENT_TYPE, REMOTE_PORT, - SERVER_ADDR, SERVER_PORT, SERVER_PROTOCOL, DOCUMENT_ROOT, + *) Добавление: переменные CONTENT_LENGTH, CONTENT_TYPE, REMOTE_PORT, + SERVER_ADDR, SERVER_PORT, SERVER_PROTOCOL, DOCUMENT_ROOT, SERVER_NAME, REQUEST_METHOD, REQUEST_URI и REMOTE_USER. - *) Изменение: nginx теперь передаёт неверные строки в заголовках - запроса клиента и ответа бэкенда. - - *) Исправление: если бэкенд долго не передавал ответ и send_timeout был + *) Изменение: nginx теперь передаёт неверные строки в заголовках запроса + клиента и ответа бэкенда. + + *) Исправление: если бэкенд долго не передавал ответ и send_timeout был меньше, чем proxy_read_timeout, то клиенту возвращался ответ 408. - *) Исправление: если бэкенд передавал неверную строку в заголовке + *) Исправление: если бэкенд передавал неверную строку в заголовке ответа, то происходил segmentation fault; ошибка появилась в 0.1.26. - *) Исправление: при использовании отказоустойчивой конфигурации в + *) Исправление: при использовании отказоустойчивой конфигурации в FastCGI мог происходить segmentation fault. - *) Исправление: директива expires не удаляла уже установленные строки + *) Исправление: директива expires не удаляла уже установленные строки заголовка "Expires" и "Cache-Control". - *) Исправление: nginx не учитывал завершающую точку в строке заголовка + *) Исправление: nginx не учитывал завершающую точку в строке заголовка запроса "Host". *) Исправление: модуль ngx_http_auth_module не работал на Linux. - *) Исправление: директива rewrite неверно работала, если в запросе + *) Исправление: директива rewrite неверно работала, если в запросе присутствовали аргументы. *) Исправление: nginx не собирался на MacOS X. @@ -4919,7 +4938,7 @@ Изменения в nginx 0.1.28 08.04.2005 - *) Исправление: при проксировании больших файлов nginx сильно нагружал + *) Исправление: при проксировании больших файлов nginx сильно нагружал процессор. *) Исправление: nginx не собирался gcc 4.0 на Linux. @@ -4929,29 +4948,29 @@ *) Добавление: параметр blocked в директиве valid_referers. - *) Изменение: ошибки обработки заголовка запроса теперь записываются на - уровне info, в лог также записывается имя сервера и строки заголовка + *) Изменение: ошибки обработки заголовка запроса теперь записываются на + уровне info, в лог также записывается имя сервера и строки заголовка запроса "Host" и "Referer". - *) Изменение: при записи ошибок в лог записывается также строка + *) Изменение: при записи ошибок в лог записывается также строка заголовка запроса "Host". - *) Добавление: директива proxy_pass_unparsed_uri. Специальная обработка + *) Добавление: директива proxy_pass_unparsed_uri. Специальная обработка символов "://" в URI, введённая в версии 0.1.11, теперь упразднена. - *) Исправление: nginx не собирался на FreeBSD и Linux, если был указан + *) Исправление: nginx не собирался на FreeBSD и Linux, если был указан параметр конфигурации --without-ngx_http_auth_basic_module. Изменения в nginx 0.1.26 22.03.2005 - *) Изменение: неверные строки заголовка, переданные клиентом, теперь + *) Изменение: неверные строки заголовка, переданные клиентом, теперь игнорируется и записываются в error_log на уровне info. - *) Изменение: при записи ошибок в лог записывается также имя сервера, + *) Изменение: при записи ошибок в лог записывается также имя сервера, при обращении к которому произошла ошибка. - *) Добавление: модуль ngx_http_auth_basic_module и директивы auth_basic + *) Добавление: модуль ngx_http_auth_basic_module и директивы auth_basic и auth_basic_user_file. @@ -4959,25 +4978,25 @@ *) Исправление: nginx не работал на Linux parisc. - *) Добавление: nginx теперь не запускается под FreeBSD, если значение + *) Добавление: nginx теперь не запускается под FreeBSD, если значение sysctl kern.ipc.somaxconn слишком большое. - *) Исправление: если модуль ngx_http_index_module делал внутреннее - перенаправление запроса в модули ngx_http_proxy_module или - ngx_http_fastcgi_module, то файл индекса не закрывался после + *) Исправление: если модуль ngx_http_index_module делал внутреннее + перенаправление запроса в модули ngx_http_proxy_module или + ngx_http_fastcgi_module, то файл индекса не закрывался после обслуживания запроса. - *) Добавление: директива proxy_pass может использоваться в location, + *) Добавление: директива proxy_pass может использоваться в location, заданных регулярным выражением. - *) Добавление: модуль ngx_http_rewrite_filter_module поддерживает + *) Добавление: модуль ngx_http_rewrite_filter_module поддерживает условия вида "if ($HTTP_USER_AGENT ~ MSIE)". - *) Исправление: nginx очень медленно запускался при большом количестве + *) Исправление: nginx очень медленно запускался при большом количестве адресов и использовании текстовых значений в директиве geo. - *) Изменение: имя переменной в директиве geo нужно указывать, как - $name. Прежний вариант без "$" пока работает, но вскоре будет убран. + *) Изменение: имя переменной в директиве geo нужно указывать, как $name. + Прежний вариант без "$" пока работает, но вскоре будет убран. *) Добавление: параметр лога "%{VARIABLE}v". @@ -4990,59 +5009,59 @@ Изменения в nginx 0.1.24 04.03.2005 - *) Добавление: модуль ngx_http_ssi_filter_module поддерживает - переменные QUERY_STRING и DOCUMENT_URI. - - *) Исправление: модуль ngx_http_autoindex_module мог выдавать ответ 404 + *) Добавление: модуль ngx_http_ssi_filter_module поддерживает переменные + QUERY_STRING и DOCUMENT_URI. + + *) Исправление: модуль ngx_http_autoindex_module мог выдавать ответ 404 на существующий каталог, если этот каталог был указан как alias. - *) Исправление: модуль ngx_http_ssi_filter_module неправильно работал + *) Исправление: модуль ngx_http_ssi_filter_module неправильно работал при больших ответах. - *) Исправление: отсутствие строки заголовка "Referer" всегда считалось + *) Исправление: отсутствие строки заголовка "Referer" всегда считалось правильным referrer'ом. Изменения в nginx 0.1.23 01.03.2005 - *) Добавление: модуль ngx_http_ssi_filter_module и директивы ssi, - ssi_silent_errors и ssi_min_file_chunk. Поддерживаются команды 'echo + *) Добавление: модуль ngx_http_ssi_filter_module и директивы ssi, + ssi_silent_errors и ssi_min_file_chunk. Поддерживаются команды 'echo var="HTTP_..." default=""' и 'echo var="REMOTE_ADDR"'. *) Добавление: параметр лога %request_time. - *) Добавление: если запрос пришёл без строки заголовка "Host", то - директива proxy_preserve_host устанавливает в качестве этого + *) Добавление: если запрос пришёл без строки заголовка "Host", то + директива proxy_preserve_host устанавливает в качестве этого заголовка первое имя сервера из директивы server_name. - *) Исправление: nginx не собирался на платформах, отличных от i386, + *) Исправление: nginx не собирался на платформах, отличных от i386, amd64, sparc и ppc; ошибка появилась в 0.1.22. - *) Исправление: модуль ngx_http_autoindex_module теперь показывает - информацию не о символическом линке, а о файле или каталоге, на + *) Исправление: модуль ngx_http_autoindex_module теперь показывает + информацию не о символическом линке, а о файле или каталоге, на который он указывает. - *) Исправление: если клиенту ничего не передавалось, то параметр + *) Исправление: если клиенту ничего не передавалось, то параметр %apache_length записывал в лог отрицательную длину заголовка ответа. Изменения в nginx 0.1.22 22.02.2005 - *) Исправление: модуль ngx_http_stub_status_module показывал неверную - статистику для обработанных соединений, если использовалось + *) Исправление: модуль ngx_http_stub_status_module показывал неверную + статистику для обработанных соединений, если использовалось проксирование или FastCGI-сервер. - *) Исправление: на Linux и Solaris установочные пути были неверно + *) Исправление: на Linux и Solaris установочные пути были неверно заключены в кавычки; ошибка появилась в 0.1.21. Изменения в nginx 0.1.21 22.02.2005 - *) Исправление: модуль ngx_http_stub_status_module показывал неверную - статистику при использовании метода rtsig или при использовании + *) Исправление: модуль ngx_http_stub_status_module показывал неверную + статистику при использовании метода rtsig или при использовании нескольких рабочих процессов на SMP машине. - *) Исправление: nginx не собирался компилятором icc под Линуксом или + *) Исправление: nginx не собирался компилятором icc под Линуксом или если библиотека zlib-1.2.x собиралась из исходных текстов. *) Исправление: nginx не собирался под NetBSD 2.0. @@ -5050,76 +5069,75 @@ Изменения в nginx 0.1.20 17.02.2005 - *) Добавление: новые параметры script_filename и remote_port в - директиве fastcgi_params. - - *) Исправление: неправильно обрабатывался поток stderr от + *) Добавление: новые параметры script_filename и remote_port в директиве + fastcgi_params. + + *) Исправление: неправильно обрабатывался поток stderr от FastCGI-сервера. Изменения в nginx 0.1.19 16.02.2005 - *) Исправление: если в запросе есть нуль, то для локальных запросов + *) Исправление: если в запросе есть нуль, то для локальных запросов теперь возвращается ошибка 404. *) Исправление: nginx не собирался под NetBSD 2.0. - *) Исправление: во время чтения тела запроса клиента в SSL соединении + *) Исправление: во время чтения тела запроса клиента в SSL соединении мог произойти таймаут. Изменения в nginx 0.1.18 09.02.2005 - *) Изменение: для совместимости с Solaris 10 в директивах - devpoll_events и devpoll_changes значения по умолчанию уменьшены с - 512 до 32. - - *) Исправление: директивы proxy_set_x_var и fastcgi_set_var не + *) Изменение: для совместимости с Solaris 10 в директивах devpoll_events + и devpoll_changes значения по умолчанию уменьшены с 512 до 32. + + *) Исправление: директивы proxy_set_x_var и fastcgi_set_var не наследовались. - *) Исправление: в директиве rewrite, возвращающей редирект, аргументы + *) Исправление: в директиве rewrite, возвращающей редирект, аргументы присоединялись к URI через символ "&" вместо "?". - *) Исправление: строки для модуля ngx_http_geo_module без символа ";" - во включённом файле игнорировались. + *) Исправление: строки для модуля ngx_http_geo_module без символа ";" во + включённом файле игнорировались. *) Добавление: модуль ngx_http_stub_status_module. - *) Исправление: неизвестный формат лог-файла в директиве access_log + *) Исправление: неизвестный формат лог-файла в директиве access_log вызывал segmentation fault. *) Добавление: новый параметр document_root в директиве fastcgi_params. *) Добавление: директива fastcgi_redirect_errors. - *) Добавление: новый модификатор break в директиве rewrite позволяет - прекратить цикл rewrite/location и устанавливает текущую - конфигурацию для запроса. + *) Добавление: новый модификатор break в директиве rewrite позволяет + прекратить цикл rewrite/location и устанавливает текущую конфигурацию + для запроса. Изменения в nginx 0.1.17 03.02.2005 - *) Изменение: модуль ngx_http_rewrite_module полностью переписан. - Теперь можно делать редиректы, возвращать коды ошибок и проверять - переменные и рефереры. Эти директивы можно использовать внутри - location. Директива redirect упразднена. + *) Изменение: модуль ngx_http_rewrite_module полностью переписан. Теперь + можно делать редиректы, возвращать коды ошибок и проверять переменные + и рефереры. Эти директивы можно использовать внутри location. + Директива redirect упразднена. *) Добавление: модуль ngx_http_geo_module. *) Добавление: директивы proxy_set_x_var и fastcgi_set_var. - *) Исправление: конфигурация location с модификатором "=" могла + *) Исправление: конфигурация location с модификатором "=" могла использоваться в другом location. - *) Исправление: правильный тип ответа выставлялся только для запросов, - у которых в расширении были только маленькие буквы. - - *) Исправление: если для location установлен proxy_pass или - fastcgi_pass, и доступ к нему запрещался, а ошибка перенаправлялась + *) Исправление: правильный тип ответа выставлялся только для запросов, у + которых в расширении были только маленькие буквы. + + *) Исправление: если для location установлен proxy_pass или + fastcgi_pass, и доступ к нему запрещался, а ошибка перенаправлялась на статическую страницу, то происходил segmentation fault. - *) Исправление: если в проксированном ответе в заголовке "Location" - передавался относительный URL, то к нему добавлялось имя хоста и + *) Исправление: если в проксированном ответе в заголовке "Location" + передавался относительный URL, то к нему добавлялось имя хоста и слэш; ошибка появилась в 0.1.14. *) Исправление: на Linux в лог не записывался текст системной ошибки. @@ -5127,83 +5145,83 @@ Изменения в nginx 0.1.16 25.01.2005 - *) Исправление: если ответ передавался chunk'ами, то при запросе HEAD + *) Исправление: если ответ передавался chunk'ами, то при запросе HEAD выдавался завершающий chunk. - *) Исправление: заголовок "Connection: keep-alive" выдавался, даже если + *) Исправление: заголовок "Connection: keep-alive" выдавался, даже если директива keepalive_timeout запрещала использование keep-alive. - *) Исправление: ошибки в модуле ngx_http_fastcgi_module вызывали + *) Исправление: ошибки в модуле ngx_http_fastcgi_module вызывали segmentation fault. - *) Исправление: при использовании SSL сжатый ответ мог передаваться не + *) Исправление: при использовании SSL сжатый ответ мог передаваться не до конца. - *) Исправление: опции TCP_NODELAY, TCP_NOPSUH и TCP_CORK, специфичные + *) Исправление: опции TCP_NODELAY, TCP_NOPSUH и TCP_CORK, специфичные для TCP сокетов, не используются для unix domain сокетов. - *) Добавление: директива rewrite поддерживает перезаписывание + *) Добавление: директива rewrite поддерживает перезаписывание аргументов. - *) Исправление: на запрос POST с заголовком "Content-Length: 0" + *) Исправление: на запрос POST с заголовком "Content-Length: 0" возвращался ответ 400; ошибка появилась в 0.1.14. Изменения в nginx 0.1.15 19.01.2005 - *) Исправление: ошибка соединения с FastCGI-сервером вызывала + *) Исправление: ошибка соединения с FastCGI-сервером вызывала segmentation fault. - *) Исправление: корректная обработка регулярного выражения, в котором + *) Исправление: корректная обработка регулярного выражения, в котором число выделенных частей не совпадает с числом подстановок. - *) Добавление: location, который передаётся FastCGI-серверу, может быть + *) Добавление: location, который передаётся FastCGI-серверу, может быть задан с помощью регулярного выражения. - *) Исправление: параметр FastCGI REQUEST_URI теперь передаётся вместе с + *) Исправление: параметр FastCGI REQUEST_URI теперь передаётся вместе с аргументами и в том виде, в котором был получен от клиента. - *) Исправление: для использования регулярных выражений в location нужно + *) Исправление: для использования регулярных выражений в location нужно было собирать nginx вместе с ngx_http_rewrite_module. - *) Исправление: если бэкенд слушал на 80-ом порту, то при использовании - директивы "proxy_preserve_host on" в заголовке "Host" указывался + *) Исправление: если бэкенд слушал на 80-ом порту, то при использовании + директивы "proxy_preserve_host on" в заголовке "Host" указывался также порт 80; ошибка появилась в 0.1.14. - *) Исправление: если задать одинаковые пути в параметрах - автоконфигурации --http-client-body-temp-path=PATH и - --http-proxy-temp-path=PATH или --http-client-body-temp-path=PATH и + *) Исправление: если задать одинаковые пути в параметрах + автоконфигурации --http-client-body-temp-path=PATH и + --http-proxy-temp-path=PATH или --http-client-body-temp-path=PATH и --http-fastcgi-temp-path=PATH, то происходил segmentation fault. Изменения в nginx 0.1.14 18.01.2005 - *) Добавление: параметры автоконфигурации - --http-client-body-temp-path=PATH, --http-proxy-temp-path=PATH и + *) Добавление: параметры автоконфигурации + --http-client-body-temp-path=PATH, --http-proxy-temp-path=PATH и --http-fastcgi-temp-path=PATH - *) Изменение: имя каталога с временными файлами, содержащие тело - запроса клиента, задаётся директивой client_body_temp_path, по - умолчанию <prefix>/client_body_temp. - - *) Добавление: модуль ngx_http_fastcgi_module и директивы fastcgi_pass, - fastcgi_root, fastcgi_index, fastcgi_params, - fastcgi_connect_timeout, fastcgi_send_timeout, fastcgi_read_timeout, - fastcgi_send_lowat, fastcgi_header_buffer_size, fastcgi_buffers, - fastcgi_busy_buffers_size, fastcgi_temp_path, - fastcgi_max_temp_file_size, fastcgi_temp_file_write_size, + *) Изменение: имя каталога с временными файлами, содержащие тело запроса + клиента, задаётся директивой client_body_temp_path, по умолчанию + <prefix>/client_body_temp. + + *) Добавление: модуль ngx_http_fastcgi_module и директивы fastcgi_pass, + fastcgi_root, fastcgi_index, fastcgi_params, fastcgi_connect_timeout, + fastcgi_send_timeout, fastcgi_read_timeout, fastcgi_send_lowat, + fastcgi_header_buffer_size, fastcgi_buffers, + fastcgi_busy_buffers_size, fastcgi_temp_path, + fastcgi_max_temp_file_size, fastcgi_temp_file_write_size, fastcgi_next_upstream и fastcgi_x_powered_by. - *) Исправление: ошибка "[alert] zero size buf"; ошибка появилась в + *) Исправление: ошибка "[alert] zero size buf"; ошибка появилась в 0.1.3. - *) Изменение: в директиве proxy_pass нужно обязательно указывать URI + *) Изменение: в директиве proxy_pass нужно обязательно указывать URI после имени хоста. - *) Изменение: если в URI встречался символ %3F, то он считался началом + *) Изменение: если в URI встречался символ %3F, то он считался началом строки аргументов. - *) Добавление: поддержка unix domain сoкетов в модуле + *) Добавление: поддержка unix domain сoкетов в модуле ngx_http_proxy_module. *) Добавление: директивы ssl_engine и ssl_ciphers. @@ -5212,7 +5230,7 @@ Изменения в nginx 0.1.13 21.12.2004 - *) Добавление: директивы server_names_hash и + *) Добавление: директивы server_names_hash и server_names_hash_threshold. *) Исправление: имена *.domain.tld в директиве server_name не работали. @@ -5224,13 +5242,13 @@ *) Добавление: параметр лога %request_length. - *) Исправление: при использовании /dev/poll, select и poll на - платформах, где возможны ложные срабатывания указанных методов, - могли быть длительные задержки при обработке запроса по keep-alive - соединению. Наблюдалось по крайней мере на Solaris с использованием + *) Исправление: при использовании /dev/poll, select и poll на + платформах, где возможны ложные срабатывания указанных методов, могли + быть длительные задержки при обработке запроса по keep-alive + соединению. Наблюдалось по крайней мере на Solaris с использованием /dev/poll. - *) Исправление: директива send_lowat игнорируется на Linux, так как + *) Исправление: директива send_lowat игнорируется на Linux, так как Linux не поддерживает опцию SO_SNDLOWAT. @@ -5238,25 +5256,25 @@ *) Добавление: директива worker_priority. - *) Изменение: под FreeBSD директивы tcp_nopush и tcp_nodelay вместе + *) Изменение: под FreeBSD директивы tcp_nopush и tcp_nodelay вместе влияют на передачу ответа. *) Исправление: nginx не вызывал initgroups(). Спасибо Андрею Ситникову и Андрею Нигматулину. - *) Изменение: ngx_http_auto_index_module теперь выдаёт размер файлов в + *) Изменение: ngx_http_auto_index_module теперь выдаёт размер файлов в байтах. - *) Исправление: ngx_http_auto_index_module возвращал ошибку 500, если в + *) Исправление: ngx_http_auto_index_module возвращал ошибку 500, если в каталоге есть битый symlink. - *) Исправление: файлы больше 4G не передавались с использованием + *) Исправление: файлы больше 4G не передавались с использованием sendfile. - *) Исправление: если бэкенд резолвился в несколько адресов и при + *) Исправление: если бэкенд резолвился в несколько адресов и при ожидании от него ответа происходила ошибка, то процесс зацикливался. - *) Исправление: при использовании метода /dev/poll рабочий процесс мог + *) Исправление: при использовании метода /dev/poll рабочий процесс мог завершиться с сообщением "unknown cycle". *) Исправление: ошибки "close() channel failed". @@ -5265,7 +5283,7 @@ *) Исправление: директива send_lowat не работала на Linux. - *) Исправление: если в конфигурации не было раздела events, то + *) Исправление: если в конфигурации не было раздела events, то происходил segmentation fault. *) Исправление: nginx не собирался под OpenBSD. @@ -5275,32 +5293,32 @@ Изменения в nginx 0.1.10 26.11.2004 - *) Исправление: если в запросе без аргументов есть "//", "/./", "/../" - или "%XX", то терялся последний символ в строке запроса; ошибка + *) Исправление: если в запросе без аргументов есть "//", "/./", "/../" + или "%XX", то терялся последний символ в строке запроса; ошибка появилась в 0.1.9. - *) Исправление: исправление в версии 0.1.9 для файлов больше 2G на - Linux не работало. + *) Исправление: исправление в версии 0.1.9 для файлов больше 2G на Linux + не работало. Изменения в nginx 0.1.9 25.11.2004 - *) Исправление: если в запросе есть "//", "/./", "/../" или "%XX", то + *) Исправление: если в запросе есть "//", "/./", "/../" или "%XX", то проксируемый запрос передавался без аргументов. - *) Исправление: при сжатии больших ответов иногда они передавались не + *) Исправление: при сжатии больших ответов иногда они передавались не полностью. - *) Исправление: не передавались файлы больше 2G на Linux, + *) Исправление: не передавались файлы больше 2G на Linux, неподдерживающем sendfile64(). - *) Исправление: на Linux при конфигурации сборки нужно было обязательно + *) Исправление: на Linux при конфигурации сборки нужно было обязательно использовать параметр --with-poll_module; ошибка появилась в 0.1.8. Изменения в nginx 0.1.8 20.11.2004 - *) Исправление: ошибка в модуле ngx_http_autoindex_module при показе + *) Исправление: ошибка в модуле ngx_http_autoindex_module при показе длинных имён файлов. *) Добавление: модификатор "^~" в директиве location. @@ -5310,37 +5328,37 @@ Изменения в nginx 0.1.7 12.11.2004 - *) Исправление: при использовании sendfile, если передаваемый файл - менялся, то мог произойти segmentation fault на FreeBSD; ошибка + *) Исправление: при использовании sendfile, если передаваемый файл + менялся, то мог произойти segmentation fault на FreeBSD; ошибка появилась в 0.1.5. Изменения в nginx 0.1.6 11.11.2004 - *) Исправление: при некоторых комбинациях директив location c - регулярными выражениями использовалась конфигурация не из того + *) Исправление: при некоторых комбинациях директив location c + регулярными выражениями использовалась конфигурация не из того location. Изменения в nginx 0.1.5 11.11.2004 - *) Исправление: на Solaris и Linux могло быть очень много сообщений + *) Исправление: на Solaris и Linux могло быть очень много сообщений "recvmsg() returned not enough data". - *) Исправление: в режиме прокси без использования sendfile на Solaris - возникала ошибка "writev() failed (22: Invalid argument)". На других + *) Исправление: в режиме прокси без использования sendfile на Solaris + возникала ошибка "writev() failed (22: Invalid argument)". На других платформах, не поддерживающих sendfile, процесс зацикливался. - *) Исправление: при использовании sendfile в режиме прокси на Solaris + *) Исправление: при использовании sendfile в режиме прокси на Solaris возникал segmentation fault. *) Исправление: segmentation fault на Solaris. - *) Исправление: обновление исполняемого файла на лету не работало на + *) Исправление: обновление исполняемого файла на лету не работало на Linux. - *) Исправление: в списке файлов, выдаваемом модулем - ngx_http_autoindex_module, не перекодировались пробелы, кавычки и + *) Исправление: в списке файлов, выдаваемом модулем + ngx_http_autoindex_module, не перекодировались пробелы, кавычки и знаки процента. *) Изменение: уменьшение операций копирования. @@ -5359,32 +5377,32 @@ *) Добавление: директива proxy_set_x_url. - *) Исправление: модуль проксировании мог привести к зацикливанию, если + *) Исправление: модуль проксировании мог привести к зацикливанию, если не использовался sendfile. Изменения в nginx 0.1.2 21.10.2004 - *) Добавление: параметры --user=USER, --group=GROUP и + *) Добавление: параметры --user=USER, --group=GROUP и --with-ld-opt=OPTIONS в configure. *) Добавление: директива server_name поддерживает *.domain.tld. *) Исправление: улучшена переносимость на неизвестные платформы. - *) Исправление: нельзя переконфигурировать nginx, если конфигурационный + *) Исправление: нельзя переконфигурировать nginx, если конфигурационный файл указан в командной строке; ошибка появилась в 0.1.1. - *) Исправление: модуль проксировании мог привести к зацикливанию, если + *) Исправление: модуль проксировании мог привести к зацикливанию, если не использовался sendfile. - *) Исправление: при использовании sendfile текст ответа не - перекодировался согласно директивам модуля charset; ошибка появилась + *) Исправление: при использовании sendfile текст ответа не + перекодировался согласно директивам модуля charset; ошибка появилась в 0.1.1. *) Исправление: очень редкая ошибка при обработке kqueue. - *) Исправление: модуль сжатия сжимал уже сжатые ответы, полученные при + *) Исправление: модуль сжатия сжимал уже сжатые ответы, полученные при проксировании. @@ -5394,27 +5412,27 @@ *) Добавление: директива tcp_nodelay. - *) Добавление: директива send_lowat работает не только на платформах, - поддерживающих kqueue NOTE_LOWAT, но и на всех, поддерживающих + *) Добавление: директива send_lowat работает не только на платформах, + поддерживающих kqueue NOTE_LOWAT, но и на всех, поддерживающих SO_SNDLOWAT. *) Добавление: эмуляция setproctitle() для Linux и Solaris. - *) Исправление: ошибка при переписывании заголовка "Location" при + *) Исправление: ошибка при переписывании заголовка "Location" при проксировании. - *) Исправление: ошибка в модуле ngx_http_chunked_module, приводившая к + *) Исправление: ошибка в модуле ngx_http_chunked_module, приводившая к зацикливанию. *) Исправление: ошибки в модуле /dev/poll. - *) Исправление: при проксировании и использовании временных файлов + *) Исправление: при проксировании и использовании временных файлов ответы портились. - *) Исправление: бэкенду передавались запросы с неперекодированными + *) Исправление: бэкенду передавались запросы с неперекодированными символами. - *) Исправление: на Linux 2.4 при конфигурации сборки нужно было + *) Исправление: на Linux 2.4 при конфигурации сборки нужно было обязательно использовать параметр --with-poll_module.
--- a/xml/en/download.xml Mon Aug 29 13:27:52 2011 +0000 +++ b/xml/en/download.xml Mon Aug 29 14:38:04 2011 +0000 @@ -21,6 +21,7 @@ <download last="5" changes="CHANGES-1.0"> +<item ver="1.0.6" pgp="yes" win="yes" /> <item ver="1.0.5" pgp="yes" win="yes" /> <item ver="1.0.4" pgp="yes" win="yes" /> <item ver="1.0.3" pgp="yes" win="yes" />
--- a/xml/index.xml Mon Aug 29 13:27:52 2011 +0000 +++ b/xml/index.xml Mon Aug 29 14:38:04 2011 +0000 @@ -2,6 +2,13 @@ <news title="nginx news" link="/" lang="en"> +<event date="2011-08-29"> +<para> +<a href="/en/download.xml">nginx-1.0.6</a> +stable version has been released. +</para> +</event> + <event date="2011-08-22"> <para> <a href="/en/download.xml">nginx-1.1.1</a>
--- a/xml/ru/download.xml Mon Aug 29 13:27:52 2011 +0000 +++ b/xml/ru/download.xml Mon Aug 29 14:38:04 2011 +0000 @@ -20,6 +20,7 @@ <download last="5" changes="CHANGES.ru-1.0"> +<item ver="1.0.6" pgp="yes" win="yes" /> <item ver="1.0.5" pgp="yes" win="yes" /> <item ver="1.0.4" pgp="yes" win="yes" /> <item ver="1.0.3" pgp="yes" win="yes" />