====== Apache Name-based Virtual Hosting ======
Note:\\
**The Configuration section in this document is outdated!**\\
**Please consult the official Apache documentation for actual config info.**
==== 1. IP-based versus Name-based Virtual Hosting ====
The Apache webserver supports two types of Virtual Hosting:
* IP-based Virtual Hosting
* Name-based Virtual Hosting
When using IP-based Virtual Hosting the webserver hosts multiple IP-addresses on its LAN card (IP-aliasing). All these IP-addresses refer to the same physical server. When a client (Webbrowser) refers to a particular IP-address the IP destination address in the IP-header will be distinctive however. The webserver can be set up such that it maps each IP-address to a different "DocumentRoot". This is called "IP-based Virtual Hosting".
Name-based Virtual Hosting takes this concept one step further.
On a particular IP-address the webserver additionally can be configured to take
in account the "Host" field of the HTTP/1.1 header:
((HTTP/1.0 (very old browsers) won't work, since there is no Host field.))
GET / HTTP/1.1
Host: www.company2.com
User-Agent: Mozilla/5.0 (X11; U; Linux i586; en-US; rv:0.9.9) ...
Accept: text/xml,application/xml,application/xhtml+xml,text/ht ...
...
This behaviour is called "Name-based Virtual Hosting".
==== 2. Example Apache Name-based Virtual Hosting ====
File: /etc/apache/httpd.conf:
NameVirtualHost typhoon
ServerName www.company1.com
DocumentRoot /var/www/company1
ServerName www.company2.com
DocumentRoot /var/www/company2
The first step is to enable "Name-based Virtual Hosting" on a particular IP-address of the server. This is the role of the "NameVirtualHost" directive. If the server has multiple IP-addresses, these addresses can be enabled for "Name-based Virtual Hosting" using multiple "NameVirtualHost" directives. As the argument of the directive an IP-address or a Hostname can be specified. \\ Note: If a Hostname is specified, the name must be resolvable into a server IP-address!
The next step is adding ... containers for each "NameVirtualHost". \\ Note that the argument string after "ServerName" must exactly match the "Host" field in the HTTP/1.1 header. Thus, when a client specifies a simple Hostname instead of the Fully Qualified Domain Name the "ServerName" directive will not match and the server will default to the first "DocumentRoot" for this IP-address.
If an IP-address is enabled for "Name-based Virtual Hosting" the main server "DocumentRoot" will never be consulted when referring to this IP-address. Other directives e.g. ... containers remain in effect however. You can override these directives by repeating them in a ... container.
====== . ======
Copyright (C) 2003 Integrated Services; Tux4u.nl\\
Author: Ing.J.M.Waldorp\\
apache-named-vhost 20030514; 2013-11-08