Apache虚拟主机示例

本文向你展示了如何在一个服务器上通过基于域名的或是基于IP的虚拟主机来部署多个web站点。另外关于如何在一个代理服务器后构建基于多个服务器的站点的说明文档也很快就会出来。GhTLinux联盟
topGhTLinux联盟
在一个IP地址上运行多个基于域名的web站点GhTLinux联盟
GhTLinux联盟
您的服务器有只一个IP地址,而在DNS中有很多域名(CNAMES)映射到这个机器。您而您想要在这个机器上运行www.example.com和www.example.org两个站点。GhTLinux联盟
注意GhTLinux联盟
GhTLinux联盟
在您的Apache服务器配置中创建一个虚拟主机并不会自动在您的DNS中对主机名做相应更新。您必须自己在DNS中添加域名来指向您的IP地址。否则别人是无法看到您的web站点的。您可以在您的hosts文件中添加这一条目来进行测试,但这种方法仅适用于那些有这些hosts文件的机器来使用。GhTLinux联盟
服务器配置GhTLinux联盟
GhTLinux联盟
# 确保Apache在监听80端口GhTLinux联盟
Listen 80GhTLinux联盟
GhTLinux联盟
# 为虚拟主机在所有IP地址上监听GhTLinux联盟
NameVirtualHost *:80GhTLinux联盟
GhTLinux联盟
GhTLinux联盟
DocumentRoot /www/example1GhTLinux联盟
ServerName www.example.comGhTLinux联盟
GhTLinux联盟
# 你可以在这里添加其他指令GhTLinux联盟
GhTLinux联盟
GhTLinux联盟
GhTLinux联盟
GhTLinux联盟
DocumentRoot /www/example2GhTLinux联盟
ServerName www.example.orgGhTLinux联盟
GhTLinux联盟
# 你可以在这里添加其他指令GhTLinux联盟
GhTLinux联盟
GhTLinux联盟
GhTLinux联盟
因为星号匹配所有IP地址,所以主服务器不接收任何请求。因为www.example.com首先出现在配置文件中,所以它拥有最高优先级,可以认为是默认或主服务器。这意味着如果一个请求不能与某个ServerName指令相匹配,它将会由第一个 段所伺服。GhTLinux联盟
注意GhTLinux联盟
GhTLinux联盟
如果您愿意,您可以用确定的IP地址来取代"*"。在这种情况下,VirtualHost的参数必须与NameVirtualHost的参数相符:GhTLinux联盟
GhTLinux联盟
NameVirtualHost 172.20.30.40GhTLinux联盟
GhTLinux联盟
GhTLinux联盟
# 其他 ...GhTLinux联盟
GhTLinux联盟
然而,当您的IP地址无法确定的时候,使用"*"是很方便的,比如说,您的ISP给您配置的是动态IP地址,而您又使用了某种动态域名解析系统时。因为"*"匹配任何IP地址,所以在这种情况下,不论IP地址如何变化,您都不需要另外进行配置。GhTLinux联盟
GhTLinux联盟
上述配置就是您在绝大多数情况下使用基于域名的虚拟主机时将要用到的。事实上,仅在一种情况下这样的配置不会让您满意:您想为不同的IP地址或是端口提供不同的内容。GhTLinux联盟
topGhTLinux联盟
在多于一个IP的情况下使用基于域名的虚拟主机。GhTLinux联盟
注意GhTLinux联盟
GhTLinux联盟
在这里讨论的任何技术都可以推广到使用任意数量的IP地址。GhTLinux联盟
GhTLinux联盟
服务器有两个IP地址。一个(172.20.30.40)用于主服务器server.domain.com ,另外一个(172.20.30.50)用于构建两个或多个虚拟主机。GhTLinux联盟
服务器配置GhTLinux联盟
GhTLinux联盟
Listen 80GhTLinux联盟
GhTLinux联盟
# "主"服务器运行于:172.20.30.40GhTLinux联盟
ServerName server.domain.comGhTLinux联盟
DocumentRoot /www/mainserverGhTLinux联盟
GhTLinux联盟
# 这是另外一个IP地址GhTLinux联盟
NameVirtualHost 172.20.30.50GhTLinux联盟
GhTLinux联盟
GhTLinux联盟
DocumentRoot /www/example1GhTLinux联盟
ServerName www.example.comGhTLinux联盟
GhTLinux联盟
# 你可以在这里添加其他指令 ...GhTLinux联盟
GhTLinux联盟
GhTLinux联盟
GhTLinux联盟
GhTLinux联盟
DocumentRoot /www/example2GhTLinux联盟
ServerName www.example.orgGhTLinux联盟
GhTLinux联盟
# 你可以在这里添加其他指令 ...GhTLinux联盟
GhTLinux联盟
GhTLinux联盟
GhTLinux联盟
任何不是针对172.20.30.50的请求都将由主服务器来伺服。而提交给172.20.30.50却没有主机名或没有"Host:"头的请求,都将由www.example.com伺服。GhTLinux联盟
topGhTLinux联盟
在不同的IP的地址(比如一个内部和一个外部地址)上提供相同的内容GhTLinux联盟
GhTLinux联盟
服务器有两个IP地址(192.168.1.1和172.20.30.40)。这个机器位于内部(局域网)网络和外部(广域网)之间。在外部,域名server.example.com指向外部地址(172.20.30.40),而在内部则指向内部地址(192.168.1.1)。GhTLinux联盟
GhTLinux联盟
服务器可以为来自内部和外部的请求提供同样的内容,您只需要一个 配置段就可以了。GhTLinux联盟
服务器配置GhTLinux联盟
GhTLinux联盟
NameVirtualHost 192.168.1.1GhTLinux联盟
NameVirtualHost 172.20.30.40GhTLinux联盟
GhTLinux联盟
GhTLinux联盟
DocumentRoot /www/server1GhTLinux联盟
ServerName server.example.comGhTLinux联盟
ServerAlias serverGhTLinux联盟
GhTLinux联盟
GhTLinux联盟
现在,从不同的网络提交的请求都会由同一个 段来伺服。GhTLinux联盟
注意GhTLinux联盟
GhTLinux联盟
在内网中,您可以使用server这个名字来代替server.example.com这个全名。GhTLinux联盟
GhTLinux联盟
跟上面一样,在上述的例子里,您可以用"*"来代替具体的IP地址,这样就可以对所有的地址都返回相同的内容了。GhTLinux联盟
topGhTLinux联盟
在不同的端口上运行不同的站点GhTLinux联盟
GhTLinux联盟
如果您想让同一个IP的不同端口伺服多个域名。您可以借助在NameVirtualHost指令中定义端口的方法来达到这个目的。如果您想使用不带"name:port"的 或是直接用Listen指令,您的配置将无法生效。GhTLinux联盟
服务器配置GhTLinux联盟
GhTLinux联盟
Listen 80GhTLinux联盟
Listen 8080GhTLinux联盟
GhTLinux联盟
NameVirtualHost 172.20.30.40:80GhTLinux联盟
NameVirtualHost 172.20.30.40:8080GhTLinux联盟
GhTLinux联盟
GhTLinux联盟
ServerName www.example.comGhTLinux联盟
DocumentRoot /www/domain-80GhTLinux联盟
GhTLinux联盟
GhTLinux联盟
GhTLinux联盟
ServerName www.example.comGhTLinux联盟
DocumentRoot /www/domain-8080GhTLinux联盟
GhTLinux联盟
GhTLinux联盟
GhTLinux联盟
ServerName www.example.orgGhTLinux联盟
DocumentRoot /www/otherdomain-80GhTLinux联盟
GhTLinux联盟
GhTLinux联盟
GhTLinux联盟
ServerName www.example.orgGhTLinux联盟
DocumentRoot /www/otherdomain-8080GhTLinux联盟
GhTLinux联盟
topGhTLinux联盟
建立基于IP的虚拟主机GhTLinux联盟
GhTLinux联盟
一个有两个IP地址(172.20.30.40和172.20.30.50)分别对应域名www.example.com和www.example.org的配置如下:GhTLinux联盟
服务器配置GhTLinux联盟
GhTLinux联盟
Listen 80GhTLinux联盟
GhTLinux联盟
GhTLinux联盟
DocumentRoot /www/example1GhTLinux联盟
ServerName www.example.comGhTLinux联盟
GhTLinux联盟
GhTLinux联盟
GhTLinux联盟
DocumentRoot /www/example2GhTLinux联盟
ServerName www.example.orgGhTLinux联盟
GhTLinux联盟
GhTLinux联盟
如果存在主服务器,那么对没有出现在任一个 段中的请求(比如,对localhost的请求)都会由主服务器来伺服。GhTLinux联盟
topGhTLinux联盟
混用基于端口和基于IP的虚拟主机GhTLinux联盟
GhTLinux联盟
如果您的服务器有两个IP地址(172.20.30.40和172.20.30.50)分别对应域名www.example.com和www.example.org 。对每个域名,您都希望在80端口和8080端口发布您的网站。您可以这样配置:GhTLinux联盟
服务器配置GhTLinux联盟
GhTLinux联盟
Listen 172.20.30.40:80GhTLinux联盟
Listen 172.20.30.40:8080GhTLinux联盟
Listen 172.20.30.50:80GhTLinux联盟
Listen 172.20.30.50:8080GhTLinux联盟
GhTLinux联盟
GhTLinux联盟
DocumentRoot /www/example1-80GhTLinux联盟
ServerName www.example.comGhTLinux联盟
GhTLinux联盟
GhTLinux联盟
GhTLinux联盟
DocumentRoot /www/example1-8080GhTLinux联盟
ServerName www.example.comGhTLinux联盟
GhTLinux联盟
GhTLinux联盟
GhTLinux联盟
DocumentRoot /www/example2-80GhTLinux联盟
ServerName www.example.orgGhTLinux联盟
GhTLinux联盟
GhTLinux联盟
GhTLinux联盟
DocumentRoot /www/example2-8080GhTLinux联盟
ServerName www.example.orgGhTLinux联盟
GhTLinux联盟
topGhTLinux联盟
混用基于域名和基于IP的虚拟主机GhTLinux联盟
GhTLinux联盟
您想在一些地址上配置基于域名的虚拟主机而在另外一些地址上配置基于IP的虚拟主机。GhTLinux联盟
服务器配置GhTLinux联盟
GhTLinux联盟
Listen 80GhTLinux联盟
GhTLinux联盟
NameVirtualHost 172.20.30.40GhTLinux联盟
GhTLinux联盟
GhTLinux联盟
DocumentRoot /www/example1GhTLinux联盟
ServerName www.example.comGhTLinux联盟
GhTLinux联盟
GhTLinux联盟
GhTLinux联盟
DocumentRoot /www/example2GhTLinux联盟
ServerName www.example.orgGhTLinux联盟
GhTLinux联盟
GhTLinux联盟
GhTLinux联盟
DocumentRoot /www/example3GhTLinux联盟
ServerName www.example3.netGhTLinux联盟
GhTLinux联盟
GhTLinux联盟
# IP-basedGhTLinux联盟
GhTLinux联盟
DocumentRoot /www/example4GhTLinux联盟
ServerName www.example4.eduGhTLinux联盟
GhTLinux联盟
GhTLinux联盟
GhTLinux联盟
DocumentRoot /www/example5GhTLinux联盟
ServerName www.example5.govGhTLinux联盟
GhTLinux联盟
topGhTLinux联盟
将 和mod_proxy模块一起使用GhTLinux联盟
GhTLinux联盟
下面的例子允许一个前端机器代理一个运行在其他机器上的虚拟主机。在如下示例中,在192.168.111.2机器上配置了一个同名的虚拟主机。这样,万一在同一台机器上代理了多个主机名,ProxyPreserveHost On 指令能确保指定的主机名顺利通过代理。GhTLinux联盟
GhTLinux联盟
GhTLinux联盟
ProxyPreserveHost OnGhTLinux联盟
ProxyPass / http://192.168.111.2GhTLinux联盟
ProxyPassReverse / http://192.168.111.2/GhTLinux联盟
ServerName hostname.example.comGhTLinux联盟
GhTLinux联盟
topGhTLinux联盟
使用"_default_"虚拟主机GhTLinux联盟
为所有端口配置"_default_"虚拟主机GhTLinux联盟
GhTLinux联盟
这样配置可以捕获所有指向没指定的IP地址和端口的请求。比如:一个没被任何虚拟主机使用的地址/端口对。GhTLinux联盟
服务器配置GhTLinux联盟
GhTLinux联盟
GhTLinux联盟
DocumentRoot /www/defaultGhTLinux联盟
GhTLinux联盟
GhTLinux联盟
这样一个使用通配符端口的默认虚拟主机可以有效的防止请求被主服务器接收。GhTLinux联盟
GhTLinux联盟
如果一个地址/端口对已经被一个基于域名的虚拟主机使用,那么"_default_"虚拟主机决不会处理发向这个地址/端口对的请求。如果一个"Host:"请求头中包含未知信息,或者干脆就没有,那么它会被第一个基于域名的虚拟主机(也就是在配置文件中最先出现的使用了那个地址/端口对的虚拟主机)处理。GhTLinux联盟
GhTLinux联盟
您可以用AliasMatch或RewriteRule来重写任何请求,使它指向一个简单信息页面(或脚本)。GhTLinux联盟
为不同的端口配置"_default_"虚拟主机GhTLinux联盟
GhTLinux联盟
与第一种一样,但我们想让服务器侦听很多端口而第二个"_default_"虚拟主机单独侦听80端口。GhTLinux联盟
服务器配置GhTLinux联盟
GhTLinux联盟
GhTLinux联盟
DocumentRoot /www/default80GhTLinux联盟
# ...GhTLinux联盟
GhTLinux联盟
GhTLinux联盟
GhTLinux联盟
DocumentRoot /www/defaultGhTLinux联盟
# ...GhTLinux联盟
GhTLinux联盟
GhTLinux联盟
侦听80端口的"_default_"虚拟主机(必须出现在所有使用通配符端口的虚拟主机之前)会捕获所有发向一个未指定的IP地址的请求。主服务器将不会用于伺服任何请求。GhTLinux联盟
为单独一个端口配置"_default_"虚拟主机GhTLinux联盟
GhTLinux联盟
如果我们只想在80端口上建立唯一的一个"_default_"虚拟主机,我们应该这样配置:GhTLinux联盟
服务器配置GhTLinux联盟
GhTLinux联盟
GhTLinux联盟
DocumentRoot /www/defaultGhTLinux联盟
...GhTLinux联盟
GhTLinux联盟
GhTLinux联盟
发向一个未指定地址的80端口的请求将会由这个虚拟主机伺服;而发向未设定地址的其他端口的请求则由主服务器伺服。GhTLinux联盟
topGhTLinux联盟
将一个基于域名的虚拟主机移植为一个基于IP的虚拟主机GhTLinux联盟
GhTLinux联盟
如果一个具有www.example.org域名的虚拟主机(就是基于域名配置示例中的第二个)得到了自己的IP地址。为了避免一些域名服务器或代理服务器在移植期间仍对这个域名做老的解析,我们可以采用一种过渡方法:同时提供新旧两个IP地址的解析。GhTLinux联盟
GhTLinux联盟
达到这个目的很简单。因为我们只要简单的把新地址(172.20.30.50)加入VirtualHost指令就行了。GhTLinux联盟
服务器配置GhTLinux联盟
GhTLinux联盟
Listen 80GhTLinux联盟
ServerName www.example.comGhTLinux联盟
DocumentRoot /www/example1GhTLinux联盟
GhTLinux联盟
NameVirtualHost 172.20.30.40GhTLinux联盟
GhTLinux联盟
GhTLinux联盟
DocumentRoot /www/example2GhTLinux联盟
ServerName www.example.orgGhTLinux联盟
# ...GhTLinux联盟
GhTLinux联盟
GhTLinux联盟
GhTLinux联盟
DocumentRoot /www/example3GhTLinux联盟
ServerName www.example.netGhTLinux联盟
ServerAlias *.example.netGhTLinux联盟
# ...GhTLinux联盟
GhTLinux联盟
GhTLinux联盟
现在这个虚拟主机就可以用新地址(表现为一个基于IP的虚拟主机)和旧地址(表现为一个基于域名的虚拟主机)同时进行访问了。GhTLinux联盟
topGhTLinux联盟
使用ServerPath指令GhTLinux联盟
GhTLinux联盟
如果我们在同一个服务器上运行了两个基于域名的虚拟主机。为了匹配正确的虚拟主机,客户端必须发送正确的"Host:" 头。而旧的使用HTTP/1.0的客户端无法发送这样的头,这样Apache就无法辨别客户端想要连接哪个虚拟主机(会用主虚拟主机来伺服这个请求)。为了尽量提供向下兼容性,我们可以提供一个主虚拟主机来返回一个页面,在页面中加入指向基于域名的虚拟主机的URL前缀的链接。GhTLinux联盟
服务器配置GhTLinux联盟
GhTLinux联盟
NameVirtualHost 172.20.30.40GhTLinux联盟
GhTLinux联盟
GhTLinux联盟
# 主虚拟主机GhTLinux联盟
DocumentRoot /www/subdomainGhTLinux联盟
RewriteEngine OnGhTLinux联盟
RewriteRule ^/.* /www/subdomain/index.htmlGhTLinux联盟
# ...GhTLinux联盟
GhTLinux联盟
GhTLinux联盟
GhTLinux联盟
DocumentRoot /www/subdomain/sub1GhTLinux联盟
ServerName www.sub1.domain.tldGhTLinux联盟
ServerPath /sub1/GhTLinux联盟
RewriteEngine OnGhTLinux联盟
RewriteRule ^(/sub1/.*) /www/subdomain$1GhTLinux联盟
# ...GhTLinux联盟
GhTLinux联盟
GhTLinux联盟
GhTLinux联盟
DocumentRoot /www/subdomain/sub2GhTLinux联盟
ServerName www.sub2.domain.tldGhTLinux联盟
ServerPath /sub2/GhTLinux联盟
RewriteEngine OnGhTLinux联盟
RewriteRule ^(/sub2/.*) /www/subdomain$1GhTLinux联盟
# ...GhTLinux联盟
GhTLinux联盟
GhTLinux联盟
由于ServerPath指令的作用,发送到http://www.sub1.domain.tld/sub1/的请求总会被sub1-vhost所伺服。GhTLinux联盟
如果客户端发送了正确的"Host:"头,发送到http://www.sub1.domain.tld/的请求只会被sub1-vhost所伺服。如果没有发送"Host:"头,客户端将会得到从主虚拟主机发送的信息页面。GhTLinux联盟
GhTLinux联盟
请注意,这里还有一点小问题:如果客户端没有发送"Host:"头,发送到http://www.sub2.domain.tld/sub1/的请求还是会被sub1-vhost所伺服。GhTLinux联盟
GhTLinux联盟
RewriteRule指令用以确保正确发送了"Host:"头的客户端可以任意使用这两种URL变量,比如说:使用或不使用URL前缀。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值