基于httpd实现虚拟主机

网友投稿 266 2022-10-27


基于httpd实现虚拟主机

众所周知,一台物理服务器只能运行一个站点,但如若想实现一台服务器运行多个站点时,就不得不用到虚拟主机了。虚拟主机,顾名思义,就是一个虚拟出来的主机,当在服务单配置完成后,客户端访问时就像是访问了多个后端服务器。

实现虚拟主机有三种不同的方式:

基于IP的虚拟主机:使用不同的IP地址提供不同的站点基于PORT的虚拟主机:使用不同的端口提供不同的站点基于HOSTNAME的虚拟主机:使用不同的主机名提供不同站点

为了更直观的感受,下面一一实现基于三种方式的虚拟主机:

说明一下实验环境,实验主机为centos7.3,IP地址为:192.168.1.104

首先安装httpd服务,这里使用的是httpd2.4.6版本:

# yum -y install httpd

安装完成后查看安装文件:

# rpm -ql httpd

对应的文件做一些简单说明:

服务脚本:/etc/rc.d/init.d/httpd     脚本配置文件:/etc/sysconfig/httpd     运行目录:/etc/httpd     配置文件:     主配置文件:/etc/httpd/conf/httpd.conf     扩展配置:/etc/httpd/conf.d/*.conf     监听的Socket:80/tcp,443/tcp     文档根目录:/var/www/html     CGI:/var/www/cgi-bin/     默认主页:index.html

在实验之前,须确保在"/var/www/html/"

一、基于IP的虚拟主机实现:

本机的IP地址为192.168.1.104,需在添加一个IP地址:

# ifconfig ens36:0 192.168.1.200 netmask 255.255.255.0 broadcast 192.168.1.255  up

用ifconfig查看:

可看到ens36:0已添加成功。

为了便于管理,我们在扩展配置文件中新建VirtualHost.conf文件:

]# vim VirtualHost.conf

添加内容如下:

    DocumentRoot "/var/www/test1/"     ServerName 192.168.1.104     DocumentRoot "/var/www/test2/"     ServerName 192.168.1.200

而后为添加的两个站点添加主页

首先创建两个目录:

# mkdir -pv /var/www/test{1,2} mkdir: created directory ‘/var/www/test1’ mkdir: created directory ‘/var/www/test2’

为test1提供主页文件:

# vim /var/www/test1/index.html

添加内容如下:

Test1 Page

保存退出。站点test2同理;

执行语法检查:

# httpd -t Syntax OK

重读配置文件:

# systemctl reload httpd

测试结果:

站点test1:

站点test2:

二、基于端口的虚拟主机实现:

编辑扩展配置文件:

]# vim VirtualHost.conf

添加内容如下:

    DocumentRoot "/var/www/test1/"     ServerName 192.168.1.104     DocumentRoot "/var/www/test2/"     ServerName 192.168.1.200

在主配置文件中,监听端口下面添加一行

Listen 8080

保存退出

执行语法检查:

# httpd -t Syntax OK

注:此处由于添加了端口,需要重启服务方能生效

# systemctl restart httpd # ss -tnl State      Recv-Q Send-Q Local Address:Port               Peer Address:Port               LISTEN     0      128             *:22                          *:*                   LISTEN     0      100     127.0.0.1:25                          *:*                   LISTEN     0      128            :::8080                       :::*                  //8080端口已监听 LISTEN     0      128            :::80                         :::*                   //80端口已监听 LISTEN     0      128            :::22                         :::*                   LISTEN     0      100           ::1:25                         :::*

测试结果:

站点1:

站点2:

三、由于基于IP和端口的虚拟主机不常用,故而此处演示基于FQDN的虚拟主机实现:

在扩展配置文件中添加如下内容:

为了使主机名解析成功,需要修改host文件,我们此处使用win下浏览器测试,故而需要修改win下hosts文件,路径为:

C:\Windows\System32\drivers\etc\hosts

添加如下内容

开始测试:

站点test1:

站点test2:

以上,即使基于httpd的虚拟主机三种实现方式,但在日常生产中,常需要对特定用户实现访问控制,下面简单演示基于用户的控制访问:

编辑扩展配置文件,并添加如下内容:

接下来用htpasswd生成密码:

创建对应的admin目录及主页文件

# mkdir /var/www/test1/admin    //创建目录 # vim /var/www/test1/admin/index.html  //创建主业文件

Authentication

   //添加的内容

如图:

而后访问:

输入用户名密码:

至此httpd的虚拟主机和用户认证就实现了。


版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:SpringBoot+VUE实现前后端分离的实战记录
下一篇:如何hack一下Rancher Kubernetes
相关文章

 发表评论

暂时没有评论,来抢沙发吧~