技术改变世界 阅读塑造人生! - shaogx.com

This string was altered by TechBlog\Plugins\Example.; This is an example to show the potential of an offcanvas layout pattern in Bootstrap. Try some responsive-range viewport sizes to see it in action.

烂泥:源码安装apache

本文首发于烂泥行天下。最近要开始学习nagios监控方面的知识了,但是nagios与apache结合的比较紧密,所以本篇文章就先把apache的源码安装学习下。我们现在分以下步骤进行安装apache:1、 安装编译环境2、 卸载原有apache3、 下载解压源码包4、 安装apache5、 测试apache6、 查看apache安装生成的目录7、 查看apache的配置文件8、 apache加入系统服务一、安装编译环境... 全文

安装 源码 apache

Ubuntu LAMP 如何配置Apache

 图-ApacheUbuntu LAMP 如何配置Apache1. 启用 mod_rewrite 模块终端命令:sudo a2enmod rewrite重启Apache服务器:sudo /etc/init.d/apache2 restart... 全文

Ubuntu LAMP Apache

puppet apache模块的例子

puppet apache模块的例子版本V1.0 时间2013-04-07 版权GPL 作者itnihao  邮箱 itnihao@qq.com 博客 http://itnihao.blog.51cto.com 如需重新发行,请注明以上信息,谢谢合作 一、apache模块的编写 目录结构/etc/puppet/modules/production/apache/... 全文

apache 模块 puppet

Apache的prefork模式和worker模式

Apache的prefork模式和worker模式 prefork模式 这个多路处理模块(MPM)实现了一个非线程型的、预派生的web服务器,它的工作方式类似于Apache 1.3。它适合于没有线程安全库,需要避免线程兼容性问题的系统。它是要求将每个请求相互独立的情况下最好的MPM,这样若一个请求出现问题就不会影响到其他请求。... 全文

apache prefork worker

Apache 日志分析

