900字范文,内容丰富有趣,生活中的好帮手!
900字范文 > Apache虚拟主机的配置(基于域名 端口 IP)

Apache虚拟主机的配置(基于域名 端口 IP)

时间:2023-01-02 03:50:28

相关推荐

Apache虚拟主机的配置(基于域名 端口 IP)

一、虚拟主机概述

虚拟 Web 主机指的是在同一台服务器中运行多个 Web 站点,其中的每一个站点实际上并不独立占用整个服务器,因此被称为“虚拟”Web 主机。通过虚拟 Web 主机服务可以充分利用服务器的硬件资源,从而大大降低网站构建及运行成本。

使用 httpd 可以非常方便地构建虚拟主机服务器,只需要运行一个 httpd 服务就能够同时支撑大量的 Web 站点。httpd 支持的虚拟主机类型包括以下三种。

基于域名:为每个虚拟主机使用不同的域名,但是其对应的 IP 地址是相同的。

例如, 和 站点的 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)虚拟主机区域:使用<VirtualHost 监听地址>……区域配置,为

每一个虚拟 Web 主机建立独立的配置内容。其中至少应包括虚拟主机的网站

名称、网页根目录的配置项;其他(如管理邮箱、访问日志等)配置项可

根据实际需要添加。

2) 目录权限:使用<Directory 目录位置>……区域配置,为每一个虚

拟 Web 主机的网站目录设置访问权限,如允许任何人访问。目录访问可以继

承其父目录的授权许可,因此可以采取直接为父文件夹授权访问权限的方法来简化配置当虚拟 Web 主机的数量较多时,建议使用独立的虚拟主机配置文件,然后在 httpd.conf文件中通过 Include 加载这些配置。这样可以将对 httpd.conf 文件的改动减至最少,更方便配置内容的维护。

[root@client ~]# vi /usr/local/httpd/conf/extra/httpd-vhosts.conf<VirtualHost *:80> #虚拟主机站点配置DocumentRoot "/var/www/html/zfweb1"#网页文件目录ServerName #域名配置ErrorLog "logs/.error_log" #日志文件位置CustomLog "logs/.access_log" common<Directory "/var/www/html">Require all granted#设置目录权限</Directory></VirtualHost><VirtualHost *:80>#虚拟主机站点配置DocumentRoot "/var/www/html/zfweb2"ServerName ErrorLog "logs/.error_log"CustomLog "logs/.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

关闭防火墙和核心防护并重启服务

systemctl stop firewalldsetenforce 0systemctl restart httpd

验证,访问两个域名

三、基于IP的虚拟主机配置

配置两张网卡

原来的网卡为VMnet8:192.168.247.170

新增一张为:VMnet8:192.168.247.177,查看新网卡的UUID,并添加网卡配置文件

nmcli connection NAME UUID TYPEDEVICE ens33 49511b41-e51a-41f0-a43e-d13274d3ce10 ethernet ens33 virbr02526d384-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-ens36TYPE=EthernetPROXY_METHOD=noneBROWSER_ONLY=noBOOTPROTO=noneDEFROUTE=yesIPV4_FAILURE_FATAL=noIPV6INIT=noIPV6_AUTOCONF=yesIPV6_DEFROUTE=yesIPV6_FAILURE_FATAL=noIPV6_ADDR_GEN_MODE=stable-privacyNAME=ens36###更改为ens36UUID=816178ee-807e-3499-9d19-20507cbb8ad3 ###更改UUID值DEVICE=ens36 ###更改为ens36ONBOOT=yesIPADDR=192.168.247.177 ###更改IP地址,虚拟主机2的地址PREFIX=24GATEWAY=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 ...... </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.confInclude conf/extra/httpd-vhosts.conf##加载虚拟主机的配置文件

添加IP和域名的映射

vi /etc/hosts192.168.247.170 192.168.247.177

关闭防火墙和核心防护并重启服务

systemctl stop firewalldsetenforce 0systemctl restart httpd

验证,访问两个域名

四、基于端口的虚拟主机配置

只需要一张网卡

修改虚拟主机配置文件

[root@client ~]# vi /usr/local/httpd/conf/extra/httpd-vhosts.conf<VirtualHost 192.168.247.170:88> #虚拟主机1端口号88DocumentRoot "/var/www/html/zfweb1"ServerName ErrorLog "logs/.error_log"CustomLog "logs/.access_log" common<Directory "/var/www/html">Require all granted</Directory></VirtualHost><VirtualHost 192.168.247.170:8080> #虚拟主机2端口号8080DocumentRoot "/var/www/html/zfweb2"ServerName ErrorLog "logs/.error_log"CustomLog "logs/.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时添加端口

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。