<?xml version="1.0" encoding="ISO-8859-1"?> <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> <html xmlns="http://www.w3.org/1999/xhtml" lang="en" xml:lang="en"><head><!-- XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX This file is generated from xml source: DO NOT EDIT XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX --> <title>Upgrading to 2.0 from 1.3 - Apache HTTP Server</title> <link href="./style/css/manual.css" rel="stylesheet" media="all" type="text/css" title="Main stylesheet" /> <link href="./style/css/manual-loose-100pc.css" rel="alternate stylesheet" media="all" type="text/css" title="No Sidebar - Default font size" /> <link href="./style/css/manual-print.css" rel="stylesheet" media="print" type="text/css" /> <link href="./images/favicon.ico" rel="shortcut icon" /></head> <body id="manual-page"><div id="page-header"> <p class="menu"><a href="./mod/">Modules</a> | <a href="./mod/directives.html">Directives</a> | <a href="./faq/">FAQ</a> | <a href="./glossary.html">Glossary</a> | <a href="./sitemap.html">Sitemap</a></p> <p class="apache">Apache HTTP Server Version 2.0</p> <img alt="" src="./images/feather.png" /></div> <div class="up"><a href="./"><img title="<-" alt="<-" src="./images/left.png" /></a></div> <div id="path"> <a href="http://www.apache.org/">Apache</a> > <a href="http://httpd.apache.org/">HTTP Server</a> > <a href="http://httpd.apache.org/docs-project/">Documentation</a> > <a href="./">Version 2.0</a></div><div id="page-content"><div id="preamble"><h1>Upgrading to 2.0 from 1.3</h1> <p>In order to assist folks upgrading, we maintain a document describing information critical to existing Apache users. These are intended to be brief notes, and you should be able to find more information in either the <a href="new_features_2_0.html">New Features</a> document, or in the <code>src/CHANGES</code> file.</p> </div> <div id="quickview"><ul id="toc"><li><img alt="" src="./images/down.png" /> <a href="#compile-time">Compile-Time Configuration Changes</a></li> <li><img alt="" src="./images/down.png" /> <a href="#run-time">Run-Time Configuration Changes</a></li> <li><img alt="" src="./images/down.png" /> <a href="#misc">Misc Changes</a></li> <li><img alt="" src="./images/down.png" /> <a href="#third-party">Third Party Modules</a></li> </ul><h3>See also</h3><ul class="seealso"><li><a href="new_features_2_0.html">Overview of new features in Apache 2.0</a></li></ul></div> <div class="top"><a href="#page-header"><img alt="top" src="./images/up.png" /></a></div> <div class="section"> <h2><a name="compile-time" id="compile-time">Compile-Time Configuration Changes</a></h2> <ul> <li>Apache now uses an <code>autoconf</code> and <code>libtool</code> system for <a href="install.html">configuring the build processes</a>. Using this system is similar to, but not the same as, using the APACI system in Apache 1.3.</li> <li>In addition to the usual selection of modules which you can choose to compile, Apache 2.0 has moved the main part of request processing into <a href="mpm.html">Multi-Processing Modules</a> (MPMs).</li> </ul> </div><div class="top"><a href="#page-header"><img alt="top" src="./images/up.png" /></a></div> <div class="section"> <h2><a name="run-time" id="run-time">Run-Time Configuration Changes</a></h2> <ul> <li>Many directives that were in the core server in Apache 1.3 are now in the MPMs. If you wish the behavior of the server to be as similar as possible to the behavior of Apache 1.3, you should select the <code class="module"><a href="./mod/prefork.html">prefork</a></code> MPM. Other MPMs will have different directives to control process creation and request processing.</li> <li>The <a href="mod/mod_proxy.html">proxy module</a> has been revamped to bring it up to HTTP/1.1. Among the important changes, proxy access control is now placed inside a <code class="directive"><a href="./mod/mod_proxy.html#proxy"><Proxy></a></code> block rather than a <code><Directory proxy:></code> block.</li> <li>The handling of <code>PATH_INFO</code> (trailing path information after the true filename) has changed for some modules. Modules that were previously implemented as a handler but are now implemented as a filter may no longer accept requests with <code>PATH_INFO</code>. Filters such as <a href="mod/mod_include.html">INCLUDES</a> are implemented on top of the core handler, and therefore reject requests with <code>PATH_INFO</code>. You can use the <code class="directive"><a href="./mod/core.html#acceptpathinfo">AcceptPathInfo</a></code> directive to force the core handler to accept requests with <code>PATH_INFO</code> and thereby restore the ability to use <code>PATH_INFO</code> in server-side includes.</li> <li>The <code class="directive"><a href="./mod/mod_negotiation.html#cachenegotiateddocs">CacheNegotiatedDocs</a></code> directive now takes the argument <code>on</code> or <code>off</code>. Existing instances of <code class="directive">CacheNegotiatedDocs</code> should be replaced with <code>CacheNegotiatedDocs on</code>.</li> <li> The <code class="directive"><a href="./mod/core.html#errordocument">ErrorDocument</a></code> directive no longer uses a quote at the beginning of the argument to indicate a text message. Instead, you should enclose the message in double quotes. For example, existing instances of <div class="example"><p><code> ErrorDocument 403 "Some Message </code></p></div> should be replaced with <div class="example"><p><code> ErrorDocument 403 "Some Message" </code></p></div> As long as the second argument is not a valid URL or pathname, it will be treated as a text message. </li> <li>The <code>AccessConfig</code> and <code>ResourceConfig</code> directives no longer exist. Existing instances of these directives can be replaced with the <code class="directive"><a href="./mod/core.html#include">Include</a></code> directive which has equivalent functionality. If you were making use of the default values of these directives without including them in the configuration files, you may need to add <code>Include conf/access.conf</code> and <code>Include conf/srm.conf</code> to your <code>httpd.conf</code>. In order to assure that Apache reads the configuration files in the same order as was implied by the older directives, the <code class="directive"><a href="./mod/core.html#include">Include</a></code> directives should be placed at the end of <code>httpd.conf</code>, with the one for <code>srm.conf</code> preceding the one for <code>access.conf</code>.</li> <li>The <code>BindAddress</code> and <code>Port</code> directives no longer exist. Equivalent functionality is provided with the more flexible <code class="directive"><a href="./mod/mpm_common.html#listen">Listen</a></code> directive.</li> <li>Another use of the <code>Port</code> directive in Apache-1.3 was setting the port number to be used in self-referential URL's. The Apache-2.0 equivalent is the new <code class="directive"><a href="./mod/core.html#servername">ServerName</a></code> syntax: it has been changed to allow specifying both the hostname <em>and</em> the port number for self-referential URL's in one directive.</li> <li>The <code>ServerType</code> directive no longer exists. The method used to serve requests is now determined by the selection of MPM. There is currently no MPM designed to be launched by inetd.</li> <li>The <code>mod_log_agent</code> and <code>mod_log_referer</code> modules which provided the <code>AgentLog</code>, <code>RefererLog</code> and <code>RefererIgnore</code> directives have been removed. Agent and referer logs are still available using the <code class="directive"><a href="./mod/mod_log_config.html#customlog">CustomLog</a></code> directive of <code class="module"><a href="./mod/mod_log_config.html">mod_log_config</a></code>.</li> <li>The <code>AddModule</code> and <code>ClearModuleList</code> directives no longer exist. These directives were used to ensure that modules could be enabled in the correct order. The new Apache 2.0 API allows modules to explicitly specify their ordering, eliminating the need for these directives.</li> <li>The <code>FancyIndexing</code> directive has been removed. The same functionality is available through the <code>FancyIndexing</code> option to the <code class="directive"><a href="./mod/mod_autoindex.html#indexoptions">IndexOptions</a></code> directive.</li> <li>The MultiViews content-negotiation technique provided by <code class="module"><a href="./mod/mod_negotiation.html">mod_negotiation</a></code> has become more strict in its default file matching. It will select only from <em>negotiable</em> files. The old behavior can be restored using the <code class="directive"><a href="./mod/mod_mime.html#multiviewsmatch">MultiviewsMatch</a></code> directive.</li> </ul> </div><div class="top"><a href="#page-header"><img alt="top" src="./images/up.png" /></a></div> <div class="section"> <h2><a name="misc" id="misc">Misc Changes</a></h2> <ul> <li>The module <code class="module"><a href="./mod/mod_auth_digest.html">mod_auth_digest</a></code>, which was experimental in Apache 1.3, is now a standard module.</li> <li>The <code>mod_mmap_static</code> module, which was experimental in Apache 1.3, has been replaced with <code class="module"><a href="./mod/mod_file_cache.html">mod_file_cache</a></code>.</li> <li>The distribution has been completely reorganized so that it no longer contains an independent <code>src</code> directory. Instead, the sources are logically organized under the main distribution directory, and installations of the compiled server should be directed to a separate directory.</li> </ul> </div><div class="top"><a href="#page-header"><img alt="top" src="./images/up.png" /></a></div> <div class="section"> <h2><a name="third-party" id="third-party">Third Party Modules</a></h2> <p>Extensive changes were made to the server API in Apache 2.0. Existing modules designed for the Apache 1.3 API will <strong>not</strong> work in Apache 2.0 without modification. Details are provided in the <a href="developer/">developer documentation</a>.</p> </div></div> <div id="footer"> <p class="apache">Maintained by the <a href="http://httpd.apache.org/docs-project/">Apache HTTP Server Documentation Project</a></p> <p class="menu"><a href="./mod/">Modules</a> | <a href="./mod/directives.html">Directives</a> | <a href="./faq/">FAQ</a> | <a href="./glossary.html">Glossary</a> | <a href="./sitemap.html">Sitemap</a></p></div> </body></html>