本文分五个部分:访问日志、错误日志、定制日志、日志分析、其他用法。摘自永远的Linux.Apache日志系列(1):访问日志   想要知道什么人在什么时候浏览了网站的哪些内容吗?查看Apache的访问日志就可以知道。访问日志是Apache的标准日志,本文详细解释了访问日志的内容以及相关选项的配置。  一、访问日志的格式   Apache内建了记录服务器活动的功能,这就是它的日志功能。这个文章介绍的就是Apache的访问日志、错误日志,以及如何分析日志数据,如何定制Apache日志,如何从日志数据生成统计报表等内容。    如 果Apache的安装方式是默认安装,服务器一运行就会有两个日志文件生成。这两个文件是access_log和error_log(在Win上是 access.log和error.log)。采用默认安装方式时,这些文件可以在/usr/local/apache/logs下找到;对于 Windows系统,这些日志文件将保存在Apache安装目录的logs子目录。不同的包管理器会把日志文件放到各种不同的位置,所以你可能需要找找其 他的地方,或者通过配置文件查看这些日志文件配置到了什么地方。  【总结】访问日志和错误日志的 位置 和 名字 :  Windows: <Apache安装目录>\logs\access.log | error.log  Linux:  /usr/local/apache/logs/access_log | error_log  正如其名字所示,访问日志access_log记录了所有对Web服务器的访问活动。下面是访问日志中一个典型的记录:    例子:216.35.116.91 - - [19/Aug/2000:14:47:37 -0400] "GET / HTTP/1.0" 200 654   【总结】:日志名字段所代表的内容:   1.远程主机、2.空白(E-mail)、3.空白(登录名)、4.请求时间、5.方法+资源+协议、6.状态代码、7.发送字节数   这行内容由7项构成,上面的例子中有两项空白,但整行内容仍旧分成了7项。    第 一项信息是远程主机的地址,即它表明访问网站的究竟是谁。在上面的例子中,访问网站的主机是216.35.116.91。随便说一句,这个地址属于一台名 为si3001.inktomi.com的机器(要找出这个信息,可以使用nslookup工具查找DNS),inktomi.com是一家制作Web搜 索软件的公司。可以看出,仅仅从日志记录的第一项出发,我们就可以得到有关访问者的不少信息。    默认情况下,第一项信息只是远程主机的 IP地址,但我们可以要求Apache查出所有的主机名字,并在日志文件中用主机名字来替代IP地址。然而,这种做法通常不值得推荐,因为它将极大地影响 服务器记录日志的速度,从而也就减低了整个网站的效率。另外,有许多工具能够将日志文件中的IP地址转换成主机名字,因此要求Apache记录主机名字替 代IP地址是得不偿失的。    然而,如果确实有必要让Apache找出远程主机的名字,那么我们可以使用指令“HostNameLookups on”。  如果HostNameLookups设置成double而不是on,日志记录程序将对它找到的主机名字进行反向查找,验证该主机名字确实指向了原来出现的IP地址。默认情况下HostNameLookups设置为off。     上 例日志记录中的第二项是空白,用一个“-”占位符替代。实际上绝大多数时候这一项都是如此。这个位置用于记录浏览者的标识,这不只是浏览者的登录名字,而 是浏览者的email地址或者其他唯一标识符。 这个信息由identd返回,或者直接由浏览器返回。很早的时候,那时Netscape 0.9还占据着统治地位,这个位置往往记录着浏览者的email 地址。然而,由于有人用它来收集邮件地址和发送垃圾邮件,所以它未能保留多久,很久之前市场上几乎所有的浏览器就取消了这项功能。因此,到了今天,我们在 日志记录的第二项看到email地址的机会已经微乎其微了。     日志记录的第三项也是空白。这个位置用于记录浏览者进行身份验证时提供的名字。当然,如果网站的某些内容要求用户进行身份验证,那么这项信息是不会空白的。但是,对于大多数网站来说,日志文件的大多数记录中这一项仍旧是空白的。     日 志记录的第四项是请求的时间。这个信息用方括号包围,而且采用所谓的“公共日志格式”或“标准英文格式”。因此,上例日志记录表示请求的时间是2000年 8月19日星期三14:47:37。时间信息最后的“-0400”表示服务器所处时区位于UTC之前的4小时。     日志记录的第五项信息或许是整个日志记录中最有用的信息,它告诉我们服务器收到的是一个什么样的请求。该项信息的典型格式是“METHOD RESOURCE PROTOCOL”,即“方法 资源 协议”。   【总结】   METHOD: GET、POST、HEAD、……   RESOURCE: /、index.html、/default/index.php、……(请求的文件)   PROTOCOL: HTTP+版本号   在上例中,METHOD是GET,其他经常可能出现的METHOD还有POST和HEAD。此外还有不少可能出现的合法METHOD,但主要就是这三种。    RESOURCE是指浏览者向服务器请求的文档,或URL。在这个例子中,浏览者请求的是“/”,即网站的主页或根。大多数情况下,“/”指向DocumentRoot目录的index.html文档,但根据服务器配置的不同它也可能指向其他文件。    PROTOCOL 通常是HTTP,后面再加上版本号。版本号或者是1.0,或者是1.1,但出现1.0的时候比较多。我们知道,HTTP协议是Web得以工作的基 础,HTTP/1.0是HTTP协议的早期版本,而1.1是最近的版本。当前大多数Web客户程序仍使用1.0版本的HTTP协议。     日志记录的第六项信息是状态代码。它告诉我们请求是否成功,或者遇到了什么样的错误。大多数时候,这项值是200,它表示服务器已经成功地响应浏览器的请求,一切正常。状态代码的完整清单可以参考维基百科中的HTTP状态码。一般地说,以2开头的状态代码表示成功,以3开头的状态代码表示由于各种不同的原因用户请求被重定向到了其他位置,以4开头的状态代码表示客户端存在某种错误,以5开头的状态代码表示服务器遇到了某个错误。     日志记录的第七项表示发送给客户端的总字节数。它告诉我们传输是否被打断(即,该数值是否和文件的大小相同)。把日志记录中的这些值加起来就可以得知服务器在一天、一周或者一月内发送了多少数据。 二、配置访问日志    访问日志文件的位置实际上是一个配置选项。如果我们检查httpd.conf配置文件,可以看到该文件中有如下这行内容:           CustomLog /usr /local/apache/logs/access_log common   注意,对于版本较早的Apache服务器,这行内容可能略有不同。它使 用的可能不是CustomLog指令,而是TransferLog指令。如果你的服务器属于这类情况,建议你尽可能地早日升级服务器。    CustomLog 指令指定了保存日志文件的具体位置以及日志的格式。上面这行指令指定的是common日志格式,自从有了Web服务器开始,common格式就是它的标准 格式。由此我们也可以理解,虽然几乎不再有任何客户程序向服务器提供用户的标识信息,但访问日志却还保留着第二项内容。   CustomLog指令中的路径是日志文件的路径,由于日志文件是由HTTP用户打开的(用User指令指定),因此必须注意这个路径要有安全保证,防止该文件被随意改写。      Apche日志系列(2):错误日志   错误日志和访问日志一样也是Apache的标准日志。本文分析错误日志的内容,介绍如何设置和错误日志相关的选项,文档错误和CGI错误的分类,以及如何方便地查看日志内容,等等。  一、文件名和位置   错 误日志无论在格式上还是在内容上都和访问日志不同。然而,错误日志和访问日志一样也提供丰富的信息,我们可以利用这些信息分析服务器的运行情况、哪里出现 了问题。    错误日志的文件名字是error_log(Windows平台是error.log)。错误日志的位置可以通过ErrorLog指令设 置:           ErrorLog logs/error.log   除非文件位置用“/”开头,否则这个文件位置是相对于ServerRoot目录的相对路径。 如果Apache采用默认安装方式安装,那么错误日志的位置应该在/usr/local/apache/logs下。但是,如果Apache用某种包管理 器安装,错误日志很可能在其他位置。    正如其名字所示,错误日志记录了服务器运行期间遇到的各种错误,以及一些普通的诊断信息,比如服务器何时启 动、何时关闭等。    我们可以设置日志文件记录信息级别的高低,控制日志文件记录信息的数量和类型。这是通过LogLevel指令设置的,该指令默认设置的级别是error,即记录称得上错误的事件。有关该指令中允许设置的各种选项的完整清单,请参见http://www.apache.org/docs/mod/core.html#loglevel的Apache文档。    大多数情况下,我们在日志文件中见到的内容分属两类:文档错误和CGI错误。但是,错误日志中偶尔也会出现配置错误,另外还有前面提到的服务器启动和关闭信息。   二、文档错误    文档错误和服务器应答中的400系列代码相对应,最常见的就是404错误——Document Not Found(文档没有找到)。除了404错误以外,用户身份验证错误也是一种常见的错误。    404错误在用户请求的资源(即URL)不存在时出现,它可能是由于用户输入的URL错误,或者由于服务器上原来存在的文档因故被删除或移动。     顺便说一下,按照Jakob Nielson的意见,在不提供重定向或者其他补救措施的情况下,我们永远不应该移动或者删除Web网站的任何资源。Nielson的更多文章,请参见http://www.zdnet.com/devhead/alertbox/。    当用户不能打开服务器上的文档时,错误日志中出现的记录如下所示:      [Fri Aug 18 22:36:26 2000] [error] [client 192.168.1.6] File does not exist:  /usr/local/apache/bugletdocs/Img/south-korea.gif     【说明】1.日期和时间、2.记录等级、3.客户IP、4.错误信息。  可以看到,正如访问日志access_log文件一样,错误日志记录也分成多个项。    错误记录的开头是日期/时间标记,注意它们的格式和access_log中日期/时间的格式不同。access_log中的格式被称为“标准英文格式”,这或许是历史跟我们开的一个玩笑,但现在要改变它已经太迟了。     错 误记录的第二项是当前记录的级别,它表明了问题的严重程度。这个级别信息可能是LogLevel指令的文档中所列出的任一级别(参见前面LogLevel 的链接),error级别处于warn级别和crit级别之间。404属于error错误级别,这个级别表示确实遇到了问题,但服务器还可以运行。     错误记录的第三项表示用户发出请求时所用的IP地址。     记 录的最后一项才是真正的错误信息。 对于404错误,它还给出了完整路径指示服务器试图访问的文件。当我们料想某个文件应该在目标位置却出现了404错误时,这个信息是非常有用的。此时产生 这种错误的原因往往是由于服务器配置错误、文件实际所处的虚拟主机和我们料想的不同,或者其他一些意料不到的情况。     由于用户身份验证问题而出现的错误记录如下所示:    [Tue Apr 11 22:13:21 2000] [error] [client 192.168.1.3] user rbowen@rcbowen.com : authentication failure for "/cgi- bin/hirecareers/company.cgi" : password mismatch   注意,由于文档错误是用户请求的直接结果,因此它们在访问日志中也会有相应的记录。  三、CGI错误   错 误日志最主要的用途或许是诊断行为异常的CGI程序。为了进一步分析和处理方便,CGI程序输出到STDERR(Standard Error,标准错误 设备)的所有内容都将直接进入错误日志。这意味着,任何编写良好的CGI程序,如果出现了问题,错误日志就会告诉我们有关问题的详细信息。    然而,把CGI程序错误输出到错误日志也有它的缺点,错误日志中将出现许多没有标准格式的内容,这使得用错误日志自动分析程序从中分析出有用的信息变得相当困难。    下面是一个例子,它是调试Perl CGI代码时,错误日志中出现的一个错误记录:    [Wed Jun 14 16:16:37 2000] [error] [client 192.168.1.3] Premature    end of script headers: /usr/local/apache/cgi-bin/HyperCalPro/announcement.cgi   Global symbol "$rv" requires explicit package name at    /usr/local/apache/cgi-bin/HyperCalPro/announcement.cgi line 81.   Global symbol "%details" requires explicit package name at    /usr/local/apache/cgi-bin/HyperCalPro/announcement.cgi line 84.   Global symbol "$Config" requires explicit package name at    /usr/local/apache/cgi-bin/HyperCalPro/announcement.cgi line 133.   Execution of /usr/local/apache/cgi-bin/HyperCalPro/announcement.cgi    aborted due to compilation errors.   可以看到,CGI错误和前面的404错误格式相同,包含日期/时间、错误级别以及客户地址、错误信息。但这个CGI错误的错误信息有好几行,这往往会干扰一些错误日志分析软件的工作。    有了这个错误信息,即使是对Perl不太熟悉的人也能够找出许多有关错误的信息,例如至少可以方便地得知是哪几行代码出现了问题。Perl在报告程序错误方面的机制是相当完善的。当然,不同的编程语言输出到错误日志的信息会有所不同。     由于CGI程序运行环境的特殊性,如果没有错误日志的帮助,大多数CGI程序的错误都将很难解决。     有 不少人在邮件列表或者新闻组中抱怨说自己有一个CGI程序,当打开网页时服务器却返回错误,比如“Internal Server Error”。我们可 以肯定,这些人还没有看过服务器的错误日志,或者根本不知道错误日志的存在。决多大多数情况下,错误日志能够精确地指出CGI错误的所在以及如何修正这个 错误。   四、查看日志文件   我常常告诉别人说,在进行开发的同时我会不断地检查服务器的日志,以便能够立即知道哪儿出了问题。但我得到的回答却往往是沉默。起先我以为这种沉默意味着“你当然得这样做”,后来我才发现这种沉默的真正含义是“我不知道别人的做法,但我自己是不干的。”    虽然如此,下面我们还是要看看如何方便地查看服务器日志文件。用telnet连接到服务器,然后输入下面的命令:      tail -f /usr/local/apache/logs/error_log  //动态显示文件后几行内容    【补充】tail命令是用来显示linux系统的文本文件的最后几行的工具。和head命令正好相反。  该命令将显示出日志文件的最后几行内容,如果有新的内容加入到日志文件,它还会立即显示出新加入的内容。    Windows用户也同样可以使用这种方法,比如可以使用各种为Windows提供的Unix工具软件包。我个人爱好一个称为AINTX的工具,它可以在http://maxx.mc.net/~jlh/nttools/index.htm找到。    还有一种替代方法是使用下面的Perl代码,它利用了一个称为File::Tail的模块:     use File::Tail;    $file=File::Tail->new("/some/log/file");    while (defined($line=$file->read)) {      print "$line";    }   无论具体采用的是哪一种方法,同时打开多个终端窗口都是一种好习惯:比如在一个窗口中显示错误日志,在另一个窗口中显示访问日志。这样,我们就能够随时获知网站上发生的事情并立即予以解决。   Apche日志系列(3):定制日志  有时候我们需要定制Apache默认日志的格式和内容,比如增加或减少日志所记录的信息、改变默认日志文件的格式等。本文介绍可以用日志记录的所有信息,以及如何设置Apache使其记录这些信息。   一、定义日志格式    很 久以前,日志文件只有一种格式,这就是“公共格式”,许多人已经习惯于使用这种格式。随后出现了定制日志格式,而且看起来定制日志格式更很受欢迎,即使公 共日志格式本身也重新用定制日志格式定义。本文介绍的就是如何随心所欲地定制日志文件的格式、如何让日志文件记录自己想要的信息。    定制日志文件的格式涉及到两个指令,即LogFormat指令和CustomLog指令。默认httpd.conf文件提供了关于这两个指令的几个示例。    LogFormat指令:定义格式并为格式指定一个名字,以后我们就可以直接引用这个名字。  CustomLog指令:设置日志文件,并指明日志文件所用的格式(通常通过格式的名字)。     LogFormat指令的功能是定义日志格式并为它指定一个名字。例如,在默认的httpd.conf文件中,我们可以找到下面这行代码:      LogFormat "%h %l %u %t \"%r\" %>s %b" common    该指令创建了一种名为“common”的日志格式,日志的格式在双引号包围的内容中指定。格式字符串中的每一个变量代表着一项特定的信息,这些信息按照格式串规定的次序写入到日志文件。   Apache文档已经给出了所有可用于格式串的变量及其含义,下面是其译文:       %a: 远程IP地址       %A: 本地IP地址       %B: 已发送的字节数,不包含HTTP头       %b: CLF格式的已发送字节数量,不包含HTTP头。例如当没有发送数据时,写入‘-’而不是0。        %{FOOBAR}e: 环境变量FOOBAR的内容        %f: 文件名字        %h: 远程主机        %H 请求的协议        %Foobar}i: Foobar的内容,发送给服务器的请求的标头行。        %l: 远程登录名字(来自identd,如提供的话)        %m: 请求的方法        %{Foobar}n: 来自另外一个模块的注解“Foobar”的内容        %{Foobar}o: Foobar的内容,应答的标头行        %p: 服务器响应请求时使用的端口        %P: 响应请求的子进程ID。        %q: 查询字符串(如果存在查询字符串,则包含“?”后面的部分;否则,它是一个空字符串。)        %r: 请求的第一行        %s: 状态。对于进行内部重定向的请求,这是指*原来*请求的状态。如果用%...>s,则是指后来的请求。        %t: 以公共日志时间格式表示的时间(或称为标准英文格式)       %{format}t: 以指定格式format表示的时间        %T: 为响应请求而耗费的时间,以秒计        %u: 远程用户(来自auth;如果返回状态(%s)是401则可能是伪造的)        %U: 用户所请求的URL路径        %v: 响应请求的服务器的ServerName        %V: 依照UseCanonicalName设置得到的服务器名字    分 析前面来自默认httpd.conf文件的LogFormat指令示例,可以看出它创建了一种名为“common”的日志格式,其中包括:远程主机,远程 登录名字,远程用户,请求时间,请求的第一行代码,请求状态,以及发送的字节数。      LogFormat " %V %h %l %u %t \"%r\" %>s %b" common    【补充】"<"和">"修饰符可以用来指定对于已被内部重定向的请求是选择原始的请求还是选择最终的请求。默认情况下,%s, %U, %T, %D, %r 使用原始请求,而所有其他格式串则选择最终请求。例如,%>s 可以用于记录请求的最终状态,而 %<u 则记录一个已经被内部重定向到非认证资源的请求的原始认证用户。  如果在“%”和变量之间放入了一个或者多个HTTP状态代码,则只有当请求返回的状态代码属于指定的状态代码之一时,变量所代表的内容才会被记录。例如,如果我们想要记录的是网站的所有无效链接,那么可以使用:       LogFormat %404{Referer}i BrokenLinks    反之,如果我们想要记录那些状态代码不等于指定值的请求,只需加入一个“!”符号即可:    LogFormat %!200U SomethingWrong   Apche日志系列(4):日志分析   尽管日志文件中包含着大量有用的信息,但这些信息只有在经过深入挖掘之后才能够最大限度地发挥作用。本文首先讨论了能够从日志文件获得的信息以及不能从日志文件获得的信息,然后介绍了几种优秀的日志分析工具以及如何自己编程分析日志文件。 一、可以得到哪些信息(4月4日)   虽 然日志文件中包含了大量的信息,但这些信息对于我们管理、规划网站却没有多少直接的帮助。为了管理和规划网站,我们需要知道:有多少人浏览了网站,他们在 看些什么,停留了多长时间,他们从哪里得知这个网站,等等。所有这些信息就隐藏于(或者可能隐藏于)日志文件之中。    就网站的经营者而 言, 他们还希望知道浏览者的姓名、地址、鞋子大小,甚至还有浏览者的信用卡号码,但这些信息都不可能从日志文件中得到。为此,作为技术人员的我们就必须知道如 何向这些经营者解释清楚:这部分信息不仅不可能从日志文件获得,而且要获得这些信息的唯一方法是直接向浏览者本人询问,并作好被拒绝的准备。     有许多信息可以用日志文件来记录,其中包括:    1.远程机器的地址:“远程机器的地址”和“谁在浏览网站”差不多,但并不等同。具体地说,远程机器的地址告诉我们浏览者来自何方,比如它可能是buglet.rcbowen.com或者proxy01.aol.com。    2. 浏览时间:浏 览者何时开始访问网站?从这个问题的答案中我们能够了解不少情况。如果网站的大多数浏览者都在早上9:00和下午4:00之间访问网站,那么可以相信网站 的浏览者大多数总在工作时间进行访问;如果访问记录大多出现在下午7:00到午夜之间,我们可以肯定浏览者一般在家里上网。 当然,从单个访问记录能够得 到的信息非常有限,但如果从数千个访问记录出发,我们就可以得到非常有用和重要的统计信息。    3.用户所访问的资源:网 站的哪些部分最受用户欢迎?这些最受欢迎的部分就是我们应该继续加以发展的部分。网站的哪些部分总是受到冷落?网站中这些受到冷落的部分或许隐藏得太深, 或许它们确实没有什么意思,此时我们就得想办法加以改进。当然,网站还有的内容,比如法律上的声明,虽然很少有人访问,但却不应该随便地改动它们。    4. 无效链接:当 然,日志文件还能够告诉我们哪些东西不能按照我们所想象地运行。网站中是否存在错误的链接?其他网站链接过来时有没有搞错URL?是否存在不能正常运行的 CGI程序?是否有搜索引擎检索程序每秒发出数千个请求,从而影响了本网站的正常服务?这些问题的答案都可以从日志文件找到线索。  Apche日志系列(5):其他用法   这篇讨论三个问题:1.如何将日志记录写入指定的程序而不是日志文件,2.如何轮换日志防止磁盘空间不足,3.多虚拟主机环境下的日志文件管理。  一、把日志记录写入到指定程序   日 志记录并非只能写入到文件,它还可以写入到指定的进程。当我们想要把日志信息写入数据库、或者是某些能够实时显示网站流量统计信息的程序时,这一点是非常 有用的。    那么,如何实现这一点呢?使用TransferLog或者CustomLog指令,我们能够指定“|”,后面再加上接收日志信息的程序名 字。例如:          CustomLog | /usr/bin/apachelog.pl common   其中/usr /bin/apachelog.pl是一个程序, 这个程序知道如何处理Apache日志文件的记录。事实上,这个程序非常简单,比如它可以是一个按照某种方式处理日志记录的Perl程序,或者是一个将日 志记录写入数据库的程序。    在采用这种记录日志数据的方法时,安全问题是最必须关注的问题。日志文件是以启动服务器的用户所具有的权限打开的,通常 是root。对于将日志记录写入数据库的程序,这一点也同样有效,所以应当确保用于记录日志数据的程序具有充分的安全保证。    如果日志数 据 通过一个不安全的程序记录(这个程序可能被非root用户侵入和修改),那么系统就面临着日志记录程序被其他怀有恶意的程序替换的危险。例如,如果 /usr/bin/apachelog.pl可被全世界的用户修改,那么任何用户都将能够编辑这个文件关闭Web服务器,把密码文件发送到某个信箱,或者 删除某些重要的文件,因为root用户具有进行所有这些操作的权限。    如果你要把日志记录写入到某个程序,建议先找找是否有现成的具备自己想要功能的模块。请访问http://modules.apache.org/,该网站收集了许多面向Apache完成各类实际任务的模块。  二、轮换日志   日志文件会越来越大,如果不小心把日志文件放到了/var之类位置,日志文件可能写满分区,从而导致服务器被迫停止运行。这种事情确实曾经发生过。    防 止出现这种问题的办法是,在日志文件变得太大之前把它们移到其他具有足够空间的位置。这可以通过几种方法实现。某些Unix变种提供一个 logrotate脚本,它能够帮助我们完成这个任务。例如RedHat就已经预先配置,它会根据日志文件的大小或者日志文件的使用时间,每隔几日轮换日 志文件。    如果要自己实现这方面的功能,我们可以使用称为Logfile::Rotate的Perl模块(可从CPAN下载)。下面的代码就具有这种功能,它由cron按照一定的间隔周期(比如一星期)运行,为了节省空间。每一个备份的日志文件都经过压缩。     use Logfile::Rotate;    $logfile = new Logfile::Rotate(     File => &single;/usr/local/apache/logs/access_log&single;,     Count => 5,     Gzip => &single;/bin/gzip&single;,     Signal => sub {      `/usr/local/apache/bin/apachectl restart`;     }     );   代码不多,Perl模块Logfile::Rotate负责了所有具体操作任务。运行这个程序,我们将得到名为access_log.1.gz、 access_log.2.gz等的文件。它可以帮助我们避免磁盘空间的不足,使得我们能够保存任意多的档案文件。   三、多个虚拟主机的日志   曾经有好几个人问起,当同一台机器上运行着多个虚拟主机时应该如何分析日志?我想,他们是先把所有虚拟主机的日志记录都保存到了同一台机器,然后又企图把这个日志文件按照虚拟主机的不同分割成多个部分。    彻 底解决这个问题的方法是一开始就不要把所有虚拟主机的日志记录都写入到同一个文件。虽然我知道确实存在这样的工具,它们能够把多个虚拟主机混合的日志记录 根据虚拟主机配置分开,指出哪些请求针对哪个虚拟主机发出,然后分别生成报表。然而,这种方法看起来实在是太麻烦了。  为每一个虚拟主机分别指定日志文件时,我们只需在每个VirtualHost区域指定该主机的日志文件。此后,当需要制作报表时,我们就可以分别地处理各个日志文件。    但 这里必须注意一下可用文件句柄的问题。也就是说,如果某台服务器上运行的虚拟主机多达数百个,每个虚拟主机都有单独的日志文件,系统可能会出现可用文件句 柄不足的问题,它可能导致系统不稳定甚至导致系统崩溃。然而,只有当服务器上运行的虚拟主机数量非常庞大时,我们才有关注这个问题的必要。  ... 全文

