LinuxSir.cn,穿越时空的Linuxsir!

 找回密码
 注册
搜索
热搜: shell linux mysql
查看: 681|回复: 1

Apache 服务器配置全攻略(二)

[复制链接]
发表于 2003-9-2 21:32:35 | 显示全部楼层 |阅读模式
紧接上篇:


DirectoryIndex index.html  

  很多情况下,URL中并没有指定文档的名字,而只是给出了一个目录名。那么Apache服务器就自动返

回这个目录下由DirectoryIndex定义的文件,当然可以指定多个文件名字,系统会这个目录下顺序搜索。

当所有由DirectoryIndex指定的文件都不存在时,Apache服务器可以根据系统设置,生成这个目录下的所

有文件列表,提供用户选择。此时该目录的访问控制选项中的Indexes选项(Options Indexes )必须打

开,以使得服务器能够生成目录列表,否则Apache将拒绝访问。  


  AccessFileName .htaccess  

  AccessFileName定义每个目录下的访问控制文件的文件名,缺省为.htaccess,可以通过更改这个文

件,来改变不同目录的访问控制限制。  


Order allow,deny  

Deny from all  

  除了可以针对目录进行访问控制之外,还可以根据文件来设置访问控制,这  

就是File语句的任务。使用File 语句,不管文件处于哪个目录,只要名字匹配, 就必须接受相应的访问

控制。这个语句对于系统安全比较重要,例如上例将屏蔽所有的使用者不能访问.htaccess文件,这样就

避免.htaccess中的关键安全信息不至于被客户获取。  


  #CacheNegotiatedDocs  

  缺省情况下如果代理服务器和Apache服务器协商是否缓存其网页,Apache给  

予否定的回答,不希望自己的网页被代理服务器缓存。然而这样就不能有效的利用代理服务器的优势,因

此可以设置CacheNegotiatieDocs 选项, 使得代理服务器可以对网页进行缓存。然而即使不设置这个选

项,有的代理服务器(或通过调整设置)也能对网页进行缓存。  


  UseCanonicalName On  

  打开这个UseCanonicalName是Web服务器的标准做法,因为客户发送的大部分请求都是对本服务器的

引用,这样服务器就能使用ServerName和Port选项的设置内容构建完整的URL,并回应客户,使浏览器能

得到规范的URL。如果将这个参数设置为Off,那么Apache将使用从客户请求中获得服务器的名字和端口值

(支持HTTP 1.1的客户的请求中将会有这些信息),重新构建URL。  


  TypesConfig /usr/local/apache/etc/mime.types  

  TypeConfig用于设置保存有不同的MIME类型数据的文件名,在Linux下缺省设置

为/usr/local/apache/etc/mime.types。  


  DefaultType text/plain  

  如果Web服务器不能决定一个文档的缺省类型,这通常表示文档使用了非标准的后缀,那么服务器就

使用 DefaultType定义的MIME类型将文档发送给客户浏览器。这里的设置为text/plain,这样设置的问题

是,如果服务器不能判断出文档的MIME,那么大部分情况下这个文档为一个二进制文档,但使用

text/plain格式发送回去,浏览器将在内部打开它而不会提示保存。因此建议将这个设置更改为  

application/octet-stream,这样浏览器将提示用户进行保存。  


MIMEMagicFile /usr/local/apache/etc/magic  

  除了从文件的后缀出发来判断文件的MIME类型之外,Apache还可以进一步分  

析文件的一些特征,来判断文件的真实MIME类型。这个功能是由mod_mime_magic 模块实现的,它需要一

个记录各种MIME类型特征的文件,以进行分析判断。上面的设置是一个条件语句,如果载入了这个模块,

就必须指定相应的标志文件magic的位置。



通常连接时,服务器仅仅可以得到客户机的IP地址,如果要想获得客户机的主机名,以进行日志记录和提

供给 CGI程序使用,就需要使用这个HostnameLookups 选项,将其设置为On打开DNS反查功能。但是这将

使服务器对每次客户请求都进行DNS查询,增加了系统开销,使得反应变慢,因此缺省设置为使用Off关闭

此选项。关闭选项之后,服务器就不会获得客户机的主机名,而只能使用IP地址来记录客户。  


ErrorLog /var/log/httpd-error.log  

LogLevel warn  

LogFormat "%h %l %u %t "%r" %>s %b "%{Referer}i" "%{User-Agent} "" combined  

LogFormat "%h %l %u %t "%r" %>s %b" common  

LogFormat "%{Referer}i -> %U" referer  

LogFormat "%{User-agent}i" agent  

