虚拟主机实质上是在一台Apache服务器建立多个WEB站点。虚拟主机有基于名称(DNS)的虚拟主机和基于IP地址的虚拟主机。

一、基于名称的虚拟主机

场景:

目前,公司共有四个部门,每个部门的域名分别如下表

表9-2-1 虚拟主机规划表

部门

域名

网页文档目录

部门1

dep1.penguin.com

/var/webroot/dep1

部门2

dep2.penguin.com

/var/webroot/dep2

部门3

dep3.penguin.com

/var/webroot/dep3

部门4

dep4.penguin.com

/var/webroot/dep4

每个部门网站的主文档的文件名都是index.htm:

部门1的index.htm内容

This is deparment one

部门2的index.htm内容

This is department two

部门3的index.htm内容

This is department three

部门4的index.htm内容

This is department four

服务器是的IP地址192.168.152.100;部门的域名由本服务器的DNS服务提供域名解析。

1、配置bind服务器,以提供域名解析

(1)使用yum或rpm安装bind的软件包后,修改/var/named/chroot/etc/name.conf,成为如下内容

{

query-source port 53;

dump-file "data/cache_dump.db";

statistics-file "data/named_stats.txt";

memstatistics-file "data/named_mem_stats.txt";

};

logging

{

channel default_debug {

file "data/named.run";

severity dynamic;

};

};

controls{

inet 127.0.0.1 allow { localhost; } keys { rndckey; };

};

include "/etc/named.root.hints";

include "/etc/named.rfc1912.zones";

include "/etc/rndc.key";

(2)修改/etc/named/chroot/etc/named.rfc1912.zones,必须包含如下内容

zone "penguin.com" IN {

type master;

file "penguin.com.zone"; //这个是区域文件

allow-update { none; };

};

(3)修改/etc/named/chroot/var/named/penguin.com.zone,使之具有如下内容

$TTL 86400

@ IN SOA ns.penguin.com root.penguin.com (

2010011701 ; serial (d. adams)

3H ; refresh

15M ; retry

1W ; expiry

1D ) ; minimum

IN NS ns.penguin.com.

ns IN A 192.168.152.100

dep1 IN A 192.168.152.100

dep2 IN A 192.168.152.100

dep3 IN A 192.168.152.100

dep4 IN A 192.168.152.100

(4)修改本机的DNS指向,修改的文件是/etc/resolv.conf,内容如下

nameserver 192.168.152.100

(5)重启动bind

service named restart

2、创建每个WEB站点下的主文档

[root@localhost named]# cd /var/webroot

[root@localhost webroot]# mkdir dep1 dep2 dep3 dep4

[root@localhost webroot]#echo "This is deparment one">dep1/index.htm

[root@localhost webroot]#echo "This is deparment two">dep2/index.htm

[root@localhost webroot]#echo "This is deparment three">dep3/index.htm

[root@localhost webroot]#echo "This is deparment four">dep4/index.htm

确保每个目录对others有x权限,对下面的文件有r权限

3、安装apache,并编辑/etc/httpd/conf/httpd.conf

使用yum 或rpm 安装apache的软件包,(软件包名是以httpd开始的)

-------------全局配置------------------

#全局配置中要修改的内容

DocumentRoot "/var/webroot" #不是主要的。可以不修改

<Directory />

Options FollowSymLinks

AllowOverride None

</Directory>

#上面对网站根,也可以不修改

<Directory "/var/webroot">

Options Indexes FollowSymLinks MultiViews

Order allow,deny

Allow from all

</Directory>

#对主服务器的根目录所指向的文件目录,进行配置,也不是主要的。

DirectoryIndex index.htm index.html index.html.var

#由于各虚拟主机下,主文档都是一样的。因些在全局配置进行设置

----------虚拟主机配置----------------------

NameVirtualHost 192.168.152.100:80

<VirtualHost 192.168.152.100:80>

ServerAdmin webmaster@dep1.penguin.com

DocumentRoot /var/webroot/dep1

ServerName dep1.penguin.com

ErrorLog logs/dep1web-error_log

CustomLog logs/dep1web-access_log common

</VirtualHost>

<VirtualHost 192.168.152.100:80>

ServerAdmin webmaster@dep2.penguin.com

DocumentRoot /var/webroot/dep2

ServerName dep2.penguin.com

ErrorLog logs/dep2web-error_log

CustomLog logs/dep2web-access_log common

</VirtualHost>

<VirtualHost 192.168.152.100:80>

ServerAdmin webmaster@dep3.penguin.com

DocumentRoot /var/webroot/dep3

ServerName dep3.penguin.com

