有关Apache 你不可能不要明白的业务

首先,那是部分Apache配置的基础设置,他能够帮你在Ubuntu CentOS
和OSX下安装和配置3个apache服务器并让她扶助PHP,然后能够创建八个虚拟主机(基于ServerName的)。

很久在此此前不变的开篇–安装

在分化的平台下安装Apache的点子差不离相同,而且多数的Linux发行版本会私下认可帮你安装Apache,所以安装Apache的率先步,应当是反省你的操作系统里是或不是业已安装了Apache。
检查apache是或不是已经设置最简便的点子一般是在终点输入apache之类的授命,看是都存在。以独家是osx,ubuntu和CentOS检查是还是不是曾经设置apache的措施:

CentOS & Ubuntu

检查是还是不是有httpd大概apache2那样的服务,那就足以略过第叁步咯

#   service httpd start
#   service apache start
#   apachectl start

OSX

主干如今主流的多少个osx版本都是暗中认可安装apache的,当然还有php

万一,你的系统很绝望(一般从网络上租用只怕购买销售的服务器主机都是很干净的)那么你就须求本身设置apache咯。

CentOS通过YUM安装
 # yum install httpd

或者(注意不是持续是照旧,两条命令二选一,怎么选就看你的现实性必要咯,关于httpd和apache2的涉嫌。。。。此处略去第一百货公司字,如有疑问问谷哥)

 # yum install apache2

ubuntu通过apt-get安装

apt-get get install apache2

那么,这是使用软件包管理器来安装apache的方法,Ubuntu通过apt-get获取的对apache2会对配置文件目录和管理稍微做一些优化和CentOS略有不同。

其次,还有手动编译安装apache的办法,大概就是这样。
####CentOS&Apache手动编译:
>      # wget http://blablabla/apache.2.x.x.tar.gz(下载地址)
     # tar -zxvf apache2.x.x.tar.gz
     # cd apache2.x.x.x
     # ./configure --prefix=/path/to/you/want/install/dir
     # make
     # make install
     # /path/to/you/want/install/dir/apachectl  start

####Apache的配置
不管是在ubuntu还是在CentOS还是OSX下你都可以在`/etc/apache(2)`下找到关于apache的配置文件
> ubuntu下略微有点不同,Ubuntu下使用apache2.conf作为跟配置目录,然后在这个文件中include另一些配置文件,其中需要注意的是`sites-available`和` sites-enabled`,sites-available内可以放置一些站点的配置文件,这些文件需要启动的时候只需要在sites-enable里建立一个软连接即可。

ln -s sites-enable/mysite.conf sites-available/mysite.conf

####一些mod的开启

