290N/AChanges with Apache 2.5.0
290N/A *) core: Add LogLevelOverride directive that allows to override the
1068N/A loglevel for clients from certain IPs. This also works for things
290N/A like the SSL handshake where <If> LogLevel ... </If> is evaluated
290N/A too late. [Stefan Fritsch]
919N/A *) mod_status: Print out list of times since a Vhost was last used.
919N/A *) core: Don't fail at startup with AH00554 when Include points to
919N/A a directory without any wildcard character. PR 54223 [Eric Covener]
919N/A *) core: Fail startup if the argument to ServerTokens is unrecognized.
919N/A *) mod_log_forensic: Don't log a spurious "-" if a request has been rejected
919N/A before mod_log_forensic could attach its id to it. [Stefan Fritsch]
919N/A *) ap_expr: Add SERVER_PROTOCOL_VERSION, ..._MAJOR, and ..._MINOR
919N/A variables. [Stefan Fritsch]
919N/A *) mod_rewrite: Stop mergeing RewriteBase down to subdirectories
290N/A unless new option 'RewriteOptions MergeBase' is configured.
290N/A PR 53963. [Eric Covener]
290N/A *) mod_session_dbd: fix a segmentation fault in the function dbd_remove.
493N/A PR 53452. [<rebanerebane gmail com>, Reimo Rebane]
970N/A *) core: New directive RegisterHttpMethod for registering non-standard
970N/A HTTP methods. [Stefan Fritsch]
970N/A *) mod_xml2enc: Fix problems with charset conversion altering the
290N/A Content-Length. [Micha Lenk <micha lenk info>]
290N/A *) core: New directive HttpProtocol which allows to disable HTTP/0.9
911N/A support. [Stefan Fritsch]
1068N/A *) mod_allowhandlers: New module to forbid specific handlers for specific
911N/A directories. [Stefan Fritsch]
290N/A *) core: Be more correct about rejecting directives that cannot work in <If>
290N/A sections. [Stefan Fritsch]
290N/A *) core: Fix directives like LogLevel that need to know if they are invoked
970N/A *) mod_cache_disk: Resolve errors while revalidating disk-cached files on
*) mod_proxy: Add ability to configure the sticky session separator.
PR 53893. [<inu inusasha de>, Jim Jagielski]
*) mod_proxy_ftp: Fix segfaults on IPv4 requests to hosts with DNS AAAA records.
PR 40841. [Andrew Rucker Jones <arjones simultan dyndns org>,
<ast domdv de>, Jim Jagielski]
*) ap_expr: Add req_novary function that allows HTTP header lookups
without adding the name to the Vary header. [Stefan Fritsch]
*) mod_ssl: Change default for SSLCompression to off, as compression
causes security issues in most setups. (The so called "CRIME" attack).
*) syslog logging: Remove stray ", referer" at the end of some messages.
*) configure: Fix processing of --disable-FEATURE for various features.
*) "Iterate" directives: Report an error if no arguments are provided.
*) htpasswd, htdbm: Optionally read passwords from stdin, as more
secure alternative to -b. PR 40243. [Adomas Paltanavicius <adomas
paltanavicius gmail com>, Stefan Fritsch]
*) htpasswd, htdbm: Add support for bcrypt algorithm (requires
apr-util 1.5 or higher). PR 49288. [Stefan Fritsch]
*) htpasswd, htdbm: Put full 48bit of entropy into salt, improve
error handling. Add some of htpasswd's improvements to htdbm,
e.g. warn if password is truncated by crypt(). [Stefan Fritsch]
to more accurately report the negotiated protocol. PR 53916.
[Nicolás Pernas Maradei <nico emutex com>, Kaspar Brand]
*) mod_systemd: New module, for integration with systemd on Linux.
*) core: ErrorDocument now works for requests without a Host header.
*) --with-module: Fix failure to integrate them into some existing
module directories. PR 40097. [Jeff Trawick]
*) mod_headers: New params: %l for load averages, %i for an
idle percentage rating of httpd, and %b for a busy percentage
*) core: New functions to obtain load parameters: ap_get_sload()
and ap_get_loadavg(). [Jim Jagielski]
*) mod_cache_socache: New cache implementation backed by mod_socache
that replaces mod_mem_cache removed from httpd v2.2. [Graham
*) mod_auth_form: Support the expr parser in the
AuthFormLoginRequiredLocation, AuthFormLoginSuccessLocation and
AuthFormLogoutLocation directives. [Graham Leggett]
*) core: Add dirwalk_stat and pre_htaccess hooks, allowing mpm-itk
to be used without patches to httpd core. [Jeff Trawick]
*) mod_proxy: Allow for persistence of local changes (via the
balancer-manager) between graceful and normal restarts.
*) mod_slotmem: New provider function, fgrab(), which forces an
allocation of a slot. [Jim Jagielski]
*) mod_proxy_balancer: The nonce is only derived from the UUID iff
not set via the 'nonce' balancer param. [Jim Jagielski]
filters in Lua [Daniel Gruno]
*) core: Apply length limit when logging Status header values.
[Jeff Trawick, Chris Darroch]
*) mod_ssl: Match wildcard SSL certificate names in proxy mode.
*) WinNT MPM: Store pid and generation for each thread in scoreboard
to allow tracking of threads from exiting children via mod_status
or other such mechanisms. [Jeff Trawick]
*) mod_ssl: Catch missing or mismatched client
cert/key pairs with
*) mod_lua: Allow scripts handled by the lua-script handler to return
a status code to the client (such as a 302 or a 500) [Daniel Gruno]
*) mod_proxy_ajp: Fix crash in packet dump code when logging
with LogLevel trace7 or trace8. PR 53730. [Rainer Jung]
*) mod_cache: Wrong content type and character set when
mod_cache serves stale content because of a proxy error.
PR 53539. [Rainer Jung, Ruediger Pluem]
*) mod_lua: Decline handling 'lua-script' if the file doesn't exist,
rather than throwing an internal server error. [Daniel Gruno]
*) mod_lua: Add functions r:flush and r:sendfile as well as additional
request information to the request_rec structure. [Daniel Gruno]
*) mod_lua: Add a server scope for Lua states, which creates a pool of
states with managable minimum and maximum size. [Daniel Gruno]
*) core: Add post_perdir_config hook.
*) mod_lua: Add new directive, LuaMapHandler, for dynamically mapping
URIs to Lua scripts and functions using regular expressions.
*) mod_lua: Add new directive LuaCodeCache for controlling in-memory
caching of lua scripts. [Daniel Gruno]
- APIs: ap_log_pid(), ap_remove_pid, ap_read_pid()
- core: the scoreboard (ScoreBoardFile), pid file (PidFile), and
- mod_cache: thundering herd lock directory
- mod_lbmethod_heartbeat, mod_heartmonitor: heartbeat storage file
- mod_ldap: shared memory cache
- mod_socache_shmcb, mod_socache_dbm: shared memory or dbm for cache
*) mod_ssl: Add RFC 5878 support. [Ben Laurie]
*) mod_ssl: Add support for TLS-SRP (Secure Remote Password key exchange
for TLS, RFC 5054). PR 51075. [Quinn Slack <sqs cs stanford edu>,
Christophe Renou, Peter Sylvester]
*) core: Make ap_regcomp() return AP_REG_ESPACE if out of memory. Make
ap_pregcomp() abort if out of memory. This raises the minimum PCRE
requirement to version 6.0. PR 53284. [Stefan Fritsch]
*) suexec: Add --enable-suexec-capabilites support on Linux, to use
*) suexec: Add support for logging to syslog as an alternative to logging
to a file; configure --without-suexec-logfile --with-suexec-syslog.
*) mod_ssl: Add support for TLS Next Protocol Negotiation. PR 52210.
*) various modules, rotatelogs: Replace use of apr_file_write() with
apr_file_write_full() to prevent incomplete writes. PR 53131.
[Nicolas Viennot <apache viennot biz>, Stefan Fritsch]
*) cross-compile: allow to provide CC_FOR_BUILD so that gen_test_char will
be compiled by the build compiler instead of the host compiler.
Also set CC_FOR_BUILD to 'cc' when cross-compilation is detected.
PR 51257. [Guenter Knauf]
*) core: In maintainer mode, replace apr_palloc with a version that
initializes the allocated memory with non-zero values, except if
AP_DEBUG_NO_ALLOC_POISON is defined. [Stefan Fritsch]
*) mod_policy: Add a new testing module to help server administrators
enforce a configurable level of protocol compliance on their
servers and application servers behind theirs. [Graham Leggett]
*) mod_firehose: Add a new debugging module able to record traffic
passing through the server in such a way that connections
and/or requests be reconstructed and replayed. [Graham Leggett]
[Apache 2.5.0-dev includes those bug fixes and changes with the
Apache
2.4.xx tree as documented below, except as noted.]
Changes with Apache
2.4.x and later:
Changes with Apache
2.2.x and later:
Changes with Apache
2.0.x and later: