mod_vhost_alias.xml revision 7db9f691a00ead175b03335457ca296a33ddf31b
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen<?xml version="1.0"?>
0d26a2bd71224b954baab529bbadc4d676c35b95slive<!DOCTYPE modulesynopsis SYSTEM "/style/modulesynopsis.dtd">
e942c741056732f50da2074b36fe59805d370650slive<?xml-stylesheet type="text/xsl" href="/style/manual.en.xsl"?>
7db9f691a00ead175b03335457ca296a33ddf31bnd<modulesynopsis metafile="mod_vhost_alias.xml.meta">
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen<name>mod_vhost_alias</name>
6eef889fc0b7cd42c4c8ca7e8e094dc2c0b030fcslive<description>Provides for dynamically configured mass virtual
6eef889fc0b7cd42c4c8ca7e8e094dc2c0b030fcslivehosting</description>
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen<status>Extension</status>
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen<sourcefile>mod_vhost_alias.c</sourcefile>
0d26a2bd71224b954baab529bbadc4d676c35b95slive<identifier>vhost_alias_module</identifier>
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen<summary>
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen <p>This module creates dynamically configured virtual hosts, by
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen allowing the IP address and/or the <code>Host:</code> header of
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen the HTTP request to be used as part of the pathname to
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen determine what files to serve. This allows for easy use of a
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen huge number of virtual hosts with similar configurations.</p>
0dcb04cfa4202dd443d362f20db0de81faa2eb17nd
0dcb04cfa4202dd443d362f20db0de81faa2eb17nd <note><title>Note</title>
0dcb04cfa4202dd443d362f20db0de81faa2eb17nd <p>If <module>mod_alias</module> or <module>mod_userdir</module> are
0dcb04cfa4202dd443d362f20db0de81faa2eb17nd used for translating URIs to filenames, they will override the
0dcb04cfa4202dd443d362f20db0de81faa2eb17nd directives of <module>mod_vhost_alias</module> described below. For
0dcb04cfa4202dd443d362f20db0de81faa2eb17nd example, the following configuration will map <code>
0dcb04cfa4202dd443d362f20db0de81faa2eb17nd /cgi-bin/script.pl</code> to <code>
0dcb04cfa4202dd443d362f20db0de81faa2eb17nd /usr/local/apache2/cgi-bin/script.pl</code> in all cases:</p>
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen
0dcb04cfa4202dd443d362f20db0de81faa2eb17nd <example>
0dcb04cfa4202dd443d362f20db0de81faa2eb17nd ScriptAlias /cgi-bin/ /usr/local/apache2/cgi-bin/<br />
0dcb04cfa4202dd443d362f20db0de81faa2eb17nd VirtualScriptAlias /never/found/%0/cgi-bin/
0dcb04cfa4202dd443d362f20db0de81faa2eb17nd </example>
0dcb04cfa4202dd443d362f20db0de81faa2eb17nd </note>
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen</summary>
0dcb04cfa4202dd443d362f20db0de81faa2eb17nd
0dcb04cfa4202dd443d362f20db0de81faa2eb17nd<seealso><directive module="core">UseCanonicalName</directive></seealso>
0dcb04cfa4202dd443d362f20db0de81faa2eb17nd<seealso><a href="/vhosts/mass.html">Dynamically configured mass
0dcb04cfa4202dd443d362f20db0de81faa2eb17nd virtual hosting</a></seealso>
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen
115d4988233465895664ae2e19ba6c281281a00bnd<section id="interpol">
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen <title>Directory Name Interpolation</title>
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen <p>All the directives in this module interpolate a string into
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen a pathname. The interpolated string (henceforth called the
115d4988233465895664ae2e19ba6c281281a00bnd "name") may be either the server name (see the <directive
115d4988233465895664ae2e19ba6c281281a00bnd module="core">UseCanonicalName</directive>
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen directive for details on how this is determined) or the IP
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen address of the virtual host on the server in dotted-quad
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen format. The interpolation is controlled by specifiers inspired
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen by <code>printf</code> which have a number of formats:</p>
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen<table>
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen<tr><td><code>%%</code></td>
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen<td>insert a <code>%</code></td></tr>
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen<tr><td><code>%p</code></td>
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen<td>insert the port number of the virtual host</td></tr>
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen<tr><td><code>%N.M</code></td>
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen<td>insert (part of) the name</td></tr>
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen</table>
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen <p><code>N</code> and <code>M</code> are used to specify
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen substrings of the name. <code>N</code> selects from the
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen dot-separated components of the name, and <code>M</code>
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen selects characters within whatever <code>N</code> has selected.
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen <code>M</code> is optional and defaults to zero if it isn't
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen present; the dot must be present if and only if <code>M</code>
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen is present. The interpretation is as follows:</p>
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen <table>
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen <tr><td><code>0</code></td>
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen <td>the whole name</td></tr>
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen <tr><td><code>1</code></td>
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen <td>the first part</td></tr>
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen <tr><td><code>2</code></td>
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen <td>the second part</td></tr>
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen <tr><td><code>-1</code></td>
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen <td>the last part</td></tr>
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen <tr><td><code>-2</code></td>
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen <td>the penultimate part</td></tr>
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen <tr><td><code>2+</code></td>
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen <td>the second and all subsequent parts</td></tr>
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen <tr><td><code>-2+</code></td>
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen <td>the penultimate and all preceding parts</td></tr>
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen <tr><td><code>1+</code> and <code>-1+</code></td>
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen <td>the same as <code>0</code></td></tr>
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen </table>
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen <p>If <code>N</code> or <code>M</code> is greater than the number
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen of parts available a single underscore is interpolated. </p>
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen</section>
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen
115d4988233465895664ae2e19ba6c281281a00bnd<section id="examples">
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen <title>Examples</title>
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen <p>For simple name-based virtual hosts you might use the
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen following directives in your server configuration file:</p>
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen
115d4988233465895664ae2e19ba6c281281a00bnd <example>
115d4988233465895664ae2e19ba6c281281a00bnd UseCanonicalName Off<br />
115d4988233465895664ae2e19ba6c281281a00bnd VirtualDocumentRoot /usr/local/apache/vhosts/%0
115d4988233465895664ae2e19ba6c281281a00bnd </example>
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen <p>A request for
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen <code>http://www.example.com/directory/file.html</code> will be
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen satisfied by the file
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen <code>/usr/local/apache/vhosts/www.example.com/directory/file.html</code>.
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen </p>
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen <p>For a very large number of virtual hosts it is a good idea
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen to arrange the files to reduce the size of the
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen <code>vhosts</code> directory. To do this you might use the
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen following in your configuration file:</p>
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen
115d4988233465895664ae2e19ba6c281281a00bnd <example>
115d4988233465895664ae2e19ba6c281281a00bnd UseCanonicalName Off<br />
115d4988233465895664ae2e19ba6c281281a00bnd VirtualDocumentRoot /usr/local/apache/vhosts/%3+/%2.1/%2.2/%2.3/%2
115d4988233465895664ae2e19ba6c281281a00bnd </example>
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen <p>A request for
115d4988233465895664ae2e19ba6c281281a00bnd <code>http://www.domain.example.com/directory/file.html</code>
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen will be satisfied by the file
115d4988233465895664ae2e19ba6c281281a00bnd <code>/usr/local/apache/vhosts/example.com/d/o/m/domain/directory/file.html</code>.</p>
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen <p>A more even spread of files can be achieved by hashing from the
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen end of the name, for example: </p>
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen<example>
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen VirtualDocumentRoot /usr/local/apache/vhosts/%3+/%2.-1/%2.-2/%2.-3/%2
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen</example>
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen <p>The example request would come from
115d4988233465895664ae2e19ba6c281281a00bnd <code>/usr/local/apache/vhosts/example.com/n/i/a/domain/directory/file.html</code>.</p>
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen <p>Alternatively you might use: </p>
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen<example>
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen VirtualDocumentRoot /usr/local/apache/vhosts/%3+/%2.1/%2.2/%2.3/%2.4+
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen</example>
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen <p>The example request would come from
115d4988233465895664ae2e19ba6c281281a00bnd <code>/usr/local/apache/vhosts/example.com/d/o/m/ain/directory/file.html</code>.</p>
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen <p>For IP-based virtual hosting you might use the following in
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen your configuration file:</p>
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen
115d4988233465895664ae2e19ba6c281281a00bnd <example>
115d4988233465895664ae2e19ba6c281281a00bnd UseCanonicalName DNS<br />
115d4988233465895664ae2e19ba6c281281a00bnd VirtualDocumentRootIP /usr/local/apache/vhosts/%1/%2/%3/%4/docs<br />
115d4988233465895664ae2e19ba6c281281a00bnd VirtualScriptAliasIP /usr/local/apache/vhosts/%1/%2/%3/%4/cgi-bin
115d4988233465895664ae2e19ba6c281281a00bnd </example>
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen <p>A request for
115d4988233465895664ae2e19ba6c281281a00bnd <code>http://www.domain.example.com/directory/file.html</code>
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen would be satisfied by the file
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen <code>/usr/local/apache/vhosts/10/20/30/40/docs/directory/file.html</code>
115d4988233465895664ae2e19ba6c281281a00bnd if the IP address of <code>www.domain.example.com</code> were
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen 10.20.30.40. A request for
115d4988233465895664ae2e19ba6c281281a00bnd <code>http://www.domain.example.com/cgi-bin/script.pl</code> would
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen be satisfied by executing the program
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen <code>/usr/local/apache/vhosts/10/20/30/40/cgi-bin/script.pl</code>.</p>
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen <p>If you want to include the <code>.</code> character in a
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen <code>VirtualDocumentRoot</code> directive, but it clashes with
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen a <code>%</code> directive, you can work around the problem in
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen the following way:</p>
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen<example>
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen VirtualDocumentRoot /usr/local/apache/vhosts/%2.0.%3.0
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen</example>
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen <p>A request for
115d4988233465895664ae2e19ba6c281281a00bnd <code>http://www.domain.example.com/directory/file.html</code>
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen will be satisfied by the file
115d4988233465895664ae2e19ba6c281281a00bnd <code>/usr/local/apache/vhosts/domain.example/directory/file.html</code>.</p>
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen <p>The <directive module="mod_log_config">LogFormat</directive>
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen directives <code>%V</code> and <code>%A</code> are useful
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen in conjunction with this module.</p>
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen</section>
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen<directivesynopsis>
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen<name>VirtualDocumentRoot</name>
0d26a2bd71224b954baab529bbadc4d676c35b95slive<description>Dynamically configure the location of the document root
0d26a2bd71224b954baab529bbadc4d676c35b95slivefor a given virtual host</description>
115d4988233465895664ae2e19ba6c281281a00bnd<syntax>VirtualDocumentRoot <em>interpolated-directory</em>|none</syntax>
115d4988233465895664ae2e19ba6c281281a00bnd<default>VirtualDocumentRoot none</default>
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen<contextlist>
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen<context>server config</context>
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen<context>virtual host</context>
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen</contextlist>
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen<usage>
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen
115d4988233465895664ae2e19ba6c281281a00bnd <p>The <directive>VirtualDocumentRoot</directive> directive allows you to
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen determine where Apache will find your documents based on the
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen value of the server name. The result of expanding
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen <em>interpolated-directory</em> is used as the root of the
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen document tree in a similar manner to the <directive
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen module="core">DocumentRoot</directive> directive's argument.
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen If <em>interpolated-directory</em> is <code>none</code> then
115d4988233465895664ae2e19ba6c281281a00bnd <directive>VirtualDocumentRoot</directive> is turned off. This directive
115d4988233465895664ae2e19ba6c281281a00bnd cannot be used in the same context as <directive
115d4988233465895664ae2e19ba6c281281a00bnd module="mod_vhost_alias">VirtualDocumentRootIP</directive>.</p>
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen</usage>
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen</directivesynopsis>
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen<directivesynopsis>
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen<name>VirtualDocumentRootIP</name>
0d26a2bd71224b954baab529bbadc4d676c35b95slive<description>Dynamically configure the location of the document root
0d26a2bd71224b954baab529bbadc4d676c35b95slivefor a given virtual host</description>
115d4988233465895664ae2e19ba6c281281a00bnd<syntax>VirtualDocumentRootIP <em>interpolated-directory</em>|none</syntax>
115d4988233465895664ae2e19ba6c281281a00bnd<default>VirtualDocumentRootIP none</default>
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen<contextlist>
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen<context>server config</context>
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen<context>virtual host</context>
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen</contextlist>
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen<usage>
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen
115d4988233465895664ae2e19ba6c281281a00bnd<p>The <directive>VirtualDocumentRootIP</directive> directive is like the
115d4988233465895664ae2e19ba6c281281a00bnd <directive module="mod_vhost_alias">VirtualDocumentRoot</directive>
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen directive, except that it uses the IP address of the server end
115d4988233465895664ae2e19ba6c281281a00bnd of the connection for directory interpolation instead of the server
115d4988233465895664ae2e19ba6c281281a00bnd name.</p>
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen</usage>
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen</directivesynopsis>
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen<directivesynopsis>
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen<name>VirtualScriptAlias</name>
0d26a2bd71224b954baab529bbadc4d676c35b95slive<description>Dynamically configure the location of the CGI directory for
0d26a2bd71224b954baab529bbadc4d676c35b95slivea given virtual host</description>
115d4988233465895664ae2e19ba6c281281a00bnd<syntax>VirtualScriptAlias <em>interpolated-directory</em>|none</syntax>
115d4988233465895664ae2e19ba6c281281a00bnd<default>VirtualScriptAlias none</default>
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen<contextlist>
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen<context>server config</context>
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen<context>virtual host</context>
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen</contextlist>
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen<usage>
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen
115d4988233465895664ae2e19ba6c281281a00bnd <p>The <directive>VirtualScriptAlias</directive> directive allows you to
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen determine where Apache will find CGI scripts in a similar
115d4988233465895664ae2e19ba6c281281a00bnd manner to <directive module="mod_vhost_alias"
115d4988233465895664ae2e19ba6c281281a00bnd >VirtualDocumentRoot</directive> does for other documents. It matches
115d4988233465895664ae2e19ba6c281281a00bnd requests for URIs starting <code>/cgi-bin/</code>, much like <directive
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen module="mod_alias">ScriptAlias</directive>
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen <code>/cgi-bin/</code> would.</p>
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen</usage>
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen</directivesynopsis>
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen<directivesynopsis>
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen<name>VirtualScriptAliasIP</name>
0d26a2bd71224b954baab529bbadc4d676c35b95slive<description>Dynamically configure the location of the cgi directory for
0d26a2bd71224b954baab529bbadc4d676c35b95slivea given virtual host</description>
115d4988233465895664ae2e19ba6c281281a00bnd<syntax>VirtualScriptAliasIP <em>interpolated-directory</em>|none</syntax>
115d4988233465895664ae2e19ba6c281281a00bnd<default>VirtualScriptAliasIP none</default>
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen<contextlist>
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen<context>server config</context>
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen<context>virtual host</context>
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen</contextlist>
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen<usage>
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen
115d4988233465895664ae2e19ba6c281281a00bnd <p>The <directive>VirtualScriptAliasIP</directive> directive is like the
115d4988233465895664ae2e19ba6c281281a00bnd <directive module="mod_vhost_alias">VirtualScriptAlias</directive>
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen directive, except that it uses the IP address of the server end
115d4988233465895664ae2e19ba6c281281a00bnd of the connection for directory interpolation instead of the server
115d4988233465895664ae2e19ba6c281281a00bnd name.</p>
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen </usage>
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen</directivesynopsis>
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen</modulesynopsis>
63ab8205d2d1e2e4b6e7e4f81adde8782a85ea9drbowen