2023年-配置apache虚拟主机.docx
《2023年-配置apache虚拟主机.docx》由会员分享,可在线阅读,更多相关《2023年-配置apache虚拟主机.docx(8页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、配置apache虚拟主机通过以下文章:实现:同一 ip不同端口对应不同的站点目录 具体实现:1.在 httpd.conf 中,设置 listen IP:80 listen IP:8080然后在virtualhost中设置:DocumnetRoot 1DocumnetRoot 2我们通常所说的虚拟主机url=j avascript:技术/url就是将一台(或者一组)服务器的资源(系统资源、网络带宽、存储空间等)按照一定的比 例分割成若干台相对独立的“小主机”的技术。每一台这样的“小主机”在功能上都可以实 现WWW、FTP、Mail等基本的Internet服务,就像使用独立的主机一样。目前网站服务
2、器的虚拟主机平台使用以开放的Apache为最多,其次是微软的Windows IISo Apache 具有跨平台(FreeBSD/Linux/Windows/Solaris/Other UNIX)、易于维护与最佳安 全性等优点。Apache是率先支持基于IP虚拟主机的服务器之一。Apache 1.1及其更新版本同时支持 基于IP和基于主机名的虚拟主机,不同的虚拟主机有时会被称为基于主机(host-based)或非 IP 虚拟主机(non-IP virtual hosts)o用Apache设置虚拟主机服务通常可以采用两种方案:基于IP地址的虚拟主机和基于主 机名字的虚拟主机,下面我们分别介绍一下它
3、们的实现方法以及优缺点。以便大家在具体的 应用中能够选择最合适的实现方法。一、Apache实现基于IP地址的虚拟主机(每个站点拥有一个独立IP地址)使用这种虚拟主机方式,首先要在服务器上为每个虚拟主机单独设置一个IP地址。这 些IP地址可以通过增加多个网卡或者在一个网卡上设立多个IP地址来完成。有了多个IP 地址后,可以采用以下两种方式之一来设置Apache。1、为每个虚拟主机运行一份Apache采用这种方式,每一份Apache程序可以以单独的用户运行,因此各个虚拟主机之间 互不影响。设置这种虚拟主机时,只要为每一份Apache设置一套配置文件就可以了,唯一 需要注意的是:必须使用“Liste
4、n”语句,强制每一份Apache仅仅在属于“自己”的IP地 址上接收服务请求。优点:各个虚拟主机之间互不干扰,安全性高。缺点:占用系统资源较多。2、多个虚拟主机共享同一份Apache采用这种方式,各个虚拟主机共享同一份Apache,因此各个虚拟主机之间有一定的影 响,尤其是执行CGI程序时,可能会带来一些严重的安全问题。设置这种虚拟主机时,只 要为每一个虚拟主机设置类似如下的信息即可:DocumentRoot /www/ghql优点:占用系统资源比上一种方式少。缺点:安全性低,每个虚拟主机仍然需要占用一个IP地址。例如服务器一个网卡上绑定有两个IP地址(172.16.3.40和172.16.3
5、.50)分别对应域名和 www.ghq2.org的服务,配置如下:服务器配置(apache的配置文件httpd.conf)Listen 80DocumentRoot /www/ghqlServerName DocumentRoot /www/ghq2ServerName www.ghq2.org配置简单说明:“Listen”默认httpd服务会监控第80号通信端口,“Listen”选项让用户自行指定apache服务器监控的IP地址或通信端口。“DocumentRoot”:指定叩ache服务器存放网页的根目录;“ServerName”:允许用户 自行设置主机名,这个名称将被送到远程连接程序,以取
6、代安装叩ache服务器主机的真实 名称。和构成虚拟主机的语法结构,其中的IP就是我们在服务器上绑定的不同的IP地址, 也可以是IP地址加上通信端口号(见下面的例子)。如果服务器有两个IP地址(172.16.3.40和172.16.3.50)分别对应域名和www.ghq2.orgo对每个域名,我们都希望在80端口和8080端口发布我们的网站。可以 这样配置:服务器配置(apache的配置文件httpd.conf)Listen 172.16.3.40:80Listen 172.16.3.40:8080Listen 172.16.3.50:80Listen 172.16.3.50:8080Docum
7、entRoot /www/ghql-80ServerName DocumentRoot /www/ghql-8080ServerName DocumentRoot /www/ghq2-80ServerName www.ghql.orgDocumentRoot /www/ghq2-8080ServerName www.ghq2.org因此,建立虚拟主机,我们要做好不同的IP对应的域名解析url=javascript:;T 作/url,建立相应的目录(如/www/ghql),将相应的主页内容存放在相应的目录中即可。二、Apache实现基于主机名的虚拟主机服务(一个IP地址实现多个网站)基于主机名字
8、的虚拟主机服务,是目前虚拟主机比较常用的一种方案。因为它不需要 更多的IP地址,无须什么特殊的软硬件支持。而且现在的浏览器大都支持这种虚拟主机的 实现方法。基于域名的的虚拟主机是根据客户端提交的HTTP头中的关于主机名的部分决定 的。使用这种技术,很多虚拟主机可以享用同一个IP地址。基于域名的虚拟主机相对比较简单,因为我们只需要配置DNS服务器将每个主机名映 射(CNAMES)到正确的IP地址,然后配置Apache HTTP服务器,令其辨识不同的主机名 就可以了。基于域名的服务器也可以缓解IP地址(IPV4)不足的问题。这种方式下,各个 虚拟主机共享同一份Apache,因此有CGI程序运行时,
9、安全性也不高。优点:只要一个IP地址就可以提供大量的虚拟主机服务。缺点:安全性差。维护这些虚拟主机时需耍更改配置文件,并且需要重新启动Apache 进程才能起作用。因此不适合进行大规模的虚拟主机服务。如果服务器只有一个IP地址,而在DNS中有很多映射到这个机器。我们想要在这个 机器上运行和www.ghq2.org两个站点。在Apache服务器的配置中创建一个 虚拟主机并不会自动在DNS中对主机名做相应更新。我们必须自己在DNS中添加域名来指 向我们的IP地址。否则别人是无法看到我们的web站点。服务器配置(apache的配置文件httpd.conf)# Ensure that Apache l
10、istens on port 80Listen 80# Listen for virtual host requests on all IP addressesNameVirtualHost *DocumentRoot /w ww/ghq 1ServerName # Other directives hereDocumentRoot /www/ghq2ServerName www.ghq2.org# Other directives here因为* (星号)匹配所有的地址,所以主服务器不接收任何请求。因为首先出现在配置文件中,所以它拥有最高优先级,可以认为是默认或首要服务器。这意味着 如果一个
11、接受的请求不能与某个ServerName指令相匹配,它将会由第一个VirtualHost所 伺服。当我们的IP地址无法确定的时候,使用*是很方便的-比如说,ISP给我们配置的是 动态IP地址(如ADSL拨号上网),而我们有使用了某种动态域名解析系统时。因为*匹配 任何IP地址,所以在这样的情况下,不论IP地址如何变化,我们都不需要另外进行配置。 上述配置就是我们在绝大多数情况下使用基于域名的虚拟主机时将要用到的。关于DNS和Apache本文档的涵义一言以蔽之就是:不要让Apache在解析配置文件的时候用到DNSo如果 Apache在解析配置文件时用到了 DNS,您的服务器就会发生可靠性的问题(
12、也可能根本无法 启动),或者遭致拒绝(偷窃)服务攻击(包括用户可以从其他用户那里偷窃点击)。一个简单示例拒绝服务main server”地址避免这些问题的小技巧附录:进一步的提示一个简单示例ServerAdmin webgirlabc.dom DocumentRoot /www/abc为了让Apache功能正常,一个虚拟主机绝对需要以下两部分的信息:ServerName和与服 务器对应的至少一个IP地址。这个示例没有包括IP地址,于是Apache必须用DNS来查 询www.abc.dom的地址。如果在某些不可预料的情况下,当您的服务器解析配置文件时没 有得到DNS的支持,那么这个虚拟主机 将不
13、会被配置。它将不会对任何请求作出反应。 (在Apache的L2版本之前,服务器甚至无法启动)。假设www.abc.dom的IP地址是1000。那么看看以下这个配置片断:ServerAdmin webgirlabc.dom DocumentRoot /www/abc现在Apache需要DNS对这个虚拟主机进行反向域名解析来确定ServerNameo如果反向解 析失败,那么这将导致这个虚拟主机部分功能丧失。(在Apache的1.2版本之前,服务器 将不能启动)。如果虚拟主机是基于域名的,它将完全不能使用,但如果它是基于IP的, 那么它将很有可能工作。然而,如果Apache不得不为一个已经包含了服务
14、器域名的服务器产生一个完整的URL,那么它将可能产生一个无效的URLo 以下是一个可以避免上述两个问题的配置片断.ServerName www.abc.domServerAdmin webgirlabc.dom DocumentRoot /www/abc拒绝服务拒绝服务主要由(至少)两种形式导致。如果您在运行Apache L2以前的版本,在上述两种 情况下,如果您的任何一个虚拟主机的DNS解析失败,您都会无法启动服务。在一些情况 下,DNS解析甚至不在您的控制范围之内。比如说,如果abc.dom是您的一个客户,而且 他们自己控制着DNSo那么仅仅是因为他们删除了 www.abc.dom这个记录
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 2023 配置 apache 虚拟主机
限制150内