Linux Apache web log

开启Apache中的Server Status

apache server-status介绍我们平时使用apache常常了解他的性能只能使用ps aux|grep httpd|wc -l查看有多少个进程,但处理了多少http的请求我们不清楚,进程是不是在工作,还是在等都不是很明白,要了解apache的性能,我们需要使用 Apache Server Status的模块来详细了解apache工作的怎么样。打开Apache Server Status 如果你的Apache配置文件httpd.conf或者extra/httpd-info.conf中有LoadModule status_module modules/mod_status.so话,说明你的Apache已经加载了此模块;或者编译的时候加上了–enable-module=so也表明服务器支持server-status。你可以用以下命令查看是否已经加载了模块: # /usr/local/apache/bin/httpd -l | grep mod_status.c 如果没有安装这个模块,那么就需要您重新编译这个模块了,进入 apache 的源码目录:# cd /usr/local/src/httpd-2.2.14/modules/generators # /usr/local/apache/bin/apxs -cia mod_status.c 这样模块就编译好了。你查看一下 apache 的配置文件里已经增加了LoadModule status_module modules/mod_status.so启动 server-status 功能,在 apache 的配置文件中增加一下配置代码: ExtendedStatus On <Location /server-status> SetHandler server-status Order Deny,Allow Deny from all Allow from IP </Location> 打开查看的话就使用http://IP/server-status来访问,如果需要自动更新,可以用http://IP/server-status?refresh=N,N是更新时间,默认是秒。下面是我的服务器的server-status显示:Apache Server Status for xxx.xxx.xxx.xxx Server Version: Apache/2.2.14 (Unix) PHP/4.4.9 Server Built: May 31 2010 10:31:44Current Time: Thursday, 16-Sep-2010 15:57:34 CST Restart Time: Monday, 13-Sep-2010 09:17:00 CST Parent Server Generation: 5 Server uptime: 3 days 6 hours 40 minutes 33 seconds Total accesses: 3303 - Total Traffic: 12.5 MB CPU Usage: u.53 s.17 cu0 cs0 - .000247% CPU load .0117 requests/sec - 46 B/second - 3958 B/request 1 requests currently being processed, 5 idle workers __W___.......................................................... ................................................................ ................................................................ ................................................................Scoreboard Key: "_" Waiting for Connection, "S" Starting up, "R" Reading Request, "W" Sending Reply, "K" Keepalive (read), "D" DNS Lookup, "C" Closing connection, "L" Logging, "G" Gracefully finishing, "I" Idle cleanup of worker, "." Open slot with no current processSrv PID Acc M CPU SS Req Conn Child Slot Client VHost Request 0-5 16798 0/552/552 W 0.12 0 0 0.0 2.08 2.08 xxx.xxx.xxx.xxx localhost.localdomain GET /status HTTP/1.1 1-5 16799 0/551/551 _ 0.12 16347 0 0.0 2.08 2.08 xxx.xxx.xxx.xxx localhost.localdomain GET /status?refresh=5 HTTP/1.1 2-5 16800 0/551/551 _ 0.11 15680 0 0.0 2.08 2.08 xxx.xxx.xxx.xxx localhost.localdomain GET /status HTTP/1.1 3-5 16801 0/566/566 _ 1.14 11517 0 0.0 2.10 2.10 xxx.xxx.xxx.xxx localhost.localdomain GET /awstatsicons/browser/firefox.png HTTP/1.1 4-5 16802 0/563/563 _ 0.65 11517 0 0.0 2.15 2.15 xxx.xxx.xxx.xxx localhost.localdomain GET /awstatsicons/browser/msie.png HTTP/1.1 5-5 16803 0/560/560 _ 0.13 11517 0 0.0 2.08 2.08 xxx.xxx.xxx.xxx localhost.localdomain GET /awstatsicons/os/linux.png HTTP/1.1 Srv Child Server number - generation PID OS process ID Acc Number of accesses this connection / this child / this slot M Mode of operation CPU CPU usage, number of seconds SS Seconds since beginning of most recent request Req Milliseconds required to process most recent request Conn Kilobytes transferred this connection Child Megabytes transferred this child Slot Total megabytes transferred this slot server-status 的输出中每个字段所代表的意义如下:字段 说明Server Version Apache 服务器的版本。Server Built Apache 服务器编译安装的时间。Current Time 目前的系统时间。Restart Time Apache 重新启动的时间。Parent Server Generation Apache 父程序 (parent process) 的世代编号,就是 httpd 接收到 SIGHUP 而重新启动的次数。Server uptime Apache 启动后到现在经过的时间。Total accesses 到目前为此 Apache 接收的联机数量及传输的数据量。CPU Usage 目前 CPU 的使用情形。_SWSS…. 所有 Apache process 目前的状态。每一个字符表示一个程序,最多可以显示 256 个程序的状态。Scoreboard Key 上述状态的说明。以下为每一个字符符号所表示的意义: * _:等待连结中。 * S:启动中。 * R: 正在读取要求。 * W:正在送出回应。 * K:处于保持联机的状态。 * D:正在查找 DNS。 * C:正在关闭连结。 * L:正在写入记录文件。 * G:进入正常结束程序中。 * I:处理闲置。 * .:尚无此程序。Srv 本程序与其父程序的世代编号。PID 本程序的 process id。Acc 分别表示本次联机、本程序所处理的存取次数。M 该程序目前的状态。CPU 该程序所耗用的 CPU 资源。SS 距离上次处理要求的时间。Req 最后一次处理要求所耗费的时间,以千分之一秒为单位。Conn 本次联机所传送的数据量。Child 由该子程序所传送的数据量。Slot 由该 Slot 所传送的数据量。Client 客户端的地址。VHost 属于哪一个虚拟主机或本主机的 IP。Request 联机所提出的要求信息。不错吧,挺直观的吧。本文转载自 http://7056824.blog.51cto.com/69854/392839... 全文

Apache Server Status

apache 对php的支持

原本lamp的环境是完好, 应为又重新编译了一次apache,(我是把原里的apache目录移除了)导致apache的php的支持,方法1、重新编译php方法   2、把原来apache目录下module/libphp5.so 复制到现在编译好的apache目录让后修改apache的配置文件vim  httpd.conf添加:LoadModule php5_module        modules/libphp5.so           AddType application/x-httpd-php .php... 全文

apache 对php的支持

apache负载均衡的实现

1、查看是否有mod_proxy_http.so、mod_proxy_balancer.so、mod_proxy.so三个模块# ll /usr/local/apache2/modules2、加载模块# cd /usr/local/src/httpd-2.2.23/modules/proxy/# /usr/local/apache2/bin/apxs -c -i mod_proxy.c proxy_util.c# /usr/local/apache2/bin/apxs -c -i mod_proxy_balancer.c... 全文

apache mod_proxy

apache查看加载的模块

 httpd -t -D DUMP_MODULES  Loaded Modules:  core_module (static)  mpm_prefork_module (static)  http_module (static)  so_module (static)  auth_basic_module (shared)  auth_digest_module (shared)  authn_file_module (shared)  authn_alias_module (shared)  authn_anon_module (shared)  authn_dbm_module (shared)  authn_default_module (shared)  authz_host_module (shared)  authz_user_module (shared)  authz_owner_module (shared)  authz_groupfile_module (shared)  authz_dbm_module (shared)  authz_default_module (shared)  ldap_module (shared)  authnz_ldap_module (shared)  include_module (shared)  log_config_module (shared)  logio_module (shared)  env_module (shared)  ext_filter_module (shared)  mime_magic_module (shared)  expires_module (shared)  deflate_module (shared)  headers_module (shared)  usertrack_module (shared)  setenvif_module (shared)  mime_module (shared)  dav_module (shared)  status_module (shared)  autoindex_module (shared)  info_module (shared)  dav_fs_module (shared)  vhost_alias_module (shared)  negotiation_module (shared)  dir_module (shared)  actions_module (shared)  speling_module (shared)  userdir_module (shared)  alias_module (shared)  rewrite_module (shared)  proxy_module (shared)  proxy_balancer_module (shared) 本方法我在真实机器上可以成功,但是通过ssh连接到服务器上只显示... 全文