ErrorLog logs/dep3web-error_log

CustomLog logs/dep3web-access_log common

</VirtualHost>

<VirtualHost 192.168.152.100:80>

ServerAdmin webmaster@dep4.penguin.com

DocumentRoot /var/webroot/dep4

ServerName dep4.penguin.com

ErrorLog logs/dep4web-error_log

CustomLog logs/dep4web-access_log common

</VirtualHost>

注意点:

1、为了使用基于域名的虚拟主机,你必须指定服务器IP地址(和可能的端口)来使主机接受请求,这个可以用NameVirtualHost指令来进行配置。如果服务器上所有的IP地址都会用到,你可以用"*"作为NameVirtualHost的参数。如果你打算使用多端口(如运行SSL)你必须在参数中指定一个端口号,比如"*:80"。请注意,在NameVirtualHost指令中指定IP地址并不会使服务器自动侦听那个IP地址。请参阅设置Apache使用的地址和端口一章获取更多详情。另外,这里设定的IP地址必须对应服务器上的一个网络接口。

下一步就是为每个虚拟主机建立<VirtualHost>段。<VirtualHost>的参数与NameVirtualHost的参数必须是一样的(比如说,一个IP地址或"*"代表的所有地址)。在每个<VirtualHost>段中,至少要有一个ServerName指令来指定伺服哪个主机和一个DocumentRoot指令来说明这个主机的内容位于文件系统的什么地方。

2、

取消中心主机(Mainhost)

如果你想在现有的web服务器上增加虚拟主机,你必须也为现存的主机建造一个<VirtualHost>定义块。这个虚拟主机中ServerName和DocumentRoot所包含的内容应该与全局的ServerName和DocumentRoot保持一致。还要把这个虚拟主机放在配置文件的最前面,来让它扮演默认主机的角色。

比如说,假设你正在为域名www.domain.tld提供服务,而你又想在同一个IP地址上增加一个名叫www.otherdomain.tld的虚拟主机,你只需在httpd.conf中加入以下内容:

NameVirtualHost *:80

<VirtualHost *:80>

ServerName www.domain.tld

ServerAlias domain.tld *.domain.tld

DocumentRoot /www/domain

</VirtualHost>

<VirtualHost *:80>

ServerName www.otherdomain.tld

DocumentRoot /www/otherdomain

</VirtualHost>

3、当然,你可以用一个固定的IP地址来代替NameVirtualHost和<VirtualHost>指令中的"*"号,以达到一些特定的目的。比如说,你可能会希望在一个IP地址上运行一个基于域名的虚拟主机,而在另外一个IP地址上运行一个基于IP的或是另外一套基于域名的虚拟主机。

4、

很多服务器希望自己能通过不只一个域名被访问。我们可以把ServerAlias指令放入<VirtualHost>小节中来解决这个问题。比如说在上面的第一个<VirtualHost>配置段中ServerAlias指令中列出的名字就是用户可以用来访问同一个web站点的其它名字:

ServerAlias domain.tld *.domain.tld

这样,所有对域domain.tld的访问请求都将由虚拟主机www.domain.tld处理。通配符标记"*"和"?"可以用于域名的匹配。当然你不能仅仅搞个名字然后把它放到ServerName或ServerAlias里就算完了。你必须先在你的DNS服务器上进行配置,将这些名字和您服务器上的一个IP地址建立映射关系

5、最后,你可以把其他一些指令放入<VirtualHost>段中,以更好的配置一个虚拟主机。大部分指令都可以放入这些<VirtualHost>段中以改变相应虚拟主机配置。如果您想了解一个特定的指令是否可以这样运用,请参见指令的作用域。主服务器(main server)范围内的配置指令(在所有<VirtualHost>配置段之外的指令)仅在它们没有被虚拟主机的配置覆盖时才起作用。

这样,当一个请求到达的时候,服务器会首先检查它是否使用了一个能和NameVirtualHost相匹配的IP地址。如果能够匹配,它就会查找每个与这个IP地址相对应的<VirtualHost>段,并尝试找出一个与请求的主机名相同的ServerName或ServerAlias配置项。如果找到了,它就会使用这个服务器。否则,将使用符合这个IP地址的第一个列出的虚拟主机。

综上所述,第一个列出的虚拟主机充当了默认虚拟主机的角色。当一个IP地址与NameVirtualHost指令中的配置相符的时候,主服务器中的DocumentRoot将永远不会被用到。所以,如果你想创建一段特殊的配置用于处理不对应任何一个虚拟主机的请求的话,你只要简单的把这段配置放到<VirtualHost>段中,并把它放到配置文件的最前面就可以了。