你可以使用软件包安装mod-php和mod-python之类的工具,事实上是得到了一个so文件,以便apache链接,很多时候仅仅apache的配置文件内默认就已经有这些mod文件了,你要做的仅仅是去掉前面的注释(#)而已。

#### 虚拟主机的配置
我举一个最常用的栗子:
> 现在一个二级域名下有如下两个站点:
   blog.mysite.com
   dev.mysite.com

如何让用户输入不同的域名,apache可以给出不同目录下的站点呢?虚拟主机(VirtualHost)可以很优雅的解决这个问题:
我们可以在主配置文件内,或者一些可以被主配置文件(http.conf `or` apache.con)include的文件(OS X下的others,CentOS下的conf.d内 )。

大概是这么写的:

<virtualHost *:80>
DocumentRoot /Users/scoot/site/admin/www
ServerName admin.dev.com
<Directory “/Users/scoot/src/admin/www”>
Options Indexes FollowSymLinks Multiviews
AllowOverride All
Order Allow,Deny
Allow from all
</Directory>
</virtualHost>

<virtualHost *:80>
DocumentRoot /Users/scoot/site/jybweb/www
ServerName
www.dev.com
<Directory “/Users/scoot/src/jybweb/www”>
Options Indexes FollowSymLinks Multiviews
AllowOverride All
Order Allow,Deny
Allow from all
</Directory>
</virtualHost>

上面的配置文件创建了两个虚拟主机(它来自于我的osx上的apache配置文件),我们现在来解读这些语句的含义:

- `<virtualHost *:80>` #指定了虚拟主机监听的ip或者域名为*,端口为80端口
- `DocumentRoot` 指定了网站所位于的目录
- `ServerName` 则为我们的域名
- `<Directory>`则具体配置了我们某一个目录的访问权限
    - `Options`  则制定了页面显示的一些规则
        - `Indexs` 默认按照apache的Indexs配置来选择默认打开的文档,如`index.php` `index.html` 你可以在apache的主配置文件内去增加你想作为默认文档的名字  
        - `FollowSymLinks` 是在默认文档没有匹配到之后显示整个文件列表(**我建议你在项目上线的时候移除它,除非你的目录下有`.htaccess`文件**)
        - `Multiviews`  这应该是apache2`新特性`了,可以按照apache2的一个隐式的规则对文件名做匹配,比如可以实现index代替index.php
         > 事实上我的配置文件内Multiviews并没有什么卵用,很多时候Multiviews反而会影响程序的调试,比如php的rewrite

    - `AllowOverride` 当设置为All的时候apache是支持此目录下的rewrite_mod的,也就是说如果你的目录下包含.htaccess文件,那么你必须设置AllowOverride 为All,否则请设置为None

    - `Order Allow,Deny `是对过滤操作的一个排序,决定优先处理Allow(允许)还是优先处理Deny(拒绝)

    - `Allow From` 说白了就是白名单 all表示全部,当然你也可以制定一个IP地址段,比如`Allow From 10.1.0.0/255.255.0.0 ` 
>ip地址段的表达公式可以自行补课,不属于本节课范畴

    - `Deny From` 黑名单,用法同Allow From相同,功能相反

>通常你还可以添加更多的Directory,分别设置不同的权限

>当配置文件被修改后一般需要重启服务器,在此之前建议使用如下命令检查配置文件是否包含语法错误: 

apachectl -t

确认无误,也就是返回`Syntax OK`后再重启服务器,重启服务器有多种命令,即可以使用系统服务Service也可使用直接定位到init.d内的apache2,也可以直接apachectl restart,下面是比较常用的一种:

service httpd(or apache2) restart

####DNS设置
如果你拥有一个上面的二级域名,你可以对其设置DNS绑定,这很简单就是点点鼠标的事情。
**但是**,如果你还没有一个域名,也没有公网服务器,你只是想在本机做配置的话,你可以修改本机的hosts文件,分别绑定几个域名到127.0.0.1,大概像下面这样:

9 ::1 localhost
10 127.0.0.1 admin.dev.com
11 127.0.0.1
www.dev.com
12 127.0.0.1 mysite
13 127.0.0.1 conf.dev.com

如果你希望你局域网内的所有用户都可以通过域名来访问的话,你可以考虑编写几行代码提供下载,帮助用户修改hosts文件,如果你的公司网络为三级网构架,你可以在你的机房自己配置一台DNS服务器。


####文件系统的权限

你以为把Apache配置好了,重启成功了,DNS也指向过来了,你就可以通过域名访问不同的站点了?一般情况下,你还需要特别注意文件系统的权限。比如,(Linux中)当你的网站目录被放在你的用户目录下时,你可能会得到403错误,这个时候必须更改文件的从属,你可以把你的用户添加到apache用户组内;
>在ubuntu下叫做www-data, osx下叫做_www, centos下叫做www,你可以在apache.conf或者httpd.conf内修改Groups的名字。

你可以尝试使用chown命令:
    # chown -R ($whoami):www DocumentRoot
在osx或者ubuntu下,可能组的名称并不是www,你可以自几在apache.conf或者httpd.conf中修改。

为了安全起见,最好在设置一下文件系统的权限,比如:

    # chmod -R 744 DocumentRoot

至于到底是 777 766 744 或是 644 ,给什么样的权限,则要看你的需求,如果你的文档中有文件需要写入权限或者有文件夹是用来存放动态生成的文件的,那么比最好是单独指定该文件或者文件夹的权限属性。

####结语
这只是apache最基础的一点配置,事实上apache还有很多东西等待我们去发掘,但是一味的去死记硬背apache的配置是很不明智的,搞清楚原理,认真的看一看apache.conf或者httpd.conf里的配置,大部分问题你都能自行解决,而不是在百度上查找那些千篇一律的`跟我做`教程。

相关文章