#CustomLog /var/log/httpd-access.log common  

#CustomLog /var/log/httpd-referer.log referer  

#CustomLog /var/log/httpd-agent.log agent  

CustomLog /var/log/httpd-access.log combined  


  这里定义了系统日志的形式,对于服务器错误记录, 由ErrorLog、 LogLevel 来定义不同的错误日

志文件及其记录内容。  

  对于系统的访问日志,缺省使用CustomLog参数定义日志的位置,缺省使用 combined 参数指定将所

有的访问日志放在一个文件中,然而也可以将不同种类的访问日志放在不同的日志记录文件中,这是通过

在 CustomLog中指定不同的记录类型来完成的。common表示普通的对单页面请求访问记录,referer表示

每个页面的引用记录,可以看出一个页面中包含的请求数,agent表示对客户机的类型记录,显然可以将

现有的combined 定义的设置行注释掉,并使用common、referer和agent作为CustomLog的参数,来为不同

种类的日志分别指定日志记录文件。  

  显然,LogFormat是用于定义不同类型的日志进行记录时使用的格式, 这里  

使用了以%开头的宏定义,以记录不同的内容。  

  如果这些参数指定的文件使用的是相对路径,那么就是相对于ServerRoot的  

路径。  


  ServerSignature On  

  一些情况下,例如当客户请求的网页并不存在时,服务器将产生错误文档,  

缺省情况下由于打开了 ServerSignature选项,错误文档的最后一行将包含服务器的名字、Apache的版本

等信息。有的管理员更倾向于不对外显示这些信息,就  

可以将这个参数设置为Off,或者设置为Email,最后一行将替换为对 ServerAdmin 的Email提示。  


Alias /icons/ "/www/icons/"  

Options Indexes MultiViews  

AllowOverride None  

Order allow,deny  

Allow from all  


  Alias参数用于将URL与服务器文件系统中的真实位置进行直接映射,一般的  

文档将在DocumentRoot 中进行查询,然而使用Alias定义的路径将直接映射到相  

应目录下,而不再到DocumentRoot 下面进行查询。因此Alias可以用来映射一些  

公用文件的路径,例如保存了各种常用图标的icons路径。这样使得除了使用符号连接之外,文档根目录

(DocumentRoot)外的目录也可以通过使用了Alias映射,提供给浏览器访问。  

  定义好映射的路径之后,应该需要使用Directory语句设置访问限制。  


s criptAlias /cgi-bin/ "/www/cgi-bin/"  

AllowOverride None  

Options None  

Order allow,deny  

Allow from all  

  s criptAlias也是用于URL路径的映射,但与Alias的不同在于,s criptAlias 是用于映射CGI程序的

路径,这个路径下的文件都被定义为CGI程序,通过执行它们来获得结果,而非由服务器直接返回其内容

。缺省情况下CGI程序使用cgi-bin目录作为虚拟路径。  


  # Redirect old-URI new-URL  

  Redirect参数是用来重写URL的,当浏览器访问服务器上的一个已经不存在的资源的时候,服务器返

回给浏览器新的URL,告诉浏览器从该URL中获取资源。这主要用于原来存在于服务器上的文档,改变了位

置之后,而又希望能使用老URL能访问到,以保持与以前的URL兼容。  


IndexOptions FancyIndexing  

AddIconByEncoding (CMP,/icons/compressed.gif) x-compress x-gzip  