shared apache 模块

apache日志文件太大的问题

管理apache服务器有些年头,虽然最近几年被nginx抢了不少风头,但我依然钟爱apache。 喜欢它强劲的并发处理能力,以及forker与worker模式间自由选择的快感,哈哈。... 全文

apache 日志

转 Apache文档

提到了awstats来分析日志,那么有关apache日志的知识是必须要了解的.现在我就将apache文档的相关部分列出来,以供参考日志文件要有效地管理Web服务器,就有必要反馈服务器的活动、性能以及出现的问题。Apache HTTP服务器提供了非常全面而灵活的日志记录功能。本文将阐述如何配置文件以及如何理解日志内容。安全警告任何人只要对Apache存放日志文件的目录具有写权限,也就当然地可以获得启动Apache的用户(通常是root)的权限,绝对不要随意给予任何人存放日志文件目录的写权限。细节请参见安全方面的提示。另外,日志文件可能会包含未加转换的来自用户的信息,用户就有机会恶意插入控制符,所以处理原始日志时应该当心这个问题。错误日志(Error Log) 相关模块 相关指令 ErrorLogLogLevel错误日志是最重要的日志文件,其文件名和位置取决于ErrorLog指令。Apache httpd将在这个文件中存放诊断信息和处理请求中出现的错误,由于这里经常包含了出错细节以及如何解决,如果服务器启动或运行中有问题,首先就应该查看这个错误日志。错误日志通常被写入一个文件(unix系统上一般是error_log ,Windows和OS/2上一般是error.log)。在unix系统中,错误日志还可能被重定向到syslog或通过管道操作传递给一个程序。错误日志的格式相对灵活,并可以附加文字描述。某些信息会出现在绝大多数记录中,一个典型的例子是:[Wed Oct 11 14:32:52 2000] [error] [client 127.0.0.1] client denied by server configuration: /export/home/live/ap/htdocs/test 其中,第一项是错误发生的日期和时间;第二项是错误的严重性,LogLevel指令使只有高于指定严重性级别的错误才会被记录;第三项是导致错误的IP地址;此后是信息本身,在此例中,服务器拒绝了这个客户的访问。服务器在记录被访问文件时,用的是文件系统路径,而不是Web路径。错误日志中会包含类似上述例子的多种类型的信息。此外,CGI脚本中任何输出到stderr的信息会作为调试信息原封不动地记录到错误日志中。用户可以增加或删除错误日志的项。但是对某些特殊请求,在访问日志(access log)中也会有相应的记录,比如上述例子在访问日志中也会有相应的记录,其状态码是403,因为访问日志也可以定制,所以可以从访问日志中得到错误事件的更多信息。在测试中,对任何问题持续监视错误日志是非常有用的。在unix系统中,可以这样做:tail -f error_log 访问日志(Access Log) 相关模块 相关指令 mod_log_configmod_setenvifCustomLogLogFormatSetEnvIf访问日志中会记录服务器所处理的所有请求,其文件名和位置取决于CustomLog指令,LogFormat指令可以简化日志的内容。这里阐述如何配置服务器的访问日志。实施日志管理,首先当然必须产生访问日志,然后才能分析日志从而得到有用的统计信息。日志分析不是Web服务器的职责,已超出本文的范畴,更多资料和有关分析工具的信息,可以查看Open DirectoryYahoo 。不同版本的Apache httpd使用了不同的模块和指令来控制对访问的记录,包括mod_log_referer, mod_log_agent和TransferLog指令。现在,CustomLog指令包含了旧版本中相关指令的所有功能。访问日志的格式是高度灵活的,使用很象C风格的printf()函数的格式字符串。下面有几个例子,完整的说明可以查看用于mod_log_config模块的格式字符串通用日志格式(Common Log Format)这是一个典型的记录格式:LogFormat "%h %l %u %t \"%r\" %>s %b" commonCustomLog logs/access_log common 它定义了一种特定的记录格式字符串,并给它起了个别名叫common ,其中的"%"指示服务器用某种信息替换,其他字符则不作替换。引号(")必须加反斜杠转义,以避免被解释为字符串的结束。格式字符串还可以包含特殊的控制符,如换行符"\n" 、制表符"\t"。CustomLog指令建立一个使用指定别名的新日志文件,除非其文件名是以斜杠开头的绝对路径,否则其路径就是相对于ServerRoot的相对路径。上述配置是一种被称为通用日志格式(CLF)的记录格式,它被许多不同的Web服务器所采用,并被许多日志分析程序所识别,它产生的记录形如:127.0.0.1 - frank [10/Oct/2000:13:55:36 -0700] "GET /apache_pb.gif HTTP/1.0" 200 2326 记录的各部分说明如下: 127.0.0.1 (%h) 这是发送请求到服务器的客户的IP地址。如果HostnameLookups设为 On ,则服务器会尝试解析这个IP地址的主机名并替换此处的IP地址,但并不推荐这样做,因为它会显著拖慢服务器,最好是用一个日志后续处理器来判断主机名,比如logresolve 。如果客户和服务器之间存在代理,那么记录中的这个IP地址就是那个代理的IP地址,而不是客户机的真实IP地址。 - (%l) 这是由客户端identd进程判断的RFC1413身份(identity),输出中的符号"-"表示此处的信息无效。除非在严格控制的内部网络中,此信息通常很不可靠,不应该被使用。只有在将IdentityCheck指令设为 On 时,Apache才会试图得到这项信息。 frank (%u) 这是HTTP认证系统得到的访问该网页的客户标识(userid),环境变量REMOTE_USER会被设为该值并提供给CGI脚本。如果状态码是401,表示客户未通过认证,则此值没有意义。如果网页没有设置密码保护,则此项将是"-"。 [10/Oct/2000:13:55:36 -0700] (%t) 这是服务器完成请求处理时的时间,其格式是: [日/月/年:时:分:秒 时区]日 = 2数字月 = 3字母年 = 4数字时 = 2数字分 = 2数字秒 = 2数字时区 = (+|-)4数字 可以在格式字符串中使用 %{format}t 来改变时间的输出形式,其中的format与C标准库中的strftime()用法相同。 "GET /apache_pb.gif HTTP/1.0" (\"%r\") 引号中是客户端发出的包含许多有用信息的请求行。可以看出,该客户的动作是GET ,请求的资源是/apache_pb.gif ,使用的协议是HTTP/1.0 。另外,还可以记录其他信息,如:格式字符串"%m %U%q %H"会记录动作、路径、查询字符串、协议,其输出和"%r"一样。 200 (%>s) 这是服务器返回给客户端的状态码。这个信息非常有价值,因为它指示了请求的结果,或者是被成功响应了(以2开头),或者被重定向了(以3开头),或者出错了(以4开头),或者产生了服务器端错误(以5开头)。完整的状态码列表参见HTTP规范(RFC2616第10章)。 2326 (%b) 最后这项是返回给客户端的不包括响应头的字节数。如果没有信息返回,则此项应该是"-",如果希望记录为"0"的形式,就应该用%B 。 组合日志格式(Combined Log Format)另一种常用的记录格式是组合日志格式,形式如下:LogFormat "%h %l %u %t \"%r\" %>s %b \"%{Referer}i\" \"%{User-agent}i\"" combinedCustomLog log/access_log combined 这种格式与通用日志格式类似,但是多了两个 %{header}i 项,其中的header可以是任何请求头。这种格式的记录形如:127.0.0.1 - frank [10/Oct/2000:13:55:36 -0700] "GET /apache_pb.gif HTTP/1.0" 200 2326 "http://www.example.com/start.html" "Mozilla/4.08 [en] (Win98; I ;Nav)" 其中,多出来的项是: "http://www.example.com/start.html" (\"%{Referer}i\") "Referer"请求头。此项指明了该请求是被从哪个网页提交过来的,这个网页应该包含有/apache_pb.gif或者其连接。 "Mozilla/4.08 [en] (Win98; I ;Nav)" (\"%{User-agent}i\") "User-Agent"请求头。此项是客户端提供的浏览器识别信息。 多文件访问日志可以简单地在配置文件中用多个CustomLog指令来建立多文件访问日志。如下例,既记录基本的CLF信息,又记录提交网页和浏览器的信息,最后两行CustomLog示范了如何模拟ReferLog和AgentLog指令的效果。LogFormat "%h %l %u %t \"%r\" %>s %b" commonCustomLog logs/access_log commonCustomLog logs/referer_log "%{Referer}i -> %U"CustomLog logs/agent_log "%{User-agent}i" 此例也说明了,记录格式可以直接由CustomLog指定,而并不一定要用LogFormat起一个别名。条件日志许多时候,根据与请求特征相关的环境变量来有选择地记录某些客户端请求会带来便利。首先,需要使用SetEnvIf指令来设置特定的环境变量以标识符合某种特定条件的请求,然后用CustomLog指令的 env= 子句,根据这些环境变量来决定记录或排除特定的请求。例如:# 不记录本机发出的请求SetEnvIf Remote_Addr "127\.0\.0\.1" dontlog# 不记录对robots.txt文件的请求SetEnvIf Request_URI "^/robots\.txt$" dontlog# 记录其他请求CustomLog logs/access_log common env=!dontlog 再如,将使用英语的请求记录到一个日志,而记录非英语的请求到另一个日志:SetEnvIf Accept-Language "en" englishCustomLog logs/english_log common env=englishCustomLog logs/non_english_log common env=!english 虽然上述已经展示了条件日志记录的强大和灵活,但这不是控制日志内容的唯一手段,还可以用日志后继处理程序来剔除你不关心的内容,从而使日志更加有用。日志滚动即使一个并不繁忙的服务器,其日志文件的信息量也会很大,一般每10000个请求,访问日志就会增加1MB或更多。这就有必要定期滚动日志文件。由于Apache会保持日志文件的打开,并持续写入信息,因此服务器运行期间不能执行滚动操作。移动或者删除日志文件以后,必须重新启动服务器才能让它打开新的日志文件。用优雅的(graceful)方法重新启动,可以使服务器启用新的日志文件,而不丢失原来尚未写入的信息。为此,有必要等待一段时间,让服务器完成正在处理的请求,并将记录写入到原来的日志文件。以下是一个典型的日志滚动和为节省存储空间而压缩旧日志的例子:mv access_log access_log.oldmv error_log error_log.oldapachectl gracefulsleep 600gzip access_log.old error_log.old 另一种执行滚动的方法是使用下一节阐述的管道日志管道日志Apache httpd可以通过管道将访问记录和出错信息传递给另一个进程,而不是写入一个文件,由于无须对主服务器进行编程,这个功能显著地增强了日志的灵活性。只要用管道操作符"|"后面跟一个可执行文件名,就可以使这个程序从标准输入设备获得事件记录。Apache在启动时,会同时启动这个管道日志进程,并且在运行过程中,如果这个进程崩溃了,会重新启动这个进程(所以我们称这个技术为"可靠管道日志")。管道日志进程由其父进程Apache httpd产生,并继承其权限,这意味着管道进程通常是作为root运行的,所以保持这个程序简单而安全极为重要。管道日志的一种重要用途是,允许日志滚动而无须重新启动服务器。为此,服务器提供了一个简单的程序rotatelogs 。每24小时滚动一次日志的例子如下:CustomLog "|/usr/local/apache/bin/rotatelogs /var/log/access_log 86400" common 注意:引号用于界定整个管道命令行。虽然这是针对访问日志的,但是其用法对于其他日志也一样。在其他站点,有一个类似但更灵活的日志滚动程序叫cronolog 。如果有较简单的离线处理日志的方案,就不应该使用条件日志和管道日志,即使它们非常强大。虚拟主机如果服务器配有若干虚拟主机,那么还有几个控制日志文件的功能。首先,可以把日志指令放在<VirtualHost>段之外,让它们与主服务器使用同一个访问日志和错误日志来记录所有的请求和错误,但是这样就不能方便的获得每个虚拟主机的信息了。如果把CustomLogErrorLog指令放在<VirtualHost>段内,所有对这个虚拟主机的请求和错误信息会被记录在其私有的日志文件中,那些没有在<VirtualHost>段内使用日志指令的虚拟主机将仍然和主服务器使用同一个日志。这种方法对虚拟主机较少的服务器很有用,但虚拟主机非常多时,就会带来管理上的困难,还经常会产生文件描述符短缺的问题。对于访问日志,有一个很好的折衷方案,在同一个访问日志文件中记录对所有主机的访问,而每条记录都注明虚拟主机的信息,日后再把记录拆开存入不同的文件。例如:LogFormat "%v %l %u %t \"%r\" %>s %b" comonvhostCustomLog logs/access_log comonvhost %v 用来附加虚拟主机的信息。有个split-logfile程序可以根据不同的虚拟主机信息对日志进行拆分,并将结果存入不同的文件。其他日志文件 相关模块 相关指令 mod_logiomod_log_forensicmod_cgimod_rewriteLogFormatForensicLogPidFileRewriteLogRewriteLogLevelScriptLogScriptLogBufferScriptLogLength记录接收和发送的实际字节数mod_logio增加了两个额外的LogFormat字段(%I 和 %O)用于记录接收和发送的实际字节数。对比记录(Forensic Logging)mod_log_forensic提供了对客户端请求的对比记录,也就是在请求被处理之前和处理完成之后进行两次记录,所以对比日志(forensic log)对于每个请求都包含两条记录。对比记录器(forensic logger)十分严格,不可以进行定制。它可以成为无价的调试和安全工具。PID文件在启动时,Apache httpd将会在logs/httpd.pid文件中保存其父进程httpd的进程ID(process id[PID])。该文件名可以用PidFile指令改变。该PID可以被管理员利用来重新启动或者终止服务器后台守护进程。在Windows中,可以使用命令行参数 -k 。更多信息请参见停止和重新启动脚本日志为了方便调试,可以用ScriptLog指令来记录CGI脚本的输入和输出。此功能应该仅用于测试,而不应该用于正常工作的服务器。更多资料请参见mod_cgi文档。重写日志在使用强大且灵活的mod_rewrite时,几乎都有必要用RewriteLog来帮助调试。这个日志提供了重写引擎如何转换请求的详细分解信息,其详细程度取决于RewriteLogLevel指令。... 全文

apache 日志 休闲 职场

Linux下编译安装Apache

1、关于编译安装;    通俗的讲就是将源代码变为计算机可执行的代码文件,而后将可执行文件安装到操作系统里,才可使用。... 全文

安装 Linux Apache

apache

## This is the main Apache server configuration file.  It contains the# configuration directives that give the server its instructions.# See <URL:[url]http://httpd.apache.org/docs/2.2/[/url]> for detailed information.# In particular, see# <URL:[url]http://httpd.apache.org/docs/2.2/mod/directives.html[/url]># for a discussion of each configuration directive.### Do NOT simply read the instructions in here without understanding# what they do.  They're here .ly as hints or reminders.  If you are unsure# consult the .line docs. You have been warned.  ## The configuration directives are grouped into three basic sections:#  1. Directives that control the operation of the Apache server process as a#     whole (the 'global environment').#  2. Directives that define the parameters of the 'main' or 'default' server,#     which responds to requests that aren't handled by a virtual host.#     These directives also provide default values for the settings#     of all virtual hosts.#  3. Settings for virtual hosts, which allow Web requests to be sent to#     different IP addresses or hostnames and have them handled by the#     same Apache server process.## Configuration and logfile names: If the filenames you specify for many# of the server's control files begin with "/" (or "drive:/" for Win32), the# server will use that explicit path.  If the filenames do *not* begin# with "/", the value of ServerRoot is prepended -- so "logs/foo.log"# with ServerRoot set to "/etc/httpd" will be interpreted by the# server as "/etc/httpd/logs/foo.log".#### Section 1: Global Environment## The directives in this section affect the overall operation of Apache,# such as the number of concurrent requests it can handle or where it# can find its configuration files.### Don't give away too much information about all the subcomponents# we are running.  Comment out this line if you don't mind remote sites# finding out what major optional modules you are runningServerTokens OS## ServerRoot: The top of the directory tree under which the server's# configuration, error, and log files are kept.## NOTE!  If you intend to place this . an NFS (or otherwise network)# mounted filesystem then please read the LockFile documentation# (available at <URL:[url]http://httpd.apache.org/docs/2.2/mod/mpm_common.html#lockfile[/url]>);# you will save yourself a lot of trouble.## Do NOT add a slash at the end of the directory path.#ServerRoot "/etc/httpd"## PidFile: The file in which the server should record its process# identification number when it starts.#PidFile run/httpd.pid## Timeout: The number of seconds before receives and sends time out.#Timeout 120## KeepAlive: Whether or not to allow persistent connections (more than# .e request per connection). Set to "Off" to deactivate.#KeepAlive Off## MaxKeepAliveRequests: The maximum number of requests to allow# during a persistent connection. Set to 0 to allow an unlimited amount.# We recommend you leave this number high, for maximum performance.#MaxKeepAliveRequests 100## KeepAliveTimeout: Number of seconds to wait for the next request from the# same client . the same connection.#KeepAliveTimeout 15#### Server-Pool Size Regulation (MPM specific)## # prefork MPM# StartServers: number of server processes to start# MinSpareServers: minimum number of server processes which are kept spare# MaxSpareServers: maximum number of server processes which are kept spare# ServerLimit: maximum value for MaxClients for the lifetime of the server# MaxClients: maximum number of server processes allowed to start# MaxRequestsPerChild: maximum number of requests a server process serves<IfModule prefork.c>StartServers       8MinSpareServers    5MaxSpareServers   20ServerLimit      256MaxClients       256MaxRequestsPerChild  4000</IfModule># worker MPM# StartServers: initial number of server processes to start# MaxClients: maximum number of simultaneous client connections# MinSpareThreads: minimum number of worker threads which are kept spare# MaxSpareThreads: maximum number of worker threads which are kept spare# ThreadsPerChild: constant number of worker threads in each server process# MaxRequestsPerChild: maximum number of requests a server process serves<IfModule worker.c>StartServers         2MaxClients         150MinSpareThreads     25MaxSpareThreads     75 ThreadsPerChild     25MaxRequestsPerChild  0</IfModule>## Listen: Allows you to bind Apache to specific IP addresses and/or# ports, in addition to the default. See also the <VirtualHost># directive.## Change this to Listen . specific IP addresses as shown below to # prevent Apache from glomming .to all bound IP addresses (0.0.0.0)##Listen 12.34.56.78:80Listen 80## Dynamic Shared Object (DSO) Support## To be able to use the functionality of a module which was built as a DSO you# have to place corresponding `LoadModule' lines at this location so the# directives contained in it are actually available _before_ they are used.# Statically compiled modules (those listed by `httpd -l') do not need# to be loaded here.## Example:# LoadModule foo_module modules/mod_foo.so#LoadModule auth_basic_module modules/mod_auth_basic.soLoadModule auth_digest_module modules/mod_auth_digest.soLoadModule authn_file_module modules/mod_authn_file.soLoadModule authn_alias_module modules/mod_authn_alias.soLoadModule authn_anon_module modules/mod_authn_anon.soLoadModule authn_dbm_module modules/mod_authn_dbm.soLoadModule authn_default_module modules/mod_authn_default.soLoadModule authz_host_module modules/mod_authz_host.soLoadModule authz_user_module modules/mod_authz_user.soLoadModule authz_owner_module modules/mod_authz_owner.soLoadModule authz_groupfile_module modules/mod_authz_groupfile.soLoadModule authz_dbm_module modules/mod_authz_dbm.soLoadModule authz_default_module modules/mod_authz_default.soLoadModule ldap_module modules/mod_ldap.soLoadModule authnz_ldap_module modules/mod_authnz_ldap.soLoadModule include_module modules/mod_include.soLoadModule log_config_module modules/mod_log_config.soLoadModule logio_module modules/mod_logio.soLoadModule env_module modules/mod_env.soLoadModule ext_filter_module modules/mod_ext_filter.soLoadModule mime_magic_module modules/mod_mime_magic.soLoadModule expires_module modules/mod_expires.soLoadModule deflate_module modules/mod_deflate.soLoadModule headers_module modules/mod_headers.soLoadModule usertrack_module modules/mod_usertrack.soLoadModule setenvif_module modules/mod_setenvif.soLoadModule mime_module modules/mod_mime.soLoadModule dav_module modules/mod_dav.soLoadModule status_module modules/mod_status.soLoadModule autoindex_module modules/mod_autoindex.soLoadModule info_module modules/mod_info.soLoadModule dav_fs_module modules/mod_dav_fs.soLoadModule vhost_alias_module modules/mod_vhost_alias.soLoadModule negotiation_module modules/mod_negotiation.soLoadModule dir_module modules/mod_dir.soLoadModule actions_module modules/mod_actions.soLoadModule speling_module modules/mod_speling.soLoadModule userdir_module modules/mod_userdir.soLoadModule alias_module modules/mod_alias.soLoadModule rewrite_module modules/mod_rewrite.soLoadModule proxy_module modules/mod_proxy.soLoadModule proxy_balancer_module modules/mod_proxy_balancer.soLoadModule proxy_ftp_module modules/mod_proxy_ftp.soLoadModule proxy_http_module modules/mod_proxy_http.soLoadModule proxy_connect_module modules/mod_proxy_connect.soLoadModule cache_module modules/mod_cache.soLoadModule suexec_module modules/mod_suexec.soLoadModule disk_cache_module modules/mod_disk_cache.soLoadModule file_cache_module modules/mod_file_cache.soLoadModule mem_cache_module modules/mod_mem_cache.soLoadModule cgi_module modules/mod_cgi.so## The following modules are not loaded by default:##LoadModule cern_meta_module modules/mod_cern_meta.so#LoadModule asis_module modules/mod_asis.so## Load config files from the config directory "/etc/httpd/conf.d".#Include conf.d/*.conf## ExtendedStatus controls whether Apache will generate "full" status# information (ExtendedStatus .) or just basic information (ExtendedStatus# Off) when the "server-status" handler is called. The default is Off.##ExtendedStatus .## If you wish httpd to run as a different user or group, you must run# httpd as root initially and it will switch.  ## User/Group: The name (or #number) of the user/group to run httpd as.#  . . SCO (ODT 3) use "User nouser" and "Group nogroup".#  . . HPUX you may not be able to use shared memory as nobody, and the#    suggested workaround is to create a user www and use that user.#  NOTE that some kernels refuse to setgid(Group) or semctl(IPC_SET)#  when the value of (unsigned)Group is above 60000; #  don't use Group #-1 . these systems!#User apacheGroup apache### Section 2: 'Main' server configuration## The directives in this section set up the values used by the 'main'# server, which responds to any requests that aren't handled by a# <VirtualHost> definition.  These values also provide defaults for# any <VirtualHost> containers you may define later in the file.## All of these directives may appear inside <VirtualHost> containers,# in which case these default settings will be overridden for the# virtual host being defined.### ServerAdmin: Your address, where problems with the server should be# e-mailed.  This address appears . some server-generated pages, such# as error documents.  e.g. admin@your-domain.com#ServerAdmin root@localhost## ServerName gives the name and port that the server uses to identify itself.# This can often be determined automatically, but we recommend you specify# it explicitly to prevent problems during startup.## If this is not set to valid DNS name for your host, server-generated# redirections will not work.  See also the UseCanonicalName directive.## If your host doesn't have a registered DNS name, enter its IP address here.# You will have to access it by its address anyway, and this will make # redirections work in a sensible way.##ServerName [url]www.example.com:80[/url]## UseCanonicalName: Determines how Apache constructs self-referencing # URLs and the SERVER_NAME and SERVER_PORT variables.# When set "Off", Apache will use the Hostname and Port supplied# by the client.  When set "On", Apache will use the value of the# ServerName directive.#UseCanonicalName Off## DocumentRoot: The directory out of which you will serve your# documents. By default, all requests are taken from this directory, but# symbolic links and aliases may be used to point to other locations.#DocumentRoot "/var/www/html"## Each directory to which Apache has access can be configured with respect# to which services and features are allowed and/or disabled in that# directory (and its subdirectories). ## First, we configure the "default" to be a very restrictive set of # features.  #<Directory />    Options FollowSymLinks    AllowOverride None</Directory>## Note that from this point forward you must specifically allow# particular features to be enabled - so if something's not working as# you might expect, make sure that you have specifically enabled it# below.### This should be changed to whatever you set DocumentRoot to.#<Directory "/var/www/html">## Possible values for the Options directive are "None", "All",# or any combination of:#   Indexes Includes FollowSymLinks SymLinksifOwnerMatch ExecCGI MultiViews## Note that "MultiViews" must be named *explicitly* --- "Options All"# doesn't give it to you.## The Options directive is both complicated and important.  Please see# [url]http://httpd.apache.org/docs/2.2/mod/core.html#options[/url]# for more information.#    Options Indexes FollowSymLinks## AllowOverride controls what directives may be placed in .htaccess files.# It can be "All", "None", or any combination of the keywords:#   Options FileInfo AuthConfig Limit#    AllowOverride None## Controls who can get stuff from this server.#    Order allow,deny    Allow from all</Directory>## UserDir: The name of the directory that is appended .to a user's home# directory if a ~user request is received.## The path to the end user account 'public_html' directory must be# accessible to the webserver userid.  This usually means that ~userid# must have permissions of 711, ~userid/public_html must have permissions# of 755, and documents contained therein must be world-readable.# Otherwise, the client will .ly receive a "403 Forbidden" message.## See also: [url]http://httpd.apache.org/docs/misc/FAQ.html#forbidden[/url]#<IfModule mod_userdir.c>    #    # UserDir is disabled by default since it can confirm the presence    # of a username . the system (depending . home directory    # permissions).    #    UserDir disable    #    # To enable requests to /~user/ to serve the user's public_html    # directory, remove the "UserDir disable" line above, and uncomment    # the following line instead:    #     #UserDir public_html</IfModule>## Control access to UserDir directories.  The following is an example# for a site where these directories are restricted to read-only.##<Directory /home/*/public_html>#    AllowOverride FileInfo AuthConfig Limit#    Options MultiViews Indexes SymLinksIfOwnerMatch IncludesNoExec#    <Limit GET POST OPTIONS>#        Order allow,deny#        Allow from all#    </Limit>#    <LimitExcept GET POST OPTIONS>#        Order deny,allow#        Deny from all#    </LimitExcept>#</Directory>## DirectoryIndex: sets the file that Apache will serve if a directory# is requested.## The index.html.var file (a type-map) is used to deliver content-# negotiated documents.  The MultiViews Option can be used for the # same purpose, but it is much slower.#DirectoryIndex index.html index.php## AccessFileName: The name of the file to look for in each directory# for additional configuration directives.  See also the AllowOverride# directive.#AccessFileName .htaccess## The following lines prevent .htaccess and .htpasswd files from being # viewed by Web clients. #<Files ~ "^\.ht">    Order allow,deny    Deny from all</Files>## TypesConfig describes where the mime.types file (or equivalent) is# to be found.#TypesConfig /etc/mime.types## DefaultType is the default MIME type the server will use for a document# if it cannot otherwise determine .e, such as from filename extensions.# If your server contains mostly text or HTML documents, "text/plain" is# a good value.  If most of your content is binary, such as applications# or images, you may want to use "application/octet-stream" instead to# keep browsers from trying to display binary files as though they are# text.#DefaultType text/plain## The mod_mime_magic module allows the server to use various hints from the# contents of the file itself to determine its type.  The MIMEMagicFile# directive tells the module where the hint definitions are located.#<IfModule mod_mime_magic.c>#   MIMEMagicFile /usr/share/magic.mime    MIMEMagicFile conf/magic</IfModule>## HostnameLookups: Log the names of clients or just their IP addresses# e.g., [url]www.apache.org[/url] (on) or 204.62.129.132 (off).# The default is off because it'd be overall better for the net if people# had to knowingly turn this feature ., since enabling it means that# each client request will result in AT LEAST .e lookup request to the# nameserver.#HostnameLookups Off## EnableMMAP: Control whether memory-mapping is used to deliver# files (assuming that the underlying OS supports it).# The default is .; turn this off if you serve from NFS-mounted # filesystems.  . some systems, turning it off (regardless of# filesystem) can improve performance; for details, please see# [url]http://httpd.apache.org/docs/2.2/mod/core.html#enablemmap[/url]##EnableMMAP off## EnableSendfile: Control whether the sendfile kernel support is # used to deliver files (assuming that the OS supports it). # The default is .; turn this off if you serve from NFS-mounted # filesystems.  Please see# [url]http://httpd.apache.org/docs/2.2/mod/core.html#enablesendfile[/url]##EnableSendfile off## ErrorLog: The location of the error log file.# If you do not specify an ErrorLog directive within a <VirtualHost># container, error messages relating to that virtual host will be# logged here.  If you *do* define an error logfile for a <VirtualHost># container, that host's errors will be logged there and not here.#ErrorLog logs/error_log## LogLevel: Control the number of messages logged to the error_log.# Possible values include: debug, info, notice, warn, error, crit,# alert, emerg.#LogLevel warn## The following directives define some format nicknames for use with# a CustomLog directive (see below).#LogFormat "%h %l %u %t \"%r\" %>s %b \"%{Referer}i\" \"%{User-Agent}i\"" combinedLogFormat "%h %l %u %t \"%r\" %>s %b" commonLogFormat "%{Referer}i -> %U" refererLogFormat "%{User-agent}i" agent# "combinedio" includes actual counts of actual bytes received (%I) and sent (%O); this# requires the mod_logio module to be loaded.#LogFormat "%h %l %u %t \"%r\" %>s %b \"%{Referer}i\" \"%{User-Agent}i\" %I %O" combinedio## The location and format of the access logfile (Common Logfile Format).# If you do not define any access logfiles within a <VirtualHost># container, they will be logged here.  Contrariwise, if you *do*# define per-<VirtualHost> access logfiles, transactions will be# logged therein and *not* in this file.##CustomLog logs/access_log common## If you would like to have separate agent and referer logfiles, uncomment# the following directives.##CustomLog logs/referer_log referer#CustomLog logs/agent_log agent## For a single logfile with access, agent, and referer information# (Combined Logfile Format), use the following directive:#CustomLog logs/access_log combined## Optionally add a line containing the server version and virtual host# name to server-generated pages (internal error documents, FTP directory# listings, mod_status and mod_info output etc., but not CGI generated# documents or custom error documents).# Set to "EMail" to also include a mailto: link to the ServerAdmin.# Set to .e of:  . | Off | EMail#ServerSignature .## Aliases: Add here as many aliases as you need (with no limit). The format is # Alias fakename realname## Note that if you include a trailing / . fakename then the server will# require it to be present in the URL.  So "/icons" isn't aliased in this# example, .ly "/icons/".  If the fakename is slash-terminated, then the # realname must also be slash terminated, and if the fakename omits the # trailing slash, the realname must also omit it.## We include the /icons/ alias for FancyIndexed directory listings.  If you# do not use FancyIndexing, you may comment this out.#Alias /icons/ "/var/www/icons/"<Directory "/var/www/icons">    Options Indexes MultiViews    AllowOverride None    Order allow,deny    Allow from all</Directory>## WebDAV module configuration section.# <IfModule mod_dav_fs.c>    # Location of the WebDAV lock database.    DAVLockDB /var/lib/dav/lockdb</IfModule>## .Alias: This controls which directories contain server .s.# .Aliases are essentially the same as Aliases, except that# documents in the realname directory are treated as applications and# run by the server when requested rather than as documents sent to the client.# The same rules about trailing "/" apply to .Alias directives as to# Alias.#.Alias /cgi-bin/ "/var/www/cgi-bin/"## "/var/www/cgi-bin" should be changed to whatever your .Aliased# CGI directory exists, if you have that configured.#<Directory "/var/www/cgi-bin">    AllowOverride None    Options None    Order allow,deny    Allow from all</Directory>## Redirect allows you to tell clients about documents which used to exist in# your server's namespace, but do not anymore. This allows you to tell the# clients where to look for the relocated document.# Example:# Redirect permanent /foo [url]http://www.example.com/bar[/url]## Directives controlling the display of server-generated directory listings.### IndexOptions: Controls the appearance of server-generated directory# listings.#IndexOptions FancyIndexing VersionSort NameWidth=* HTMLTable## AddIcon* directives tell the server which icon to show for different# files or filename extensions.  These are .ly displayed for# FancyIndexed directories.#AddIconByEncoding (CMP,/icons/compressed.gif) x-compress x-gzipAddIconByType (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 .exeAddIcon /icons/binhex.gif .hqxAddIcon /icons/tar.gif .tarAddIcon /icons/world2.gif .wrl .wrl.gz .vrml .vrm .ivAddIcon /icons/compressed.gif .Z .z .tgz .gz .zipAddIcon /icons/a.gif .ps .ai .epsAddIcon /icons/layout.gif .html .shtml .htm .pdfAddIcon /icons/text.gif .txtAddIcon /icons/c.gif .cAddIcon /icons/p.gif .pl .pyAddIcon /icons/f.gif .forAddIcon /icons/dvi.gif .dviAddIcon /icons/uuencoded.gif .uuAddIcon /icons/..gif .conf .sh .shar .csh .ksh .tclAddIcon /icons/tex.gif .texAddIcon /icons/bomb.gif coreAddIcon /icons/back.gif ..AddIcon /icons/hand.right.gif READMEAddIcon /icons/folder.gif ^^DIRECTORY^^AddIcon /icons/blank.gif ^^BLANKICON^^## DefaultIcon is which icon to show for files which do not have an icon# explicitly set.#DefaultIcon /icons/unknown.gif## AddDe.ion allows you to place a short de.ion after a file in# server-generated indexes.  These are .ly displayed for FancyIndexed# directories.# Format: AddDe.ion "de.ion" filename##AddDe.ion "GZIP compressed document" .gz#AddDe.ion "tar archive" .tar#AddDe.ion "GZIP compressed tar archive" .tgz## ReadmeName is the name of the README file the server will look for by# default, and append to directory listings.## HeaderName is the name of a file which should be prepended to# directory indexes. ReadmeName README.htmlHeaderName HEADER.html## IndexIgnore is a set of filenames which directory indexing should ignore# and not include in the listing.  Shell-style wildcarding is permitted.#IndexIgnore .??* *~ *# HEADER* README* RCS CVS *,v *,t## DefaultLanguage and AddLanguage allows you to specify the language of # a document. You can then use content negotiation to give a browser a # file in a language the user can understand.## Specify a default language. This means that all data# going out without a specific language tag (see below) will # be marked with this .e. You probably do NOT want to set# this unless you are sure it is correct for all cases.## * It is generally better to not mark a page as # * being a certain language than marking it with the wrong# * language!## DefaultLanguage nl## Note 1: The suffix does not have to be the same as the language# keyword --- those with documents in Polish (whose net-standard# language code is pl) may wish to use "AddLanguage pl .po" to# avoid the ambiguity with the common suffix for perl .s.## Note 2: The example entries below illustrate that in some cases # the two character 'Language' abbreviation is not identical to # the two character 'Country' code for its country,# E.g. 'Danmark/dk' versus 'Danish/da'.## Note 3: In the case of 'ltz' we violate the RFC by using a three char# specifier. There is 'work in progress' to fix this and get# the reference data for rfc1766 cleaned up.## Catalan (ca) - Croatian (hr) - Czech (cs) - Danish (da) - Dutch (nl)# English (en) - Esperanto (eo) - Estonian (et) - French (fr) - German (de)# Greek-Modern (el) - Hebrew (he) - Italian (it) - Japanese (ja)# Korean (ko) - Luxembourgeois* (ltz) - Norwegian Nynorsk (nn)# Norwegian (no) - Polish (pl) - Portugese (pt)# Brazilian Portuguese (pt-BR) - Russian (ru) - Swedish (sv)# Simplified Chinese (zh-CN) - Spanish (es) - Traditional Chinese (zh-TW)#AddLanguage ca .caAddLanguage cs .cz .csAddLanguage da .dkAddLanguage de .deAddLanguage el .elAddLanguage en .enAddLanguage eo .eoAddLanguage es .esAddLanguage et .etAddLanguage fr .frAddLanguage he .heAddLanguage hr .hrAddLanguage it .itAddLanguage ja .jaAddLanguage ko .koAddLanguage ltz .ltzAddLanguage nl .nlAddLanguage nn .nnAddLanguage no .noAddLanguage pl .poAddLanguage pt .ptAddLanguage pt-BR .pt-brAddLanguage ru .ruAddLanguage sv .svAddLanguage zh-CN .zh-cnAddLanguage zh-TW .zh-tw## LanguagePriority allows you to give precedence to some languages# in case of a tie during content negotiation.## Just list the languages in decreasing order of preference. We have# more or less alphabetized them here. You probably want to change this.#LanguagePriority en ca cs da de el eo es et fr he hr it ja ko ltz nl nn no pl pt pt-BR ru sv zh-CN zh-TW## ForceLanguagePriority allows you to serve a result page rather than# MULTIPLE CHOICES (Prefer) [in case of a tie] or NOT ACCEPTABLE (Fallback)# [in case no accepted languages matched the available variants]#ForceLanguagePriority Prefer Fallback## Specify a default charset for all content served; this enables# interpretation of all content as UTF-8 by default.  To use the # default browser choice (ISO-8859-1), or to allow the META tags# in HTML content to override this choice, comment out this# directive:#AddDefaultCharset GB2312## AddType allows you to add to or override the MIME configuration# file mime.types for specific file types.##AddType application/x-tar .tgz## AddEncoding allows you to have certain browsers uncompress# information . the fly. Note: Not all browsers support this.# Despite the name similarity, the following Add* directives have nothing# to do with the FancyIndexing customization directives above.##AddEncoding x-compress .Z#AddEncoding x-gzip .gz .tgz# If the AddEncoding directives above are commented-out, then you# probably should define those extensions to indicate media types:#AddType application/x-compress .ZAddType application/x-gzip .gz .tgz## AddHandler allows you to map certain file extensions to "handlers":# actions unrelated to filetype. These can be either built into the server# or added with the Action directive (see below)## To use CGI .s outside of .Aliased directories:# (You will also need to add "ExecCGI" to the "Options" directive.)##AddHandler cgi-. .cgi## For files that include their own HTTP headers:##AddHandler send-as-is asis## For type maps (negotiated resources):# (This is enabled by default to allow the Apache "It Worked" page#  to be distributed in multiple languages.)#AddHandler type-map var## Filters allow you to process content before it is sent to the client.## To parse .shtml files for server-side includes (SSI):# (You will also need to add "Includes" to the "Options" directive.)#AddType text/html .shtmlAddOutputFilter INCLUDES .shtml## Action lets you define media types that will execute a . whenever# a matching file is called. This eliminates the need for repeated URL# pathnames for oft-used CGI file processors.# Format: Action media/type /cgi-./location# Format: Action handler-name /cgi-./location### Customizable error responses come in three flavors:# 1) plain text 2) local redirects 3) external redirects## Some examples:#ErrorDocument 500 "The server made a boo boo."#ErrorDocument 404 /missing.html#ErrorDocument 404 "/cgi-bin/missing_handler.pl"#ErrorDocument 402 [url]http://www.example.com/sub.ion_info.html[/url]### Putting this all together, we can internationalize error responses.## We use Alias to redirect any /error/HTTP_<error>.html.var response to# our collection of by-error message multi-language collections.  We use # includes to substitute the appropriate text.## You can modify the messages' appearance without changing any of the# default HTTP_<error>.html.var files by adding the line:##   Alias /error/include/ "/your/include/path/"## which allows you to create your own set of files by starting with the# /var/www/error/include/ files and# copying them to /your/include/path/, even . a per-VirtualHost basis.#Alias /error/ "/var/www/error/"<IfModule mod_negotiation.c><IfModule mod_include.c>    <Directory "/var/www/error">        AllowOverride None        Options IncludesNoExec        AddOutputFilter Includes html        AddHandler type-map var        Order allow,deny        Allow from all        LanguagePriority en es de fr        ForceLanguagePriority Prefer Fallback    </Directory>#    ErrorDocument 400 /error/HTTP_BAD_REQUEST.html.var#    ErrorDocument 401 /error/HTTP_UNAUTHORIZED.html.var#    ErrorDocument 403 /error/HTTP_FORBIDDEN.html.var#    ErrorDocument 404 /error/HTTP_NOT_FOUND.html.var#    ErrorDocument 405 /error/HTTP_METHOD_NOT_ALLOWED.html.var#    ErrorDocument 408 /error/HTTP_REQUEST_TIME_OUT.html.var#    ErrorDocument 410 /error/HTTP_GONE.html.var#    ErrorDocument 411 /error/HTTP_LENGTH_REQUIRED.html.var#    ErrorDocument 412 /error/HTTP_PRECONDITION_FAILED.html.var#    ErrorDocument 413 /error/HTTP_REQUEST_ENTITY_TOO_LARGE.html.var#    ErrorDocument 414 /error/HTTP_REQUEST_URI_TOO_LARGE.html.var#    ErrorDocument 415 /error/HTTP_UNSUPPORTED_MEDIA_TYPE.html.var#    ErrorDocument 500 /error/HTTP_INTERNAL_SERVER_ERROR.html.var#    ErrorDocument 501 /error/HTTP_NOT_IMPLEMENTED.html.var#    ErrorDocument 502 /error/HTTP_BAD_GATEWAY.html.var#    ErrorDocument 503 /error/HTTP_SERVICE_UNAVAILABLE.html.var#    ErrorDocument 506 /error/HTTP_VARIANT_ALSO_VARIES.html.var</IfModule></IfModule>## The following directives modify normal HTTP response behavior to# handle known problems with browser implementations.#BrowserMatch "Mozilla/2" nokeepaliveBrowserMatch "MSIE 4\.0b2;" nokeepalive downgrade-1.0 force-response-1.0BrowserMatch "RealPlayer 4\.0" force-response-1.0BrowserMatch "Java/1\.0" force-response-1.0BrowserMatch "JDK/1\.0" force-response-1.0## The following directive disables redirects . non-GET requests for# a directory that does not include the trailing slash.  This fixes a # problem with Microsoft WebFolders which does not appropriately handle # redirects for folders with DAV methods.# Same deal with Apple's DAV filesystem and Gnome VFS support for DAV.#BrowserMatch "Microsoft Data Access Internet Publishing Provider" redirect-carefullyBrowserMatch "MS FrontPage" redirect-carefullyBrowserMatch "^WebDrive" redirect-carefullyBrowserMatch "^WebDAVFS/1.[0123]" redirect-carefullyBrowserMatch "^gnome-vfs/1.0" redirect-carefullyBrowserMatch "^XML Spy" redirect-carefullyBrowserMatch "^Dreamweaver-WebDAV-SCM1" redirect-carefully## Allow server status reports generated by mod_status,# with the URL of [url]http://servername/server-status[/url]# Change the ".example.com" to match your domain to enable.##<Location /server-status>#    SetHandler server-status#    Order deny,allow#    Deny from all#    Allow from .example.com#</Location>## Allow remote server configuration reports, with the URL of#  [url]http://servername/server-info[/url] (requires that mod_info.c be loaded).# Change the ".example.com" to match your domain to enable.##<Location /server-info>#    SetHandler server-info#    Order deny,allow#    Deny from all#    Allow from .example.com#</Location>## Proxy Server directives. Uncomment the following lines to# enable the proxy server:##<IfModule mod_proxy.c>#ProxyRequests .##<Proxy *>#    Order deny,allow#    Deny from all#    Allow from .example.com#</Proxy>## Enable/disable the handling of HTTP/1.1 "Via:" headers.# ("Full" adds the server version; "Block" removes all outgoing Via: headers)# Set to .e of: Off | . | Full | Block##ProxyVia .## To enable a cache of proxied content, uncomment the following lines.# See [url]http://httpd.apache.org/docs/2.2/mod/mod_cache.html[/url] for more details.##<IfModule mod_disk_cache.c>#   CacheEnable disk /#   CacheRoot "/var/cache/mod_proxy"#</IfModule>##</IfModule># End of proxy directives.### Section 3: Virtual Hosts## VirtualHost: If you want to maintain multiple domains/hostnames . your# machine you can setup VirtualHost containers for them. Most configurations# use .ly name-based virtual hosts so the server doesn't need to worry about# IP addresses. This is indicated by the asterisks in the directives below.## Please see the documentation at # <URL:[url]http://httpd.apache.org/docs/2.2/vhosts/[/url]># for further details before you try to setup virtual hosts.## You may use the command line option '-S' to verify your virtual host# configuration.## Use name-based virtual hosting.##NameVirtualHost *:80## NOTE: NameVirtualHost cannot be used without a port specifier # (e.g. :80) if mod_ssl is being used, due to the nature of the# SSL protocol.### 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 *:80>#    ServerAdmin webmaster@dummy-host.example.com#    DocumentRoot /www/docs/dummy-host.example.com#    ServerName dummy-host.example.com#    ErrorLog logs/dummy-host.example.com-error_log#    CustomLog logs/dummy-host.example.com-access_log common#</VirtualHost>用户登陆:<Directory "/www1">    Options Indexes FollowSymLinks    AllowOverride None    Order allow,deny    Allow from all    authtype basic    anthname "jay.com"    authuserfile /etc/httpd/conf/password   :htpasswd -a xiaozhe    require valid-user xiaozhe</Directory>虚拟主机IP:<VirtualHost 192.168.3.160:80>        DocumentRoot /www1</VirtualHost>  SSL:https<Directory "/www2">    Options Indexes FollowSymLinks    AllowOverride None    Order allow,deny    Allow from all      SSLCertificatefile    /etc/httpd/conf/server.crt  使用openssl生成两个文件    SSLCertificatekeyfile /etc/httpd/conf/server.key  </Directory><VirtualHost 192.168.3.161:80>        DocumentRoot /www2</VirtualHost> 本文出自 “集群存储” 博客,谢绝转载!... 全文

linux apache 休闲 职场 服务器配置

搭建Web服务器Apache

相信使用过计算机的人,都应该有过访问Web服务器的经历。在网站浏览新闻、登录邮件服务器收发邮件、通过网络购物、以浏览器方式配置防火墙等,无一例外都有一个Web服务器在为访问者提供服务。尽管有其他方式来实现对设备或服务的访问(如配置卫星调制解调器),但以Web方式提供访问的策略依然是最受欢迎的,因为它更直观,也更方便,因此,使得Web服务器得以更广泛的流行。Apache是Linux主流的服务器,为Linux的迅速繁荣立下汗马功劳。根据资料显示,截至2005年12月,在Internet上,Apache服务器以绝对优势雄居Web服务器之首。在这节内容中,我们讨论Linux下大名鼎鼎的Web服务器Apache。请初学者注意,不要花费心思去搜寻名字为Apache这样的软件包,它现在的名字是httpd。Apache服务器的安装有两种时候可以安装Apache服务器:安装Linux操作系统的时候安装Web服务器和安装完系统后安装Apache服务器。 提示:可以用命令#rpm-qa|grep httpd检查一个系统是否安装了Apache服务器,如果没有输出,则表明没有安装。图1为某个安装了Apache服务器输出的一个范例。如果是以源码安装的Apache服务器,则此种方法无效,需要用find工具查找httpd文件是否存在。如果在安装Linux操作系统期间没有安装Apache,这就需要使用包文件来安装。1.RPM包的安装。从Linux的安装光盘和互联网上,都可以得到Apache的RPM安装包,然后把安装包复制到硬盘,并切换到安装包文件所在的目录。本文以httpd-2.0.52-9.ent.rpm为例。执行命令:... 全文

Web 虚拟机Apache 服务器

Apache配置注释(四)

apache主配置文件httpd.conf[root@eric6apache]# cat conf/httpd.conf|grep -v '.*#'|grep -v '^$'|nl1ServerRoot"/application/apache2.2.25" #apache的根目录,应只能root访问,一般不需要更改此项2Listen 80#apache监听的端口,默认为80,如果同时监听81端口,可以增加一行Listen81#3行-8行为apache的用户和组配置,即在运行时以次用户的身份启动服务和读取文件... 全文

配置 Apache 注释

Apache与Tomcat集群配置(1)

PS:今天整理硬盘,发现这个有用的收藏,与大家分享!一、 环境说明Windows XPapache_2.0.59-win32-x86-no_ssl.msi http://httpd.apache.org/mod_jk-apache-2.0.59.so http://tomcat.apache.org/download-connectors.cgiapache-tomcat-5.5.23.zip http://tomcat.apache.org/download-55.cgi我的程序分别安装到D:\webserver\Apache Group\Apache2... 全文

Apache Tomcat

Apache DBUtils使用总结

Apache DBUtils使用总结 DBUtils是个小巧的JDBC轻量级封装的工具包,其最核心的特性是结果集的封装,可以直接将查询出来的结果集封装成JavaBean,这就为我们做了最枯燥乏味、最容易出错的一大部分工作。 在使用DBUtils之前,应该注意一些问题: 1、DBUtils是JDBC的简单封装,可以和JDBC混合使用。 2、DBUtils对结果集自动封装为JavaBean是有着苛刻要求的:必须满足JavaBean的规范,其次Bean的getter与setter方法的名字与结果集的列名一一对应,而不要求JavaBean的私有成员与表结果集列名一一对应。比如:person表中有个字段叫:address,那么对应的JavaBean的Person类中必须有getAddress和setAddress两个方法,而Person类中可以将address属性命名为add,这是没问题的。 3、DBUtils可以将结果集封装为各种类型,主要有:Bean/List<Bean>,Map/List<Map>/Map<Map>,数组/List<数组>,列/List<列>,这些类型。对于Map<Map>的类型使用KeyedHandler作为结果集处理器,内层的Map是“列名-值"对,外层的Map是“主键-内层Map的引用”,但此处的主键不一定就是数据库的主键,可以随意指定,比如:ResultSetHandler h = new KeyedHandler("id"); Map found = (Map) queryRunner.query("select id, name, age from person", h); Map jane = (Map) found.get(new Long(1)); // jane's id is 1 String janesName = (String) jane.get("name"); Integer janesAge = (Integer) jane.get("age"); 4、DBUtils执行插入操作的时候,无法返回自增主键,这是一个很严重的问题,当然不能怪DBUtils,可以通过变通的方法来实现,比如在MySQL中,执行完了一个插入SQL后,接着执行SELECT LAST_INSERT_ID()语句,就可以获取到自增主键。 5、DBUtils的性能和JDBC性能是一样,测试过程中没发现性能损失,拥有了很高性能的同时,而不失JDBC的灵活性。 6、对于JavaBean的成员类型定义,有一条原则那就是:尽可能使用包装类型,而不要使用基本类型。很多人不理解为什么,包括我见到一些傻B(,我提出让改为包装类型,他还信誓旦旦的说他的代码多牛多叼),都干好多年了,这个简单的道理还不知道:        //错误        int a1 = (Integer) null;        boolean x1 = (Boolean)null;        //正确        Integer a2 = (Integer) null;        Boolean x2 = (Boolean)null; 实际上就是为了保证在查询结果为null的时候,也不会因为给基本类型赋null值而发生错误。 下面给出一个简单例子,作为以后写代码时候有点参考: 环境:MySQL5.4JDK1.5 建表SQL: CREATE TABLE person (      id bigint(20) NOT NULL AUTO_INCREMENT,      name varchar(24) DEFAULT NULL,      age int(11) DEFAULT NULL,      address varchar(120) DEFAULT NULL,      PRIMARY KEY (id) ) ENGINE=MyISAM AUTO_INCREMENT=1 DEFAULT CHARSET=gbk Java代码: public class Person {         private Long id;         private String sdf;         private String address2;         private Integer age;         public Person() {         }         public Person(String sdf) {                 this.sdf = sdf;         }         public Person(String sdf, Integer age, String address) {                 this.sdf = sdf;                 this.age = age;                 this.address2 = address;         }         public Long getId() {                 return id;         }         public void setId(Long id) {                 this.id = id;         }         public String getSdf() {                 return sdf;         }         public void setSdf(String sdf) {                 this.sdf = sdf;         }         public Integer getAge() {                 return age;         }         public void setAge(Integer age) {                 this.age = age;         }         public String getAddress() {                 return address2;         }         public void setAddress(String address2) {                 this.address2 = address2;         } } 测试 package com.lavasoft.dbstu; import com.lavasoft.common.DBToolkit; import org.apache.commons.dbutils.QueryRunner; import org.apache.commons.dbutils.handlers.BeanHandler; import org.apache.commons.dbutils.handlers.BeanListHandler; import org.apache.commons.dbutils.handlers.MapHandler; import org.apache.commons.dbutils.handlers.ScalarHandler; import java.sql.Connection; import java.sql.SQLException; import java.util.List; import java.util.Map; /** * Created by IntelliJ IDEA. * * @author leizhimin 2010-1-25 21:00:29 */ public class PersonDAOImpl implements PersonDAO {         private static PersonDAOImpl instance = new PersonDAOImpl();         public static PersonDAOImpl getInstance() {                 return instance;         }         public static void main(String[] args) {                 //错误                 int a1 = (Integer) null;                 boolean x1 = (Boolean) null;                 //正确                 Integer a2 = (Integer) null;                 Boolean x2 = (Boolean) null;                 getInstance().save(null); //                getInstance().save(null); //                getInstance().save(null); //                getInstance().save(null); //                getInstance().save(null);                 getInstance().update(null);                 getInstance().load(null);                 getInstance().load4Map(null);         }         @Override         public Long save(String sql) {                 Long id = null;                 String ins_sql = "INSERT INTO person (NAME, age, address) VALUES ('aaa', 21, 'address001')";                 Connection conn = DBToolkit.getConnection();                 QueryRunner qr = new QueryRunner();                 try {                         qr.update(conn, ins_sql);                         //获取新增记录的自增主键                         id = (Long) qr.query(conn, "SELECT LAST_INSERT_ID()", new ScalarHandler(1));                 } catch (SQLException e) {                         e.printStackTrace();                 } finally {                         DBToolkit.closeConnection(conn);                 }                 return id;         }         @Override         public int delete(Long id) {                 int x = 0;                 Connection conn = DBToolkit.getConnection();                 QueryRunner qr = new QueryRunner();                 try {                         x = qr.update(conn, "DELETE FROM person WHERE id = ?", id);                 } catch (SQLException e) {                         e.printStackTrace();                 } finally {                         DBToolkit.closeConnection(conn);                 }                 return x;         }         @Override         public int update(Person person) {                 int x = 0;                 Connection conn = DBToolkit.getConnection();                 QueryRunner qr = new QueryRunner();                 try {                         x = qr.update(conn, "UPDATE person SET NAME = ?, age = ?, address = ? WHERE id = ?", "xxx", 23, "ttt", 5);                 } catch (SQLException e) {                         e.printStackTrace();                 } finally {                         DBToolkit.closeConnection(conn);                 }                 return x;         }         @Override         public Person load(Long id) {                 Connection conn = DBToolkit.getConnection();                 QueryRunner qr = new QueryRunner();                 try {                         Person person = (Person) qr.query(conn, "SELECT * FROM person where id = ?", new BeanHandler(Person.class), 3L);                         System.out.println(person.getId() + "\t" + person.getSdf() + "\t" + person.getAge() + "\t" + person.getAddress());                 } catch (SQLException e) {                         e.printStackTrace();                 }                 return null;         }         @Override         public List<Person> findPerson(String sql) {                 Connection conn = DBToolkit.getConnection();                 QueryRunner qr = new QueryRunner();                 try {                         List<Person> pset = (List) qr.query(conn, "SELECT * FROM person", new BeanListHandler(Person.class));                         for (Person person : pset) {                                 System.out.println(person.getId() + "\t" + person.getSdf() + "\t" + person.getAge() + "\t" + person.getAddress());                         }                 } catch (SQLException e) {                         e.printStackTrace();                 }                 return null;         }         public Person load4Map(Long id) {                 Connection conn = DBToolkit.getConnection();                 QueryRunner qr = new QueryRunner();                 try {                         //先将两个字段置为null                         qr.update(conn, "update person set age = null,address =null where id =1");                         Map<String, Object> map = qr.query(conn, "SELECT * FROM person where id = ?", new MapHandler(), 1L);                         Person person = new Person();                         person.setId((Long) map.get("id"));                         person.setSdf((String) map.get("name"));                         person.setAge((Integer) map.get("age"));                         person.setAddress((String) map.get("address"));                         System.out.println(person.getId() + "\t" + person.getSdf() + "\t" + person.getAge() + "\t" + person.getAddress());                 } catch (SQLException e) {                         e.printStackTrace();                 }                 return null;         } } 注意:从上面的过程看,每个SQL的执行都需要用到QueryRunner,这其实是一个普通的类,非线程安全。在创建这个QueryRunner对象的时候,每次都要new。 QueryRunner对象的创建方式很多,可以通过DateSource,也可以通过Connection来创建。从QueryRunner对象上,可以直接获取到DataSource或者Connection对象。 如果你想看更多例子:http://jzinfo.javaeye.com/blog/543929本文出自 “熔 岩” 博客,请务必保留此出处http://lavasoft.blog.51cto.com/62575/270661... 全文

DBUtils Apache 休闲 职场

基于apache服务的svn服务器之构建

   svn是一款非常不错的开源的版本控制软件,现在就其搭建过程做如下记载,主要是借助apache进行工作的。一.环境准备二.svn配置... 全文

linux apache

第六章apache目录文件的位置及作用

 版本V1.0时间2012-10-04版权GPL作者itnihao 邮箱 itnihao@qq.com博客 http://itnihao.blog.51cto.com如需重新发行,请注明以上信息,谢谢合作前言... 全文

apache