ServerRoot “/usr/local“ ServerRoot用于指定守护进程httpd的运行目录,httpd在启动以后将自动将进程的当前目录改变为这个目录,所以若是设置文件中指定的文件或目录是相对路径,那么真实路径就位于这个ServerR oot定义的路径之下。 ScoreBoardFile /var/run/httpd.scoreboard httpd使用ScoreBoardFile来维护进程的内部数据,所以一般不须要改变这个参数,除非管理员想在一台计算机上运行几个 Apache服务器,这时每一个Apache服务器都须要独立的设置文件htt pd.conf,并使用不一样的ScoreBoardFile。 #ResourceConfig conf/srm.conf #AccessConfig conf/access.conf 这两个参数ResourceConfig和AccessConfig,就用于和使用srm.conf和access.conf设置文件的老版本 Apache兼容。若是没有兼容的须要,能够将对应的设置文件指定为/dev/null,这将表示不存在其余设置文件,而仅使用httpd.conf一个 文件来保存全部的设置选项。 PidFile /var/run/httpd.pid PidFile指定的文件将记录httpd守护进程的进程号,因为httpd能自动复制其自身,所以系统中有多个httpd进程,但只有一个进程 为最初启动的进程,它为其余进程的父进程,对这个进程发送信号将影响全部的httpd进程。PidFILE定义的文件中就记录httpd父进程的进程号。 Timeout 300 Timeout定义客户程序和服务器链接的超时间隔,超过这个时间间隔(秒)后服务器将断开与客户机的链接。 KeepAlive On 在HTTP 1.0中,一次链接只能做传输一次HTTP请求,而KeepAlive参数用于支持HTTP 1.1版本的一次链接、屡次传输功能,这样就能够在一次链接中传递多个HTTP请求。虽然只有较新的浏览器才支持这个功能,但仍是打开使用这个选项。 MaxKeepAliveRequests 100 MaxKeepAliveRequests为一次链接能够进行的HTTP请求的最大请求次数。将其值设为0将支持在一次链接内进行无限次的传输请求。事实上没有客户程序在一次链接中请求太多的页面,一般达不到这个上限就完成链接了。 KeepAliveTimeout 15 KeepAliveTimeout测试一次链接中的屡次请求传输之间的时间,若是服务器已经完成了一次请求,但一直没有接收到客户程序的下一次请求,在间隔超过了这个参数设置的值以后,服务器就断开链接。 ThreadsPerChild 50 设置服务器使用进程的数目。 # 这是以服务器的响应速度为准的, 数目太大则会变慢 MaxRequestsPerChild 30 使用子进程的方式提供服务的Web服务,经常使用的方式是一个子进程为一次链接服务,这样形成的问题就是每次链接都须要生成、退出子进程的系统操做, 使得这些额外的处理过程占据了计算机的大量处理能力。所以最好的方式是一个子进程能够为屡次链接请求服务,这样就不须要这些生成、退出进程的系统消 耗,Apache就采用了这样的方式,一次链接结束后,子进程并不退出,而是停留在系统中等待下一次服务请求,这样就极大的提升了性能。 但因为在处理过程当中子进程要不断的申请和释放内存,次数多了就会形成一些内存垃圾,就会影响系统的稳定性,而且影响系统资源的有效利用。所以在一 个副本处理过必定次数的请求以后,就可让这个子进程副本退出,再从原始的htt pd进程中从新复制一个干净的副本,这样就能提升系统的稳定性。这样,每一个子进程处理服务请求次数由MaxRe questPerChild定义。 缺省的设置值为30,这个值对于具有高稳定性特色的FreeBSD系统来说是过于保守的设置,能够设置为1000甚至更高,设置为0支持每一个副本进行无限 次的服务处理。 为了安全,设置为零 #Listen 3000 #Listen 12.34.56.78:80 #BindAddress * Listen参数能够指定服务器除了监视标准的80端口以外,还监视其余端口的HTTP请求。因为FreeBSD系统能够同时拥有多个IP地址, 所以也能够指定服务器只听取对某个BindAddress< /B>的IP地址的HTTP请求。若是没有配置这一项,则服务器会回应对全部IP的请求。 即便使用了BindAddress参数,使得服务器只回应对一个IP地址的请求,可是经过使用扩展的Listen参数,仍然可让HTTP守护进 程回应对其余IP地址的请求。此时Listen参数的用法与上面的第二个例子相同。这种比较复杂的用法主要用于设置虚拟主机。此后能够用 VirtualHost参数定义对不一样IP的虚拟主机,然而这种用法是较早的HTTP 1.0标准中设置虚拟主机的方法,每针对一个虚拟主机就须要一个IP地址,实际上用处并不大。在HTTP 1.1中,增长了对单IP地址多域名的虚拟主机的支持,使得虚拟主机的设置具有更大的意义。 #ExtendedStatus On Apache服务器能够经过特殊的HTTP请求,来报告自身的运行状态,打开这个ExtendedStatus 参数可让服务器报告更全面的运行状态信息 --------------------------------------------------------------------------------- ServerAdmin you@your.address 配置文件中应该改变的也许只有ServerAdmin, 这一项用于配置WWW服务器的管理员的email地址,这将在HTTP服务出现错误的条件下返回给浏览器,以便让Web使用者和管理员联系,报告错误。习 惯上使用服务器上的webmaster做为WWW服务器的管理员,经过邮件服务器的别名机制,将发送到webmaster 的电子邮件发送给真正的Web管理员。 ServerName localhost 缺省状况下,并不须要指定这个ServerName参数,服务器将自动经过名字解析过程来得到本身的名字,但若是服务器的名字解析有问题(一般为 反向解析不正确),或者没有正式的DNS名字,也能够在这里指定I P地址。当ServerName设置不正确的时候,服务器不能正常启动。 一般一个Web服务器能够具备多个名字,客户浏览器可使用全部这些名字或IP地址来访问这台服务器,但在没有定义虚拟主机的状况下,服务器老是 以本身的正式名字回应浏览器。ServerName就定义了Web服务器本身认可的正式名字,例如一台服务器名字(在DNS中定义了A类型)为 freebsd.exmaple.org.cn,同时为了方便记忆还定义了一个别名(CNAME记录)为www.exmaple.org.cn,那么 Apache自动解析获得的名字就为freebsd.example.org.cn,这样无论客户浏览器使用哪一个名字发送请求,服务器老是告诉客户程序自 己为freebsd.example.org.cn。虽然这通常并不会形成什么问题,可是考虑到某一天服务器可能迁移到其余计算机上,而只想经过更改 DNS中的www别名配置就完成迁移任务,因此不想让客户在其书签中使用 freebsd记录下这个服务器的地址,就必须使用ServerName来从新指定服务器的正式名字。 DocumentRoot “/usr/local/www/data“ DocumentRoot定义这个服务器对外发布的超文本文档存放的路径,客户程序请求的UR L就被映射为这个目录下的网页文件。这个目录下的子目录,以及使用符号链接指出的文件和目录都能被浏览器访问,只是要在URL上使用一样的相对目录名。 注意,符号链接虽然逻辑上位于根文档目录之下,但实际上能够位于计算机上的任意目录中,所以可使客户程序能访问那些根文档目录以外的目录,这在 增长了灵活性的同时但减小了安全性。Apache在目录的访问控制中提供了FollowSymLinks选项来打开或关闭支持符号链接的特性。 <Directory /> Options FollowSymLinks AllowOverride None </Directory> Apache服务器能够针对目录进行文档的访问控制,然而访问控制能够经过两种方式来实现,一个是在设置文件 httpd.conf(或access.conf)中针对每一个目录进行设置,另外一个方法是在每一个目录下设置访问控制文件,一般访问控制文件名字 为.htaccess。虽然使用这两个方式都能用于控制浏览器的访问,然而使用配置文件的方法要求每次改动后从新启动httpd守护进程,比较不灵活,因 此主要用于配置服务器系统的总体安全控制策略,而使用每一个目录下的.htaccess文件设置具体目录的访问控制更为灵活方便。 <Directory “H:/web001“> Directory语句就是用来定义目录的访问限制的,这里能够看出它的标准语法,为一个目录定义访问限制。上例的这个设置是针对系统的根目录进行 的,设置了容许符号链接的选项FollowSymLinks ,以及使用AllowOverride None表示不容许这个目录下的访问控制文件来改变这里进行的配置,这也意味着不用查看这个目录下的相应访问控制文件。 因为Apache对一个目录的访问控制设置是可以被下一级目录继承的,所以对根目录的设置将影响到它的下级目录。注意因为 AllowOverride None的设置,使得Apache服务器不须要查看根目录下的访问控制文件,也不须要查看如下各级目录下的访问控制文件,直至httpd.conf(或 access.conf )中为某个目录指定了容许Alloworride,即容许查看访问控制文件。因为Apache对目录访问控制是采用的继承方式,若是从根目录就容许查看访 问控制文件,那么Apache就必须一级一级的查看访问控制文件,对系统性能会形成影响。而缺省关闭了根目录的这个特性,就使得Apache从 httpd.conf中具体指定的目录向下搜寻,减小了搜寻的级数,增长了系统性能。所以对于系统根目录设置AllowOverride None不但对于系统安全有帮助,也有益于系统性能。 Options Indexes FollowSymLinks AllowOverride None Order allow,deny Allow from all </Directory> 这里定义的是系统对外发布文档的目录的访问设置,设置不一样的AllowOverride选项,以定义配置文件中的目录设置和用户目录下的安全控制文件的关系,而Options选项用于定义该目录的特性。 配置文件和每一个目录下的访问控制文件均可以设置访问限制,设置文件是由管理员设置的,而每一个目录下的访问控制文件是由目录的属主设置的,所以管理 员能够规定目录的属主是否能覆盖系统在设置文件中的设置,这就须要使用 AllowOverride参数进行设置,一般能够设置的值为: AllowOverride的设置 对每一个目录访问控制文件做用的影响 All 缺省值,使访问控制文件能够覆盖系统配置 None 服务器忽略访问控制文件的设置 Options 容许访问控制文件中可使用Options参数定义目录的选项 FileInfo 容许访问控制文件中可使用AddType等参数设置 AuthConfig 容许访问控制文件使用AuthName,AuthType等针对每一个用户的认证机制,这使目录属主能用口令和用户名来保护目录 Limit 容许对访问目录的客户机的IP地址和名字进行限制 每一个目录具有必定属性,可使用Options来控制这个目录下的一些访问特性设置,如下为经常使用的特性选项: Options设置 服务器特性设置 All 全部的目录特性都有效,这是缺省状态 None 全部的目录特性都无效 FollowSymLinks 容许使用符号链接,这将使浏览器有可能访问文档根目录(DocumentRoot)以外的文档 SymLinksIfOwnerMatch 只有符号链接的目的与符号链接自己为同一用户所拥有时,才容许访问,这个设置将增长一些安全性 ExecCGI 容许这个目录下能够执行CGI程序 Indexes 容许浏览器能够生成这个目录下全部文件的索引,使得在这个目录下没有index.html(或其余索引文件)时,能向浏览器发送这个目录下的文件列表 此外,上例中还使用了Order、Allow、Deny等参数,这是Limit语句中用来根据浏览器的域名和 IP地址来控制访问的一种方式。其中Order定义处理Allow和Deny的顺序,而Allow、Deny则针对名字或IP进行访问控制设置,上例使用 allow from all,表示容许全部的客户机访问这个目录,而不进行任何限制。 UserDir public_html (Win32=“My Documents/My Website“) 当在一台FreeBSD上运行Apache服务器时,这台计算机上的全部用户均可以有本身的网页路径,形如 http://freebsd.example.org.cn/~user,使用波浪符号加上用户名就能够映射到用户本身的网页目录上。映射目录为用户个 人主目录下的一个子目录,其名字就用UseDir这个参数进行定义,缺省为public_html。若是不想为正式的用户提供网页服务,使用 DISABLED做UserDir的参数便可。 # # AllowOverride FileInfo AuthConfig Limit # Options MultiViews Indexes SymLinksIfOwnerMatch IncludesNoExec # # Order allow,deny # Allow from all # # # Order deny,allow # Deny from all # # 这里能够看到Directory的另外一个用法,便可以经过简单的模式匹配方法,针对分布在不一样目录下的子目录定义访问控制权限。这样设置就须要Apache服务器对每一个路径进行额外的处理,所以就会下降服务器的性能,因此缺省状况并无打开这种访问限制。 这里能够看到另一个语句Limit,Limit语句就是用来针对具体的请求方法来设定访问控制的,其中可使用GET、POST等各类服务器支 持的请求方法作Limit的参数,来设定对不一样请求方法的访问限制。通常能够打开对GET、POST、HEAD三种请求方法,而屏蔽其余的请求方法,以增 加安全性。Limit语句中,可使用Order 、Allow、Deny,Allow和Deny中可使用匹配的方法针对域名和IP进行限制,只是对于域名是从后向前匹配,对于IP地址则从前向后匹配。 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中的关键安全信息不至于被客户获取。 TypesConfig /usr/local/etc/apache/mime.types TypeConfig用于设置保存有不一样的MIME类型数据的文件名,在FreeBSD下缺省设置为/usr/local/etc/apache/mime.types。 DefaultType text/plain 若是Web服务器不能决定一个文档的缺省类型,这一般表示文档使用了非标准的后缀,那么服务器就使用 DefaultType定义的MIME类型将文档发送给客户浏览器。这里的设置为text/plain,这样设置的问题是,若是服务器不能判断出文档的 MIME,那么大部分状况下这个文档为一个二进制文档,但使用 text/plain格式发送回去,浏览器将在内部打开它而不会提示保存。所以建议将这个设置更改成 application/octet-stream,这样浏览器将提示用户进行保存。 MIMEMagicFile /usr/local/etc/apache/magic 除了从文件的后缀出发来判断文件的MIME类型以外,Apache还能够进一步分析文件的一些特征,来判断文件的真实MIME类型。这个功能是由 mod_mime_magic模块实现的,它须要一个记录各类MIME类型特征的文件,以进行分析判断。上面的设置是一个条件语句,若是载入了这个模块, 就必须指定相应的标志文件magic的位置。 HostnameLookups Off 一般链接时,服务器仅仅能够获得客户机的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}i\““ 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/ “/usr/local/www/icons/“ Options Indexes MultiViews AllowOverride None Order allow,deny Allow from all Alias参数用于将URL与服务器文件系统中的真实位置进行直接映射,通常的文档将在DocumentRoot 中进行查询,然而使用Alias定义的路径将直接映射到相应目录下,而再也不到DocumentRoot 下面进行查询。所以Alias能够用来映射一些公用文件的路径,例如保存了各类经常使用图标的icons路径。这样使得除了使用符号链接以外,文档根目录 (DocumentRoot)外的目录也能够经过使用了Alias映射,提供给浏览器访问。 定义好映射的路径以后,应该须要使用Directory语句设置访问限制。 ScriptAlias /cgi-bin/ “/usr/local/www/cgi-bin/“ AllowOverride None Options None Order allow,deny Allow from all ScriptAlias也是用于URL路径的映射,但与Alias的不一样在于,ScriptAlias是用于映射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/script.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 #AddDescription “GZIP compressed document“ .gz #AddDescription “tar archive“ .tar #AddDescription “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定义的缺省图标。 一样,使用AddDescription能够为不一样类型的文档加入不一样的描述。而且,服务器还在目录下,查询使用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 的请求。这个国际化的能力实际的应用并很少。 AddDefaultCharset ISO-8859-1 浏览器选择的标准编码 简体中文网站改成:GB2312 #AddType application/x-httpd-php3 .phtml #AddType application/x-httpd-php3-source .phps AddType参数能够为特定后缀的文件指定MIME类型,这里的设置将覆盖mime.types中的设置。 #AddHandler cgi-script .cgi AddHandler是用于指定非静态的处理类型,用于定义文档为一个非静态的文档类型,须要进行处理,再向浏览器返回处理结果。例如上面注释中 的设置是将以.cgi结尾的文件设置为cgi-script类型,那么服务器将启动这个CGI程序以进行处理。若是须要在前面AliasScript定义 的路径以外执行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-script/location # Action handler-name /cgi-script/location 由于Apache内部提供的处理功能有限,所以可使用Action为服务器定义外部程序做为可处理的动态文档类型,这些外部程序与标准CGI程 序相同,都是对输入的数据处理以后,再输出不一样MIME类型的结果。例如要定义一个对特殊后缀wri都先执行wri2txt进行处理操做,再返回结果的操 做,可使用: Action windows-writer /bin/wri2txt AddHandler windows-writer wri 更进一步,能够直接使用Action定义对某个MIME类型预先进行处理操做,这须要例子中第一种格式的Action 参数设置方式。这样设置方式就再也不须要额外的AddHandler用来将处理操做与文件后缀联系起来,而是使用Action直接处理MIME类型的文件。 但若是文档后缀没有正式的MIME类型,还须要先定义一个MIME类型。 #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/subscription_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命令为特定的客户程序,设置特殊的参数,以保证对老版本浏览器的兼容性,并支持新浏览器的新特性。 # #ProxyRequests On # # # Order deny,allow # Deny from all # Allow from .your_domain.com # #ProxyVia On #CacheRoot “/usr/local/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地址,FreeBSD下须要使用ifconfig的alias参数来进行这个配置,但此时会影响网络性能。 HTTP 1.1标准在协议中规定了对浏览器和服务器通讯时,服务器可以跟踪浏览器请求的是哪一个主机名字。所以能够利用这个新特性,使用更轻松的方式设定虚拟主机。 这种方式不须要额外的IP地址,但须要新版本的浏览器支持。这种方式已经成为创建虚拟主机的标准方式。 要创建非IP基础的虚拟主机,多个域名是不可少的配置,由于每一个域名就对应一个要服务的虚拟主机。所以须要更改DNS服务器的配置,为服务器增长多个CNAME选项,如: freebsd IN A 192.168.1.64 vhost1 IN CNAME freebsd vhost2 IN CNAME freebsd 基本的设置选项都是为了freebsd主机设定的,若是要为vhost1和vhost2设定虚拟主机,就要使用VirtualHost语句定义不一样的选项,在语句中可使用配置文件前面中的大部分选项,而能够从新定义几乎全部的针对服务器的设置。 NameVirtualHost 192.168.1.64 DocumentRoot /usr/local/www/data ServerName freebsd.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,才应用前面定义的缺省选项。 ---------------------------------------------------------------------------------------- NameVirtualHost www.xxx.org (对于动态IP的另类方法:指定虚拟主机的IP,因为要将域名映射为IP,不能使用localhost,127.0.0.1,计算机名,等这样的地址,因此,能够再一次经过域名转换,将域名转换为IP,这样就没必要每次更改IP了。) # # VirtualHost example: # Almost any Apache directive may go into a VirtualHost container. # The first VirtualHost section is used for requests without a known # server name. # <VirtualHost 192.168.0.1>(虚拟主机IP) ServerAdmin 111@xxx.com(第一个虚拟主机Email) DocumentRoot H:/web001(第一个虚拟主机目录) ServerName www.xxx.org(第一个虚拟主机域名) ErrorLog logs/www.xxx.org-error.log(第一个虚拟主机错误日志) CustomLog logs/www.xxx.org-access.log common(第一个虚拟主机数据) </VirtualHost> <VirtualHost 192.168.0.2>(虚拟主机IP) ServerAdmin 111@xxx.com(第二个虚拟主机Email) DocumentRoot H:/web002(第二个虚拟主机目录) ServerName www.xxx2.org(第二个虚拟主机域名) ErrorLog logs/www.xxx2.org-error.log(第二个虚拟主机错误日志) CustomLog logs/www.xxx2.org-access.log common(第二个虚拟主机数据) </VirtualHost> 以此类推,能够增长更多虚拟主机。