AddIconByType (TXT,/icons/text.gif) text/*  

AddIconByType (IMG,/icons/image2.gif) image/*  

AddIconByType (SND,/icons/sound2.gif) audio/*  

AddIconByType (VID,/icons/movie.gif) video/*  

AddIcon /icons/binary.gif .bin .exe  

AddIcon /icons/binhex.gif .hqx  

AddIcon /icons/tar.gif .tar  

AddIcon /icons/world2.gif .wrl .wrl.gz .vrml .vrm .iv  

AddIcon /icons/compressed.gif .Z .z .tgz .gz .zip  

AddIcon /icons/a.gif .ps .ai .eps  

AddIcon /icons/layout.gif .html .shtml .htm .pdf  

AddIcon /icons/text.gif .txt  

AddIcon /icons/c.gif .c  

AddIcon /icons/p.gif .pl .py  

AddIcon /icons/f.gif .for  

AddIcon /icons/dvi.gif .dvi  

AddIcon /icons/uuencoded.gif .uu  

AddIcon /icons/s cript.gif .conf .sh .shar .csh .ksh .tcl  

AddIcon /icons/tex.gif .tex  

AddIcon /icons/bomb.gif core  

AddIcon /icons/back.gif ..  

AddIcon /icons/hand.right.gif README  

AddIcon /icons/folder.gif ^^DIRECTORY^^  

AddIcon /icons/blank.gif ^^BLANKICON^^  

DefaultIcon /icons/unknown.gif  

#AddDes cription "GZIP compressed document" .gz  

#AddDes cription "tar archive" .tar  

#AddDes cription "GZIP compressed tar archive" .tgz  

ReadmeName README  

HeaderName HEADER  

IndexIgnore .??* *~ *# HEADER* README* RCS CVS *,v *,t  


当一个HTTP请求的URL为一个目录的时候,服务器返回这个目录中的索引文件。但如果一个目录中不存在

缺省的索引文件,并且该服务器又许可显示目录文件列表的时候,就会显示出这个目录中的文件列表,为

了使得这个文件列表能具有可理解性,而不仅仅是一个简单的列表,就需要前面的这些设置参数。   





如果使用了IndexOptions FancyIndexing选项,可以让服务器产生的目录列  

表中针对各种不同类型的文档引用各种图标。而哪种文件使用哪种图标,则使用  

下面的 AddIconByEncoding、AddIconByType以及AddIcon来定义,分别依据MIME 的编码、类型以及文件

的后缀来判断使用何种图标。如果不能确定文档使用的图标,就使用 DefaultIcon定义的缺省图标。  

  同样,使用AddDes cription可以为不同类型的文档加入不同的描述。并且,  

服务器还在目录下,查询使用ReadmeName和HeaderName定义的文件(自动加上 .  

html后缀,如果没有发现,再使用.txt后缀进行搜索),如果发现了这些文件,  

就在文件列表之前首先显示这些文件的内容,以使得普通目录列表具备更大的可  

理解性。  

  IndexIgnore让服务器在列出文件列表时忽略相应的文件, 这里使用模式配  

置的方式定义文件名。  


AddEncoding x-compress Z  

AddEncoding x-gzip gz  

  AddEncoding用于告诉一些使用压缩的MIME类型,这样可以让浏览器进行解压缩*作。  


AddLanguage en .en  

AddLanguage fr .fr  

AddLanguage de .de  

AddLanguage da .da  

AddLanguage el .el  

AddLanguage it .it  

LanguagePriority en fr de  


  一个HTML文档可以同时具备多个语言的版本,如对于file1.html文档可以具  

备file1.html.en、file1.html.fr 等不同的版本,每个语言后缀必须使用 AddLanguage进行定义。这样

服务器可以针对不同国家的客户,通过与浏览器进行协商,发送不同的语言版本。而LanguagePriority

定义不同语言的优先级,以便在浏览器没有特殊要求时,按照顺序使用不同的语言版本回应对file1.html

的请求。  

这个国际化的能力实际的应用并不多。  

#AddType application/x-httpd-php .phtml  

#AddType application/x-httpd-php-source .phps  

 AddType参数可以为特定后缀的文件指定MIME类型,这里的设置将覆盖 mime.types中的设置。  


  #AddHandler cgi-s cript .cgi  

  AddHandler是用于指定非静态的处理类型,用于定义文档为一个非静态的文  

档类型,需要进行处理,再向浏览器返回处理结果。例如上面注释中的设置是将以.cgi结尾的文件设置为

cgi-s cript类型,那么服务器将启动这个CGI程序以进行处理。如果需要在前面Aliass cript定义的路径

之外执行CGI程序,就需要使用这个参数进行设置,此后以.cgi结尾的文件将被当作CGI程序执行。  


  在配置文件、这个目录中的.htaccess以及其上级目录的.htaccess中必须允许执行CGI程序,这需要

通过Options ExecCGI参数设定。  


#AddType text/html .shtml  

#AddHandler server-parsed .shtml  

  另外一种动态进行处理的类型为server-parsed,由服务器自身预先分析网页内的标记,将标记更改

为正确的HTML标识。由于server-parsed需要对text/html 类型的文档进行处理,因此首先定义了对应

的.shtml为text/html类型。  

  然而要支持SSI,还要首先要在配置文件(或.htaccess)中使用Options Includes允许该目录下的文

档可以为SSI类型,或使用Options IncludesNOExec让执行普通的SSI标志,但不执行其中引用的外部程序

。  


  另一种指定server-parsed类型的方式为使用XBitBack设置选项,如果将 XBitHack设置为On,服务器

将检查所有text/html类型的文档(包括.html后缀的文档),如果发现文件属性具备执行位 “x",则服

务器就认为它是服务器分析文档,需要服务器进行处理。推荐使用AddHandler进行设置,而将XBitBack

设置为Off,因为使用XBitBack将对所有的HTML文档都执行额外的检查,降低了效率。  


#AddHandler send-as-is asis  

#AddHandler imap-file map  

#AddHandler type-map var  

上面被注释的AddHandler用于支持Apache服务器的asis、map和var处理能力  

。  


# Action media/type /cgi-s cript/location  

# Action handler-name /cgi-s cript/location  

 因为Apache内部提供的处理功能有限,因此可以使用Action为服务器定义外  

部程序作为可处理的动态文档类型,这些外部程序与标准CGI程序相同,都是对输入的数据处理之后,再

输出不同MIME类型的结果。例如要定义一个对特殊后缀wri都先执行wri2txt进行处理*作,再返回结果的*

作,可以使用:  


Action windows-writer /bin/wri2txt  

AddHandler windows-writer wri  

 更进一步,可以直接使用Action定义对某个MIME类型预先进行处理*作,这  

需要例子中第一种格式的Action 参数设置方式。这样设置方式就不再需要额外的AddHandler用来将处理*

作与文件后缀联系起来,而是使用Action直接处理MIME类型的文件。但如果文档后缀没有正式的MIME类型

,还需要先定义一个MIME类型。  


#MetaDir .web  

#MetaSuffix .meta  

 Meta信息是在文档发送给客户之前,预先发送给客户浏览器一些数据,因此  

浏览器可以通过HEAD请求来访问这些Meta信息而不必真正通过GET来返回全部文档数据。服务器通常发送

给浏览器的是一些标准的HTTP头信息,如果要想增加额外的信息,就需要使用MetaDir来定义Meta数据存

放的目录, 而MetaS uffix用于指定包含Meta数据的文件后缀。  


#ErrorDocument 500 "The server made a boo boo.  

#ErrorDocument 404 /missing.html  

#ErrorDocument 404 /cgi-bin/missing_handler.pl  

#ErrorDocument 402  

http://some.other_server.com/subs cription_info.html  

  如果客户请求的网页不存在,或者没有访问权限等情况发生时,服务器将产  

生一个错误代码,同时也将回应客户浏览器一个标识错误的网页。  

ErrorDocument就用于设置当出现哪个错误时应该回应客户浏览器那些内容,ErrorDocument的第一个参数

为错误的序号,第二个参数为回应的数据,可以为简单的文本,本地网页,本地CGI程序,以及远程主机

上的网页。  


BrowserMatch "Mozilla/2" nokeepalive  

BrowserMatch "MSIE 4.0b2;" nokeepalive downgrade-1.0 force-response-1.0  

BrowserMatch "RealPlayer 4.0" force-response-1.0  

BrowserMatch "Java/1.0" force-response-1.0  

BrowserMatch "JDK/1.0" force-response-1.0  

 BrowserMatch命令为特定的客户程序,设置特殊的参数,以保证对老版本浏  

览器的兼容性,并支持新浏览器的新特性。  


#  

# SetHandler server-status  

# Order deny,allow  

# Deny from all  

# Allow from .your_domain.com  

#  

#  

# SetHandler server-info  

# Order deny,allow  

# Deny from all  

# Allow from .your_domain.com  

#  

#  

# Deny from all  

# ErrorDocument 403 http://phf.apache.org/phf_abuse_log.cgi ;


用于设置访问控制的设置主要是针对目录和文件进行设置的,然而也可以针对不同的URL进行访问控制的

设置,这样就不必担心s criptAlias、Alias是否将路径设置到了受控制的目录之外了。针对URL进行控制

的语句为 Location语句,这样不但能对服务器上的文件、CGI提供保护,此外,它还能保护不能找到对应

文件,而是由服务器本身提供的特殊功能URLhttp://servername/server-status用于报告当前Apache服务

器的状态http://servername/server-info用于报告Apache 服务器的统计信息。与此相关的设置还有

ExtendedStatus参数,可以让服务器输出更详细的的报告。  


#  

#ProxyRequests On  

#  

#  

# Order deny,allow  

# Deny from all  

# Allow from .your_domain.com  

#  

#ProxyVia On  

#CacheRoot "/www/proxy"  

#CacheSize 5  

#CacheGcInterval 4  

#CacheMaxExpire 24  

#CacheLastModifiedFactor 0.1  

#CacheDefaultExpire 1  

#NoCache a_domain.com another_domain.edu joes.garage_sale.com  


#  


  Apache服务器本身就具备代理的功能,然而这要求加载入mod_proxy模块。这能使用IfModule语句进

行判断,如果存在mod_proxy模块,就使用ProxyRequests打开代理支持。此后的Directory用于设置对

Proxy功能的访问权限设置,以及用于设置缓冲的各个参数设置。  


虚拟主机  

#NameVirtualHost 12.34.56.78:80  

#NameVirtualHost 12.34.56.78  

#  

# ServerAdmin webmaster@host.some_domain.com  

# DocumentRoot /www/docs/host.some_domain.com  

# ServerName host.some_domain.com  

# ErrorLog logs/host.some_domain.com-error_log  

# CustomLog logs/host.some_domain.com-access_log common  

#  


#  


  缺省设置文件中的这些内容是用于设置命名基础的虚拟主机服务器时使用。  

其中NameVirtualHost 来指定虚拟主机使用的IP地址,这个IP地址将对应多个 DNS名字,如果Apache使用

了Listen 参数控制了多个端口,那么就可以在这里加上端口号以进一步进行区分对不同端口的不同连接

请求。此后,使用 VirtualHost 语句,使用NameVirtualHost指定的IP地址作参数,对每个名字都定义对

应的虚拟主机设置。  

  虚拟主机是在一台Web服务器上,可以为多个单独域名提供Web服务,并且每个域名都完全独立,包括

具有完全独立的文档目录结构及设置,这样域名之间完全独立,不但使用每个域名访问到的内容完全独立

,并且使用另一个域名无法访  

问其他域名提供的网页内容。  

  虚拟主机的概念对于ISP来讲非常有用,因为虽然一个组织可以将自己的网页挂在具备其他域名的服

务器上的下级往址上,但使用独立的域名和根网址更为正式,易为众人接受。传统上,必须自己设立一台

服务器才能达到单独域名的目的,然而这需要维护一个单独的服务器,很多小单位缺乏足够的维护能力,

更为合适的方式是租用别人维护的服务器。ISP也没有必要为一个机构提供一个单独的服务器,完全可以

使用虚拟主机能力,使服务器为多个域名提供Web服务,而且不同的服务互不干扰,对外就表现为多个不

同的服务器。  

  有两种设定虚拟主机的方式,一种是基于HTTP 1.0标准,需要一个具备多IP  

地址的服务器,再配置DNS 服务器,给每个IP地址以不同的域名,最后才能配置Apache的配置文件,使服

务器对不同域名返回不同的Web文档。由于这需要使用额外的IP地址,对每个要提供服务的域名都要使用

单独的IP地址,因此这种方式实现起来问题较多。  

  可以在一个网络界面上绑定多个IP地址,Linux下需要使用ifconfig的 alias参数来进行这个配置,

但此时会影响网络性能。  

  HTTP 1.1标准在协议中规定了对浏览器和服务器通信时,服务器能够跟踪浏  

览器请求的是哪个主机名字。因此可以利用这个新特性,使用更轻松的方式设定  

虚拟主机。这种方式不需要额外的IP地址,但需要新版本的浏览器支持。这种方式已经成为建立虚拟主机

的标准方式。  

  要建立非IP基础的虚拟主机,多个域名是不可少的配置,因为每个域名就对  

应一个要服务的虚拟主机。因此需要更改DNS服务器的配置,为服务器增加多个C NAME选项,如:  


linux IN A 192.168.1.64  

vhost1 IN CNAME linux  

vhost2 IN CNAME linux  


 基本的设置选项都是为了linux主机设定的,如果要为vhost1和vhost2设定  

虚拟主机,就要使用VirtualHost语句定义不同的选项,在语句中可以使用配置文件前面中的大部分选项

,而可以重新定义几乎所有的针对服务器的设置。  


NameVirtualHost 192.168.1.64  


DocumentRoot /www/data  

ServerName linux.example.org.cn  


DocumentRoot /vhost1  

ServerName vhost1.example.org.cn  


DocumentRoot /vhost2  

ServerName vhost2.example.org.cn  


  这里需要注意的是,VirtualHost的参数地址一定要和NameVirtualHost定义的地址相一致,必须保证

所有的值严格一致,Apache服务器才承认这些定义是为这个IP地址定义的虚拟主机。  

  此外,定义过NameVirtualHost之后,那么对这个IP地址的访问都被区分不同的虚拟主机进行处理,

而对其他IP地址的访问,例如127.0.0.1,才应用前面定义的缺省选项。
发表于 2003-9-4 13:50:53 | 显示全部楼层

厉害

学习中,看着有些头晕。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

快速回复 返回顶部 返回列表