Apache2之虚拟主机设置手册

极速动力1年前帮助188

翻译人员:无

校对人员:无

适用版本:2

近来似乎有不少的兄弟在Gaim中寻问关于虚拟主机设置,明天刚好有点时间,所以我就边试验边写了这篇手册,供你们参考。

1.测试环境2.基本配置

我们都晓得,假如我们想在单台机器上设置多个域名主机名时,我们就要用到基于名称的虚拟主机了。这么要怎么进行设置呢?这就是本手册想解决的问题了。在的/etc//目录下有个的主配置文件.conf。在该文件中我们可以看见有如此一行内容:

Include /etc/apache2/sites-enabled/[^.#]*

这行的意思表明该文件包含了/etc//sites-/目录中文件名不含"."或"#"这两个字符的所有文件。而当我们列举该目录的文件时,发觉只有一个000-的软链接文件,实际联接的是/etc//sites-目录中的文件,不难看出该文件的文件名中并不包含"."或"#"。所以这个文件其实是要被配置文件.conf所包含的了。打开该文件,发觉它似乎是一个虚拟主机的配置文件,不过因为该文件中的虚拟主机为*,所以它实际上是一个通用配置文件。假如我们要构建虚拟主机的话,这么就要把该文件改成如下所示

NameVirtualHost 10.39.6.59

ServerName www.firehare.com
ServerAdmin Ubuntu.firehare@gmail.com

DocumentRoot /var/www/

Options FollowSymLinks
AllowOverride None


Options Indexes FollowSymLinks MultiViews
AllowOverride None
Order allow,deny
allow from all
# This directive allows us to have apache2's default start page
# in /apache2-default/, but still have / go to the right place
# Commented out for Ubuntu
#RedirectMatch ^/$ /apache2-default/


ScrIPtAlias /cgi-bin/ /usr/lib/cgi-bin/

AllowOverride None
Options ExecCGI -MultiViews +SymLinksIfOwnerMatch
Order allow,deny
Allow from all


ErrorLog /var/log/apache2/error.log

# Possible values include: debug, info, notice, warn, error, crit,
# alert, emerg.
LogLevel warn

CustomLog /var/log/apache2/access.log combined
ServerSignature On

Alias /doc/ "/usr/share/doc/"

Options Indexes MultiViews FollowSymLinks
AllowOverride None
Order deny,allow
Deny from all
Allow from 127.0.0.0/255.0.0.0 ::1/128



下边我们来剖析一下前面这段设置中与虚拟主机有关的设置句子:

这样我们就配置了一个虚拟主机。但因为这是缺省配置,所以在重启以后,无论你输入dns服务器中指向这个主机的任何域名,就会被导向这个缺省配置所指向的/var/www这个目录的。除非该域名被其他虚拟主机配置所用,例如我们还配置了指向本机,且配置了相应的虚拟主机,这样的话,输入域名才会被对应当域名的目录中。

3.进一步说明

为了说明清楚我们再添加一个虚拟主机站点,首先到/etc//sites-/目录中构建一个文件。其实这个文件名中是没有"."或"#"这两个字符的了。之后编辑该文件:


ServerName edunuke.firehare.com
ServerAdmin ubuntu.firehare@firehare.com
DocumentRoot "/var/www/edunuke/"
ErrorLog "/var/log/apache2/edunuke_errors.log"
CustomLog "/var/log/apache2/edunuke_accesses.log" common

设置的具体含意同前面的相像,这是我就不再多说了。之后再运行命令

sudo a2ensite edunuke

这样的话,虚拟主机站点就早已安装好了。这时你也可以在/etc//sites-/目录中发觉多了一个到/etc//sites-/的软链接。接出来就是将重启来使虚拟主机站点运行上去:

sudo /etc/init.d/apache2 restart

这样你在浏览器上输入的话,都会被指向/var/www/目录了,而输入其他指向本机的域名则还会指到缺省配置中的/var/www目录中。熟悉的同学会问为何这样麻烦,置于一个文件中不也是可以吗?为何要用两个文件呢?虽然很简单,由于假如我要对站点进行维护时,我只要运行命令:

sudo a2dissite edunuke
sudo /etc/init.d/apache2 restart

即可,这样既可以维护这个站点,同时还不影响其他站点的正常运行。

4.中级配置

里面谈了一下简单的虚拟主机配置方式。这个基本上能满足我们大部份的须要。但若果要是安装Zope+Plone的话,前面的这点设置是远远不够的,因为Zope+Plone结构所采用的端口并非是80端口,所以我们还得做端口重定向。为了才能做这个,我们得激活和Proxy两个模块。激活模块很简单,同站点配置目录一样,在中也有两个模块配置目录:mods-和mods-。在mods-目录中的是所有可用的模块,而在mods-目录中的则是已被安装到中的模块。因为在mods-目录中早已有了和Proxy模块的配置引导文件,所以只须要简单地将其安装到中即可。使用命令:

sudo a2enmod rewrite
sudo a2enmod proxy

之后,添加虚拟主机站点,同站点创建相像在/etc//sites-/目录中构建一个文件plone。其实这个文件名中是没有"."或"#"这两个字符的了。之后编辑该文件:


ServerName plone.firehare.com
ServerAdmin ubuntu.firehare@firehare.com
ErrorLog "/var/log/apache2/plone_errors.log"
CustomLog "/var/log/apache2/plone_accesses.log" common

RewriteEngine on
RewriteRule ^/(.*) http://127.0.0.1:8081/VirtualHostBase/http/plone.firehare.com:80/plone/VirtualHostRoot/$1 [L,P]


Order Deny,Allow
Deny from all
Allow from all



这样就安装好了虚拟主机站点,可以在浏览器中地址栏中输入就可以重定向到Zope+Plone站点去了。

相关文章

新哈弗H5,凭哪些15万级SUV无对手?

日前,新哈弗H5即将上市,12.28-15.78万的定价让这款车成为了辐条的焦点,“大型全用途硬朗SUV”这个新的细分品类第一次出现在人们的视野中,超高的性价比让它获得了不少的称赞,也带来了众多疑惑,...

免费海外虚拟主机怎样样?海外虚拟主机要注意什么性能指标?

免费海外虚拟主机怎样样?海外虚拟主机要注意什么性能指标?随着经济的发展,更多的企业开始选择与美国企业进行贸易互动若果是外贸建站,选择虚拟主机就有一定的要求。否则在用户访问网站是,因为距离较远的问题,用...

下一代浏览器Beaker?把你的笔记本弄成文件共享服务器

浏览器你们应当都很熟悉了,傲游、、Edge和其它基于的浏览器,好多都是长治小异,通过扩充插件都可以达到一样的功能。 明天给你们推荐一款另类的冷门浏览器「」基于、、Node.js构建的点对点浏览器,按照...

美国虚拟主机购买,华人代理转运

美国虚拟主机购买比较常见的价格范围在100美元-160美元。知乎有朋友推荐一个美国虚拟主机商,很推荐:“国外美国虚拟主机华人快递代理转运”下面是详细介绍,有兴趣可以查看一下:虚拟主机购买推荐,美国虚拟...

香港服务器防御CC攻击:多种工具畅受欢迎

香港服务器防御cc攻击的工具非常多,以下是一些常见的cc工具和对应的防御网站,例如,比如,最近vps大佬也加入了vps防御cc行列之中,还有加拿大的也使用-vpn,广受欢迎。 可以用 搭建vps可不是...

网站被功击如何办?

网站被功击你要好好对整个网站进行剖析。那边我先介绍下。功击的形式在一一为你解答: 功击可以分为入侵功击跟干扰功击(也就是所谓的DDOS功击)DDOS功击他还有下边的分类待会儿渐渐跟你说你不急 入侵功击...