分类: 系统运维
2008-04-22 11:22:37
Apache基于域名的虚拟主机和基于IP的虚拟主机比较
基于IP的虚拟主机使用连接的IP地址来决定相应的虚拟主机。这样,你就需要为每个虚拟主机分配一个独立的IP地址。而基于域名的虚拟主机是根据客户端提交的HTTP头中标识主机名的部分决定的。使用这种技术,很多虚拟主机可以共享同一个IP地址。
基于域名的虚拟主机相对比较简单,因为你只需要配置你的DNS服务器将每个主机名映射到正确的IP地址,然后配置Apache HTTP服务器,令其辨识不同的主机名就可以了。基于域名的服务器也可以缓解IP地址不足的问题。所以,如果没有特殊原因使你必须使用基于IP的虚拟主机,您最好还是使用基于域名的虚拟主机。
下列情况下,你可能会想要使用基于IP的虚拟主机:一些古董级的客户端与基于域名的虚拟主机不兼容。为了与基于域名的虚拟主机兼容,客户端必须发送"Host"头。HTTP/1.1规范中对此做了要求。而所有现在常见的仅支持HTTP/1.0的旧版本浏览器都以附加的方式实现了这个要求。如果你又想支持这些老浏览器,又想使用基于域名的虚拟主机。我们提供了一个技术方案,你可以在本文末尾看到它。
SSL协议先天特性决定了基于域名的虚拟主机无法成为SSL安全服务器。 一些操作系统和网络设备实现的带宽管理技术无法在多个主机共享一个IP的情况下区别它们。
1. 使用基于域名的虚拟主机
相关模块 相关指令
core DocumentRoot
NameVirtualHost
ServerAlias
ServerName
ServerPath
为了使用基于域名的虚拟主机,你必须指定服务器IP地址(和可能的端口)来使主机接受请求,这个可以用NameVirtualHost指令来进行配置。如果服务器上所有的IP地址都会用到,你可以用"*"作为 NameVirtualHost的参数。如果你打算使用多端口(如运行SSL)你必须在参数中指定一个端口号,比如"*:80"。请注意,在NameVirtualHost指令中指定IP地址并不会使服务器自动侦听那个IP地址。另外,这里设定的IP地址必须对应服务器上的一个网络接口。
取消中心主机(Mainhost) 如果你想在现有的web服务器上增加虚拟主机,你必须也为现存的主机建造一个
比如你正在为mail.abcd.com域提供服务,而你又想在同一个ip地址上增加一个叫做email.abcd.com的虚拟主机,在httpd.conf中加入以下内容:
NameVirtualHost *:80
DocumentRoot /path/web/portal
ServerName mail.abcd.com
ErrorLog logs/mail-error_log
CustomLog logs/mail-access_log common
ServerAdmin
DocumentRoot /path/web/corp
ServerName email.abcd.com
ErrorLog logs/email-error_log
CustomLog logs/email-access_log common
当然,你可以用一个固定的IP地址来代替NameVirtualHost和
很多服务器希望自己能通过不只一个域名被访问。我们可以把ServerAlias指令放入
ServerAlias abcd.com *.abcd.com
这样,所有对域abcd.com的访问请求都将由虚拟主机mail.abcd.com处理。通配符标记"*"和"?"可以用于域名的匹配。当然你不能仅仅搞个名字然后把它放到ServerName或ServerAlias里就算完了。你必须先在你的DNS服务器上进行配置,将这些名字和您服务器上的一个IP地址建立映射关系。
最后,你可以把其他一些指令放入
这样,当一个请求到达的时候,服务器会首先检查它是否使用了一个能和NameVirtualHost相匹配的IP地址。如果能够匹配,它就会查找每个与这个IP地址相对应的
综上所述,第一个列出的虚拟主机充当了默认虚拟主机的角色。当一个IP地址与NameVirtualHost指令中的配置相符的时候,主服务器中的DocumentRoot将永远不会被用到。所以,如果你想创建一段特殊的配置用于处理不对应任何一个虚拟主机的请求的话,你只要简单的把这段配置放到