热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

基于域名、端口和IP的虚拟主机构建方案

本文探讨了在单台物理服务器上构建多个Web站点的虚拟主机方案,详细介绍了三种主要的虚拟主机类型:基于域名、基于IP地址和基于端口的虚拟主机。每种类型的实现方式及其优缺点均进行了深入分析,为实际应用提供了全面的技术指导。
虚拟web主机

在同一台物理服务器中运行多个web站点,其中每一个站点并不独立占用一台真正的计算机

httpd支持的虚拟主机类型
*   基于域名的虚拟主机
*   基于IP地址的虚拟主机
*   基于端口的虚拟主机

技术图片

案例一——基于域名
  • 构建2个虚拟web站点

    www.accp.com  ip地址为本机地址
    www.kgc.com    ip地址为本机地址
  • 在浏览器中访问这两个域名时,分别显示不同的内容

    实验环境

    一台Linux主机做服务器
    一台win7主机做测试

1,安装http和dns服务

    [root@localhost ~]# yum install httpd bind -y  //安装http,dns服务

2,配置dns主配置文件

    [root@localhost ~]# vim /etc/named.conf   ##主配置文件

    options {
                    listen-on port 53 { any; };      ##将本机监听为所有
                    listen-on-v6 port 53 { ::1; };
                    directory       "/var/named";
                    dump-file       "/var/named/data/cache_dump.db";
                    statistics-file "/var/named/data/named_stats.txt";
                    memstatistics-file "/var/named/data/named_mem_stats.txt";
                    recursing-file  "/var/named/data/named.recursing";
                    secroots-file   "/var/named/data/named.secroots";
                    allow-query     { any; };      ##允许所有

3,配置区域配置文件(etc/named.rfc1912.zones)

[root@localhost ~]# vim /etc/named.rfc1912.zones  ##配置区域配置文件
zone "localhost" IN {             ##复制两个模板到下面
                type master;
                file "named.localhost";
                allow-update { none; };
};

zone "accp.com" IN {            ##修改localhost为accp.com
                type master;
                file "accp.com.zone";    ##创建区域数据配置文件
                allow-update { none; };
};

zone "kgc.com" IN {              ##修改localhost为kgc.com
                type master;
                file "kgc.com.zone";      ##创建区域数据配置文件
                allow-update { none; };
};

4,编辑区域数据配置文件(accp.com.zone kgc.com.zone)

[root@localhost ~]# cd /var/named/     ##切换到/var/named目录下  
[root@localhost named]# cp -p named.localhost accp.com.zone   
##复制模板为accp.com.zone
[root@localhost named]# vim accp.com.zone  ##编辑区域数据配置文件

$TTL 1D
@       IN SOA  @ rname.invalid. (
                                                                                0       ; serial
                                                                                1D      ; refresh
                                                                                1H      ; retry
                                                                                1W      ; expire
                                                                                3H )    ; minimum
                NS      @
                A       127.0.0.1
www IN  A       192.168.13.133   ##删除ipv6 添加域名解析地址为本机
[root@localhost named]# cp -p accp.com.zone  kgc.com.zone
##编辑kgc的区域数据配置文件,内容不需要更改

5,关闭防火墙并开启服务

[root@localhost named]# systemctl start named   ##开启dns服务
[root@localhost named]# systemctl stop firewalld.service    ##关闭防火墙
[root@localhost named]# setenforce 0   ##关闭增强功能

6,进入win7测试主机中,修改DNS解析服务器,查看是否可以解析

技术图片
技术图片

7,在Linux中创建一个http扩展配置文件

[root@localhost named]# cd /etc/httpd/conf   ##切换到http配置目录中
[root@localhost named]# mkdir extra     ##创建扩展配置文件目录
[root@localhost named]# cd extra
[root@localhost named]# vim vhost.conf   ##编辑扩展配置文件

         ##标签 *所有ip 80端口
    Documentroot "/var/www/html/accp/"    ##站点目录
    ServerName www.accp.com                 ##域名
    Errorlog "logs/www.accp.com.error_log"    ##错误日志文件
    Customlog "logs/www.accp.com.access_log" common  ##访问日志
                    ##控制目录权限
        Require all granted                           ##允许所有人可以访问
    

##上面的logs是软连接/var/log/httpd     ##下面的只要修改accp为kgc即可
    
        Documentroot "/var/www/html/kgc/"
        ServerName www.kgc.com
        Errorlog "logs/www.kgc.com.error_log"
        Customlog "logs/www.kgc.com.access_log" common
        
            Require all granted
        
    

8,到网页站点中,创建accp和kgc的网页主页内容文件

[root@localhost extra]# cd /var/www/html/   ##切换到网页站点中
[root@localhost html]# mkdir accp kgc        ##创建两个网站的站点目录
[root@localhost html]# cd accp/ 
[root@localhost accp]# vim index.html        ##编辑accp网页内容
this is a accp web

[root@localhost html]# cd kgc/
[root@localhost accp]# vim index.html        ##编辑kgc网页内容
this is a kgc web

9,将http扩展配置文件加载到主配置文件中,并开启http服务

[root@localhost www]# cd /etc/httpd/conf    ##切换到http的配置文件目录
[root@localhost conf]# vim httpd.conf     ##编辑主配置文件
Include conf/extra/vhost.conf                  ##在末行加入扩展配置文件目录
[root@localhost conf]# systemctl start httpd     ##启动http服务

10,使用域名进行页面访问

技术图片
技术图片

案例二——基于端口

1,配置扩展配置文件内容

[root@lolocalhost extra]# vim vhost.conf
    
        Documentroot "/var/www/html/kgc/"
        ServerName www.kgc.com
        Errorlog "logs/www.kgc.com.error_log"
        Customlog "logs/www.kgc.com.access_log" common
        
            Require all granted
        
    

            ##端口号改成8080
        Documentroot "/var/www/html/kgc02/"       ##目录更改为02
        ServerName www.kgc.com
        Errorlog "logs/www.kgc02.com.error_log"           ##日志文件更改为02
        Customlog "logs/www.kgc02.com.access_log" common
        
            Require all granted
        
    

2,编辑网站目录和网站内容

[root@localhost extra]# cd /var/www/html/
[root@localhost html]# mkdir kgc02
[root@localhost html]# vim index.html     ##编辑kgc02网页的内容
this is a kgc02 web

3,配置http主配置文件,修改监听端口,并重启网络服务

[root@localhost html]# vim /etc/httpd/conf/httpd.conf     ##修改配置文件
Listen 192.168.13.133:80               ##修改ipv4监听端口
Listen 192.168.13.133:8080
#Listen 80      ##将ipv6端口注释
[root@localhost html]# systemctl restart httpd.service  ##重启网络服务
[root@localhost html]# netstat -ntap   ##查看监听端口开启状态 
tcp        0      0 192.168.13.133:8080     0.0.0.0:*               LISTEN      4093/httpd          
tcp        0      0 192.168.13.133:80       0.0.0.0:*               LISTEN      4093/httpd   

4,测试网页

技术图片
技术图片

案例三——基于IP

在Linux上添加一块网卡做不同IP

1,配置扩展配置文件内容

[root@lolocalhost extra]# vim vhost.conf
             ##修改ip地址
         Documentroot "/var/www/html/accp/"     ##域名此处没有用处删除
         Errorlog "logs/www.accp.com.error_log"
         Customlog "logs/www.accp.com.access_log" common
         
             Require all granted
         
     

          ##修改ip地址
        Documentroot "/var/www/html/accp02/"  ##修改目录accp02和日志
        Errorlog "logs/www.accp02.com.error_log"
        Customlog "logs/www.accp02.com.access_log" common
        
            Require all granted
        
    

2,编辑网站目录和网站内容

[root@localhost extra]# cd /var/www/html/  
[root@localhost html]# mkdir accp02   ##创建132ip地址的目录站点内容
[root@localhost html]# cd accp02/
[root@localhost accp02]# echo "this is 132 web" > index.html
[root@localhost accp02]# cd ../
[root@localhost html]# cd accp     ##修改133ip地址网页内容
[root@localhost accp]# vim index.html
this is 133 web

3,配置http主配置文件,修改监听端口,并重启网络服务

[root@localhost html]# vim /etc/httpd/conf/httpd.conf     ##修改配置文件
Listen 192.168.13.133:80    ##添加两个ip的端口监听
Listen 192.168.13.132:80
#Listen 192.168.13.133:8080   ##注释8080端口的
#Listen 80                    ##将ipv6端口注释
[root@localhost conf]# systemctl restart httpd.service  ##重启网络服务

4,测试网页

技术图片
技术图片

扩展:不同ip不同域名访问

1,配置扩展配置文件内容

[root@lolocalhost extra]# vim vhost.conf
    
    Documentroot "/var/www/html/accp/"
    ServerName www.accp.com    ##添加域名
    Errorlog "logs/www.accp.com.error_log"
    Customlog "logs/www.accp.com.access_log" common
    
        Require all granted
    



    Documentroot "/var/www/html/accp02/"
    ServerName www.naccp.com    ##添加另一个域名
    Errorlog "logs/www.accp02.com.error_log"
    Customlog "logs/www.accp02.com.access_log" common
    
        Require all granted
    

2,在dns区域配置文件中添加新的域名解析

[root@localhost /]# vim /etc/named.rfc1912.zones 
zone "accp.com" IN {
    type master;
    file "accp.com.zone";
    allow-update { none; };
};

zone "naccp.com" IN {
                type master;
                file "naccp.com.zone";
                allow-update { none; };
};

3,配置区域数据配置文件

[root@localhost named]# cd /var/named/
[root@localhost named]# cp -p accp.com.zone naccp.com.zone ##复制
[root@localhost named]# vim naccp.com.zone ##配置区域数据配置文件
$TTL 1D
@       IN SOA  @ rname.invalid. (
                                                                                0       ; serial
                                                                                1D      ; refresh
                                                                                1H      ; retry
                                                                                1W      ; expire
                                                                                3H )    ; minimum
                NS      @
                A       127.0.0.1
www IN  A       192.168.13.132   ##此处的naccp要修改132ip地址

4,重启dns和http服务,并测试

[root@localhost named]# systemctl restart named  ##重启DNS
[root@localhost named]# systemctl restart httpd.service  ##重启网络

技术图片
技术图片

谢谢阅读!!!

构建虚拟主机——基于域名,端口,IP


推荐阅读
  • 本文探讨了如何通过最小生成树(MST)来计算严格次小生成树。在处理过程中,需特别注意所有边权重相等的情况,以避免错误。我们首先构建最小生成树,然后枚举每条非树边,检查其是否能形成更优的次小生成树。 ... [详细]
  • QUIC协议:快速UDP互联网连接
    QUIC(Quick UDP Internet Connections)是谷歌开发的一种旨在提高网络性能和安全性的传输层协议。它基于UDP,并结合了TLS级别的安全性,提供了更高效、更可靠的互联网通信方式。 ... [详细]
  • 本文总结了2018年的关键成就,包括职业变动、购车、考取驾照等重要事件,并分享了读书、工作、家庭和朋友方面的感悟。同时,展望2019年,制定了健康、软实力提升和技术学习的具体目标。 ... [详细]
  • 深入理解Cookie与Session会话管理
    本文详细介绍了如何通过HTTP响应和请求处理浏览器的Cookie信息,以及如何创建、设置和管理Cookie。同时探讨了会话跟踪技术中的Session机制,解释其原理及应用场景。 ... [详细]
  • 本文详细介绍了如何使用 Yii2 的 GridView 组件在列表页面实现数据的直接编辑功能。通过具体的代码示例和步骤,帮助开发者快速掌握这一实用技巧。 ... [详细]
  • 在Linux系统中配置并启动ActiveMQ
    本文详细介绍了如何在Linux环境中安装和配置ActiveMQ,包括端口开放及防火墙设置。通过本文,您可以掌握完整的ActiveMQ部署流程,确保其在网络环境中正常运行。 ... [详细]
  • 2023 ARM嵌入式系统全国技术巡讲旨在分享ARM公司在半导体知识产权(IP)领域的最新进展。作为全球领先的IP提供商,ARM在嵌入式处理器市场占据主导地位,其产品广泛应用于90%以上的嵌入式设备中。此次巡讲将邀请来自ARM、飞思卡尔以及华清远见教育集团的行业专家,共同探讨当前嵌入式系统的前沿技术和应用。 ... [详细]
  • 国内BI工具迎战国际巨头Tableau,稳步崛起
    尽管商业智能(BI)工具在中国的普及程度尚不及国际市场,但近年来,随着本土企业的持续创新和市场推广,国内主流BI工具正逐渐崭露头角。面对国际品牌如Tableau的强大竞争,国内BI工具通过不断优化产品和技术,赢得了越来越多用户的认可。 ... [详细]
  • 本文详细分析了JSP(JavaServer Pages)技术的主要优点和缺点,帮助开发者更好地理解其适用场景及潜在挑战。JSP作为一种服务器端技术,广泛应用于Web开发中。 ... [详细]
  • 优化ListView性能
    本文深入探讨了如何通过多种技术手段优化ListView的性能,包括视图复用、ViewHolder模式、分批加载数据、图片优化及内存管理等。这些方法能够显著提升应用的响应速度和用户体验。 ... [详细]
  • Explore how Matterverse is redefining the metaverse experience, creating immersive and meaningful virtual environments that foster genuine connections and economic opportunities. ... [详细]
  • 本文详细介绍如何使用Python进行配置文件的读写操作,涵盖常见的配置文件格式(如INI、JSON、TOML和YAML),并提供具体的代码示例。 ... [详细]
  • 技术分享:从动态网站提取站点密钥的解决方案
    本文探讨了如何从动态网站中提取站点密钥,特别是针对验证码(reCAPTCHA)的处理方法。通过结合Selenium和requests库,提供了详细的代码示例和优化建议。 ... [详细]
  • 1:有如下一段程序:packagea.b.c;publicclassTest{privatestaticinti0;publicintgetNext(){return ... [详细]
  • 深入理解 SQL 视图、存储过程与事务
    本文详细介绍了SQL中的视图、存储过程和事务的概念及应用。视图为用户提供了一种灵活的数据查询方式,存储过程则封装了复杂的SQL逻辑,而事务确保了数据库操作的完整性和一致性。 ... [详细]
author-avatar
雪_月_
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有