虚拟 Web 主机指的是在同一台服务器中运行多个 Web 站点,其中的每一个站点实际上并不独立占用整个服务器,因此被称为“虚拟”Web 主机。通过虚拟 Web 主机服务可以充分利用服务器的硬件资源,从而大大降低网站构建及运行成本。
使用 httpd 可以非常方便地构建虚拟主机服务器,只需要运行一个 httpd 服务就能够同时支撑大量的 Web 站点。httpd 支持的虚拟主机类型包括以下三种。
基于域名:为每个虚拟主机使用不同的域名,但是其对应的 IP 地址是相同的。
例如,www.zf.com 和 www.zzff.com 站点的 IP 地址都是 192.168.247.170。这是使用最为普遍的虚拟 Web 主机类型。
基于 IP 地址:为每个虚拟主机使用不同的域名,且各自对应的 IP 地址也不相同。这种方式需要为服务器配备多个网络接口,因此应用并不是非常广泛。(但是相对安全)
基于端口:这种方式并不使用域名、IP 地址来区分不同的站点内容,而是使用了不同的TCP 端口号,因此用户在浏览不同的虚拟站点时需要同时指定端口号才能访问。
为虚拟主机准备测试网页
[root@client ~]# mkdir -p /var/www/html/zfweb1
[root@client ~]# mkdir -p /var/www/html/zfweb2
[root@client ~]# echo "this is zfweb1" > /var/www/html/zfweb1/index.html
[root@client ~]# echo "this is zfweb2" > /var/www/html/zfweb2/index.html
修改虚拟主机的配置文件
1)虚拟主机区域:使用
每一个虚拟 Web 主机建立独立的配置内容。其中至少应包括虚拟主机的网站
名称、网页根目录的配置项;其他(如管理邮箱、访问日志等)配置项可
根据实际需要添加。
2) 目录权限:使用
拟 Web 主机的网站目录设置访问权限,如允许任何人访问。目录访问可以继
承其父目录的授权许可,因此可以采取直接为父文件夹授权访问权限的方法来简化配置当虚拟 Web 主机的数量较多时,建议使用独立的虚拟主机配置文件,然后在 httpd.conf文件中通过 Include 加载这些配置。这样可以将对 httpd.conf 文件的改动减至最少,更方便配置内容的维护。
[root@client ~]# vi /usr/local/httpd/conf/extra/httpd-vhosts.conf
<VirtualHost *:80> #虚拟主机www.zf.com站点配置
DocumentRoot "/var/www/html/zfweb1" #网页文件目录
ServerName www.zf.com #域名配置
ErrorLog "logs/www.zfweb1.com.error_log" #日志文件位置
CustomLog "logs/www.zfweb1.com.access_log" common
<Directory "/var/www/html">
Require all granted #设置目录权限
</Directory>
</VirtualHost>
<VirtualHost *:80> #虚拟主机www.zf.com站点配置
DocumentRoot "/var/www/html/zfweb2"
ServerName www.zzff.com
ErrorLog "logs/www.zfweb2.com.error_log"
CustomLog "logs/www.zfweb2.com.access_log" common
<Directory "/var/www/html">
Require all granted
</Directory>
</VirtualHost>
修改全局配置文件
[root@client ~]# vi /etc/httpd.conf
#ServerName 前面要加# ,注释原来的域名,不使用
Include conf/extra/httpd-vhosts.conf #加载虚拟主机的配置文件,开启虚拟主机模块功能
添加IP和域名的映射
192.168.247.170 www.zf.com www.zzff.com
关闭防火墙和核心防护并重启服务
systemctl stop firewalld
setenforce 0
systemctl restart httpd
验证,访问两个域名
配置两张网卡
原来的网卡为VMnet8:192.168.247.170
新增一张为:VMnet8:192.168.247.177,查看新网卡的UUID,并添加网卡配置文件
nmcli connection
NAME UUID TYPE DEVICE
ens33 49511b41-e51a-41f0-a43e-d13274d3ce10 ethernet ens33
virbr0 2526d384-aa95-4b4c-9c39-226fc07a2844 bridge virbr0
有线连接 1 816178ee-807e-3499-9d19-20507cbb8ad3 ethernet ens36
cd /etc/sysconfig/network-scripts/
cp ifcfg-ens33 ifcfg-ens36
vi ifcfg-ens36
TYPE=Ethernet
PROXY_METHOD=none
BROWSER_ONLY=no
BOOTPROTO=none
DEFROUTE=yes
IPV4_FAILURE_FATAL=no
IPV6INIT=no
IPV6_AUTOCONF=yes
IPV6_DEFROUTE=yes
IPV6_FAILURE_FATAL=no
IPV6_ADDR_GEN_MODE=stable-privacy
NAME=ens36 ###更改为ens36
UUID=816178ee-807e-3499-9d19-20507cbb8ad3 ###更改UUID值
DEVICE=ens36 ###更改为ens36
ONBOOT=yes
IPADDR=192.168.247.177 ###更改IP地址,虚拟主机2的地址
PREFIX=24
GATEWAY=192.168.247.2
IPV6_PRIVACY=no
重启网卡
systemctl restart network
修改虚拟主机配置文件
vim /usr/local/httpd/conf/extra/httpd-vhosts.conf
<VirtualHost 192.168.247.170:80> #虚拟主机1站点配置,需要添加IP地址,对应站点区域
DocumentRoot "/var/www/html/zfweb1"
ServerName www.zf.com
......
</VirtualHost>
<VirtualHost 192.168.247.177:80> #虚拟主机2站点配置,需要添加IP地址,对应站点区域
DocumentRoot "/var/www/html/zfweb2"
ServerName www.zzff.top
......
</VirtualHost>
vim /usr/local/httpd/conf/httpd.conf
Include conf/extra/httpd-vhosts.conf ##加载虚拟主机的配置文件
添加IP和域名的映射
vi /etc/hosts
192.168.247.170 www.zf.com
192.168.247.177 www.zzff.com
关闭防火墙和核心防护并重启服务
systemctl stop firewalld
setenforce 0
systemctl restart httpd
验证,访问两个域名
只需要一张网卡
修改虚拟主机配置文件
[root@client ~]# vi /usr/local/httpd/conf/extra/httpd-vhosts.conf
<VirtualHost 192.168.247.170:88> #虚拟主机1端口号88
DocumentRoot "/var/www/html/zfweb1"
ServerName www.zf.com
ErrorLog "logs/www.zfweb1.com.error_log"
CustomLog "logs/www.zfweb1.com.access_log" common
<Directory "/var/www/html">
Require all granted
</Directory>
</VirtualHost>
<VirtualHost 192.168.247.170:8080> #虚拟主机2端口号8080
DocumentRoot "/var/www/html/zfweb2"
ServerName www.zzff.com
ErrorLog "logs/www.zfweb2.com.error_log"
CustomLog "logs/www.zfweb2.com.access_log" common
<Directory "/var/www/html">
Require all granted
</Directory>
</VirtualHost>
修改主配置文件
vi /usr/local/httpd/conf/httpd.conf #省略部分内容
Include conf/extra/httpd-vhosts.conf #加载独立的配置文件
Listen 192.168.247.170:88 #监听 88 端口
Listen 192.168.247.170:8080 #监听 8080 端口
验证,访问IP时添加端口