<?xml version="1.0" encoding="UTF-8" ?>
<rss version="2.0">
<channel>
<title><![CDATA[七小木东]]></title> 
<link>http://www.qixiaomudong.cn/index.php</link> 
<description><![CDATA[七小木东]]></description> 
<language>zh-cn</language> 
<copyright><![CDATA[七小木东]]></copyright>
<item>
<link>http://www.qixiaomudong.cn/read.php?236</link>
<title><![CDATA[免费网络管理流量监控软件大比拼]]></title> 
<author>七小木东 &lt;admin@yourname.com&gt;</author>
<category><![CDATA[网络&amp;服务]]></category>
<pubDate>Wed, 11 Feb 2009 06:52:19 +0000</pubDate> 
<guid>http://www.qixiaomudong.cn/read.php?236</guid> 
<description>
<![CDATA[ 
	【IT168 专稿】希望能够找到免费的流量监控软件，前一阶段笔者为各位介绍了多款免费流量监控软件，并对这些软件的实际使用步骤和应用方法进行了阐述，那么究竟这些流量监控软件哪个具有最佳性能呢？今天我们就来进行一次硬碰硬的大比拼，看看谁才是免费流量监控软件之王。<br/><br/>&nbsp;&nbsp;&nbsp;&nbsp;四款软件齐登场：<br/>&nbsp;&nbsp;&nbsp;&nbsp;经过多名专家的品评，免费流量监控软件迎来了四强。这四位选手可以说是最具有实力的，在监视流量、控制流量、排查故障方面都有各自的绝招，下面我们就来了解一下四强选手的基本情况，看看谁能够在本次免费流量监控软件大比拼中独占鳌头。<br/><br/>&nbsp;&nbsp;&nbsp;&nbsp;Sniffer pro：<br/>&nbsp;&nbsp;&nbsp;&nbsp;Sniffer pro可以说是Sniffer软件的鼻祖，他的功能一点都不输于其他付费工具，他是由NAI公司出品的可能是目前最好的网络协议分析软件之一，支持各种平台，性能优越。<br/><br/>&nbsp;&nbsp;&nbsp;&nbsp;Sniffer pro小档案：<br/>&nbsp;&nbsp;&nbsp;&nbsp;软件版本：v4.7.530 特别版<br/>&nbsp;&nbsp;&nbsp;&nbsp;软件大小：33.02 MB<br/>&nbsp;&nbsp;&nbsp;&nbsp;软件语言：英文<br/>&nbsp;&nbsp;&nbsp;&nbsp;软件类别：共享软件 <br/>&nbsp;&nbsp;&nbsp;&nbsp;运行环境：WinXP/Win2000/NT/WinME/Win9X/Win2003<br/>&nbsp;&nbsp;&nbsp;&nbsp;下载地址：http://www.cncode.com/Download.asp?ID=1340&URL=http://downloads1012.cncode.com/server/SnifferPro_4_70_530.rar<br/><br/>&nbsp;&nbsp;&nbsp;&nbsp;PRTG：<br/>&nbsp;&nbsp;&nbsp;&nbsp;PRTG全称为Paessler Router Traffic Grapher，他是另外一款功能强大的免费且可以通过路由器等设备上的SNMP协议取得流量资讯并产生图形报表的软件，他可以为我们产生企业内部网络包括服务器，路由器，交换机，员工计算机等多种设备的网络流量图形化报表，并能够对这些报表进行统计和绘制，帮助我们这些网络管理员找到企业网络的问题所在，分析网络的升级方向。当然该软件可以在绘制完毕后将图形图表以页面的形式反馈给我们，这样网络管理员可以通过网络中的任何一台计算机访问配置了PRTG的计算机，实现远程管理，查看和维护网络流量的目的。<br/><br/>&nbsp;&nbsp;&nbsp;&nbsp;PRTG小档案：<br/>&nbsp;&nbsp;&nbsp;&nbsp;软件版本：v4.0.8.154.Enterprise<br/>&nbsp;&nbsp;&nbsp;&nbsp;软件大小：5.46MB<br/>&nbsp;&nbsp;&nbsp;&nbsp;软件语言：英文版<br/>&nbsp;&nbsp;&nbsp;&nbsp;软件类型：免费软件<br/>&nbsp;&nbsp;&nbsp;&nbsp;适用平台：windows 2000/xp/2003<br/>&nbsp;&nbsp;&nbsp;&nbsp;下载地址：http://download2.paessler.com/download/prtg.zip<br/><br/>&nbsp;&nbsp;&nbsp;&nbsp;MRTG：<br/>&nbsp;&nbsp;&nbsp;&nbsp;MRTG（Multi Router Traffic Grapher）是一款实用的网络流量监控软件，他通过snmp协议从设备得到流量信息，这样我们就可以监视通过服务器网卡的流量了，另外该软件还可以把流量数据以网页图表的方式显示出来，间隔时间可以是5分钟，30分钟，2小时或1天等多个选项，对生成的网页通过一般的网页编辑软件也可以进一步修改和美工。<br/><br/>&nbsp;&nbsp;&nbsp;&nbsp;MRTG小档案：<br/>&nbsp;&nbsp;&nbsp;&nbsp;软件版本：V2.10.0 pre 7<br/>&nbsp;&nbsp;&nbsp;&nbsp;软件大小：1558 KB<br/>&nbsp;&nbsp;&nbsp;&nbsp;软件性质：免费软件<br/>&nbsp;&nbsp;&nbsp;&nbsp;运行平台：Window 98/NT/2000/XP/2003<br/>下载地址：http://down.it168.com/files/xiazai3.asp?iid=4635<br/><br/>&nbsp;&nbsp;&nbsp;&nbsp;Ethereal：<br/>&nbsp;&nbsp;&nbsp;&nbsp;Ethereal是当前较为流行的一种计算机网络调试和数据包嗅探软件。Ethereal 基本类似于tcpdump，但Ethereal还具有设计完美的GUI和众多分类信息及过滤选项。用户通过Ethereal，同时将网卡插入混合模式，可以查看到网络中发送的所有通信流量，并根据流量进行测试从而发现网络问题并排除网络故障。 <br/><br/>&nbsp;&nbsp;&nbsp;&nbsp;ethereal小档案：<br/>&nbsp;&nbsp;&nbsp;&nbsp;软件版本： V0.99.0<br/>&nbsp;&nbsp;&nbsp;&nbsp;软件大小： 12747 KB <br/>&nbsp;&nbsp;&nbsp;&nbsp;软件语言： 英文 <br/>&nbsp;&nbsp;&nbsp;&nbsp;软件类别： 免费版<br/>&nbsp;&nbsp;&nbsp;&nbsp;应用平台： Win9x/NT/2000/XP/2003 <br/>&nbsp;&nbsp;&nbsp;&nbsp;下载地址：http://ftp7.enet.com.cn:88/pub/system/sysanaly/ethereal-setup-0.exe<br/><br/>&nbsp;&nbsp;&nbsp;&nbsp;那么到底这四强选手谁能够获得免费流量监控软件的桂冠呢？下面我们就来详细比较下。<br/>系统通用性大比拼<br/>&nbsp;&nbsp;&nbsp;&nbsp;一般对于这种流量监控软件我们在实际使用中都需要系统的支持，对于大多数中小企业来说计算机使用的操作系统无外乎Windows系统和类Linux系统。所以说要看这个流量监控软件是否兼容性好，还要看他是否真的能够在这两种操作系统中运行，如果不能的话通过专门的Windows版本和Linux版本也可以将就兼容。<br/><br/>&nbsp;&nbsp;&nbsp;&nbsp;Sniffer pro：（如图1）<br/>&nbsp;&nbsp;&nbsp;&nbsp;sniffer pro是Windows系统下的sniffer老大，不过他并不兼容Linux，也没有对应linux系统下运行的版本。<br/><br/> <br/>图1 <br/><br/><br/>&nbsp;&nbsp;&nbsp;&nbsp;PRTG：（如图2）<br/>&nbsp;&nbsp;&nbsp;&nbsp;PRTG是流量监控软件中的佼佼者，虽然他不能同时兼容Windows系统和Linux系统，但是PRTG推出了Windows版本和Linux版本，这样不管在哪个系统中都可以有效的运行PRTG。<br/><br/> <br/>图2 <br/><br/><br/>&nbsp;&nbsp;&nbsp;&nbsp;MRTG：（如图3）<br/>MRTG虽然无法同时兼容Windows和Linux系统，但是他同样提供了适用于两个系统的MRTG版本。不过MRTG出身自Linux系统，所以在Linux系统中他的表现更好，运行也更稳定，相应的在Windows系统中运行却时有毛病出现。<br/><br/> <br/>图3 <br/><br/><br/>&nbsp;&nbsp;&nbsp;&nbsp;Ethereal：（如图4）<br/>&nbsp;&nbsp;&nbsp;&nbsp;Ethereal是响当当的流量监控软件，而且类Ethereal的监控软件很多，很多公司出品的收费软件的核心也都是Ethereal。但是不管如何改进，类Ethereal表现终究是差些，所以说在实际使用中Ethereal的运行效果最好。他同样提供Windows系统和Linux系统两个版本。<br/><br/> <br/>图4 <br/><br/><br/>&nbsp;&nbsp;&nbsp;&nbsp;小结:<br/>&nbsp;&nbsp;&nbsp;&nbsp;Sniffer pro因为自负而缺乏Linux系统版本的支持，而其他三位高手则均推出了适用于Windows和Linux系统的版本，在这方面打平手。<br/><br/>&nbsp;&nbsp;&nbsp;&nbsp;分组比拼功能<br/>&nbsp;&nbsp;&nbsp;&nbsp;由于四款软件的功能导向不同，所以我们无法把他们拿到一起进行功能比拼。笔者将类似的两款放到一组进行对比。<br/><br/>&nbsp;&nbsp;&nbsp;&nbsp;扫描组——Sniffer pro和Ethereal<br/>&nbsp;&nbsp;&nbsp;&nbsp;一般来说Sniffer pro和Ethereal的特点是对于网络的数据包进行监控，可以了解网络中流动的所有数据信息，分析数据包中的源地址目的地址以及端口号，甚至还可以对数据包中的内容进行分析，所以将他们放到一组比较合适。<br/><br/>&nbsp;&nbsp;&nbsp;&nbsp;通过笔者的详细比较，Sniffer pro和Ethereal都可以对网络中的所有数据进行捕获，可以了解网络的通讯信息，可以定义适当的过滤器对网络中的数据包进行筛选，两者旗鼓相当，不过Ethereal因为弟子众多，所以扩展插件更多，可以通过这些扩展插件实现一些更加高级的功能或者更加方便使用者分析网络，另外ethereal内置的一些流量分析工具要比sniffer pro强大得多。所以在功能比拼上ethereal小胜sniffer pro，同时sniffer pro也因为两败而被淘汰。<br/><br/>&nbsp;&nbsp;&nbsp;&nbsp;小结:ethereal艰难晋级， sniffer pro惨遭淘汰。<br/><br/>&nbsp;&nbsp;&nbsp;&nbsp;监视组——PRTG和MRTG<br/>PRTG和MRTG都是提供了对流经服务器或路由器各个端口的流量监控，他们只能够对流量信息的多少进行监视，并且根据输入输出的数据大小绘制相应的图表，经过反复对比发现异常现象。所以将他们放到一组比较合适。<br/><br/>&nbsp;&nbsp;&nbsp;&nbsp;PRTG和MRTG笔者都使用过，作为流量监控软件来说两者都是非常不错的，监控后绘制的图表都可以以网页的形式发布，方便我们这些网络管员在第一时间掌握企业内部流量情况。不过就个人感觉不管是使用效果还是配置过程MRTG都要大大输于PRTG。主要表现在以下几个方面。<br/><br/>&nbsp;&nbsp;&nbsp;&nbsp;首先PRTG安装很简单，使用也是图形化界面，而MRTG则要复杂得多，大部分指令都是基于命令行的；另外PRTG可以轻松实现用一台计算机监控多台服务器的功能，而MRTG要反复设置修改默认模板才行；PRTG的监控内容也比MRTG多，除了MRTG拥有的流量监控外PRTG还可以对CPU使用情况，内存资源，缓存信息等进行管理；最关键的是PRTG集成了页面发布工具，在监控完毕后不需要任何设置就可以通过网页的形式访问结果；而MRTG自己不带页面发布工具，需要我们自己安装IIS或Apache来将生成的报表页面发布出去。所以经过比较PRTG大胜MRTG。<br/><br/>&nbsp;&nbsp;&nbsp;&nbsp;小结——PRTG大胜晋级， MRTG受重伤无法继续比赛而被淘汰。<br/><br/>&nbsp;&nbsp;&nbsp;&nbsp;强中强再决斗<br/>&nbsp;&nbsp;&nbsp;&nbsp;Ethereal终于在最后的比拼中与PRTG相遇了，两者的优势完全不同，Ethereal以分析网络流量中数据包的内容见长，而PRTG则在统计数据包的数量占优，两者所实现的功能是不一样的。在这种情况下两者无法决一胜负。<br/><br/>&nbsp;&nbsp;&nbsp;&nbsp;对于我们这些中小企业的网络管理员来说应该学会使用上述两款软件，毕竟不管是分析网络流量中的数据包内容还是统计数据包的数量制作成网页进行再分析都是重要的，只有采取双管齐下两个软件一起使用的策略，才能让我们网络的故障在第一时间被发现并解决。这也是为什么当初ethereal与PRTG非要决一胜负的结果是同归于尽了，只有集两者功能于一身的功能更强大的软件才能够独占鳌头。<br/><br/>&nbsp;&nbsp;&nbsp;&nbsp;总结<br/>&nbsp;&nbsp;&nbsp;&nbsp;实际上正如本文所分析的那样，对于我们这些网络管理员来说并不一定非要抱着一款网络流量管理软件不放，必要时应该换换思路换换功能使用多款网络流量管理软件有效管理企业内网，发挥各个工具的独特优势，减少故障发生的机率，让我们可以对流经企业网络的数据包在微观（数据包内容）和宏观（数量统计）上均有一个清晰的了解。<br/>http://publish.it168.com/2006/1205/20061205009202.shtml
]]>
</description>
</item><item>
<link>http://www.qixiaomudong.cn/read.php?189</link>
<title><![CDATA[超级嗅探狗15天限制破解]]></title> 
<author>七小木东 &lt;admin@yourname.com&gt;</author>
<category><![CDATA[网络&amp;服务]]></category>
<pubDate>Wed, 12 Nov 2008 07:42:50 +0000</pubDate> 
<guid>http://www.qixiaomudong.cn/read.php?189</guid> 
<description>
<![CDATA[ 
	超级嗅探狗15天限制破解 <br/><br/>其实发现这个问题是半个月前了，文章也早就写好了，只是没有公开出来，设置成了私有文章！<br/><br/>用过这个东西的人应该了解，15天限制一到，改一系统时间，又能用了。可是这样改时间，根本不是办法。经常会导致卡巴斯基出错，还有其它等等的问题。网上找的超级嗅探狗的激活码，根本就是无效的，都是原公司的人在那里发布的广告。<br/><br/>我折腾了一晚，终于弄明白了，原理我不说为什么了，没什么好说的，高手看到了，也不要笑我多此一举，这么简单的操作还写BAT文件。操作是简单，发现问题的过程是挺累人的。<br/><br/>把下面的代码复制到记事本里，另存为bat文件！<br/><br/>echo off<br/><br/>net stop WFilterd<br/>rd bak /s/q<br/>md bak<br/>xcopy WFilter bak /e/i<br/>rd Wfilter /s/q<br/>ren bak WFilter<br/>net start WFilterd<br/>echo enjoy it!可继续试用15天！&nbsp;&nbsp;&nbsp;&nbsp; By - 人参乌龙茶 hi.ooolong.cn<br/>pause<br/><br/><br/>把bat文件放到超级嗅探狗的安装目录上一级，比如说，你的程序装在C:&#92;Program Files&#92;IMFirewall&#92;WFilter下，WFilter目录下有startsys.exe,webservd.exe,Device.cfg等文件。那么就是把这个bat文件放在C:&#92;Program Files&#92;IMFirewall目录下，一定要和WFilter是同级目录！即bat文件要放在startsys.exe,webservd.exe,Device.cfg等文件的上级目录！<br/><br/>双击运行，就OK啦，还是提示试用14天！只是单纯的改变天数限制，对于8台电脑的限制没有去做研究，以后了解了再说啦。<br/>
]]>
</description>
</item><item>
<link>http://www.qixiaomudong.cn/read.php?156</link>
<title><![CDATA[配置Apache服务器（三）]]></title> 
<author>七小木东 &lt;admin@yourname.com&gt;</author>
<category><![CDATA[网络&amp;服务]]></category>
<pubDate>Tue, 18 Jul 2006 06:38:51 +0000</pubDate> 
<guid>http://www.qixiaomudong.cn/read.php?156</guid> 
<description>
<![CDATA[ 
	通常连接时，服务器仅仅可以得到客户机的IP地址，如果要想获得客户机的 <br/>主机名，以进行日志记录和提供给 CGI程序使用，就需要使用这个 HostnameLookups 选项，将其设置为On打开DNS反查功能。但是这将使服务器对每次客户请求都进行DNS查询，增加了系统开销，使得反应变慢，因此缺省设置为使用Off关闭此选项。关闭选项之后，服务器就不会获得客户机的主机名，而只能使用IP地址来记录客户。 <br/><br/>ErrorLog /var/log/httpd-error.log <br/>LogLevel warn <br/>LogFormat &quot;%h %l %u %t &quot;%r&quot; %&gt;s %b &quot;%&#123;Referer&#125;i&quot; &quot;%&#123;User-Agent&#125; &quot;&quot; combined <br/>LogFormat &quot;%h %l %u %t &quot;%r&quot; %&gt;s %b&quot; common <br/>LogFormat &quot;%&#123;Referer&#125;i -&gt; %U&quot; referer <br/>LogFormat &quot;%&#123;User-agent&#125;i&quot; agent <br/>#CustomLog /var/log/httpd-access.log common <br/>#CustomLog /var/log/httpd-referer.log referer <br/>#CustomLog /var/log/httpd-agent.log agent <br/>CustomLog /var/log/httpd-access.log combined <br/><br/>　　这里定义了系统日志的形式，对于服务器错误记录， 由ErrorLog、 LogLevel 来定义不同的错误日志文件及其记录内容。 <br/>　　对于系统的访问日志，缺省使用CustomLog参数定义日志的位置，缺省使用 combined 参数指定将所有的访问日志放在一个文件中，然而也可以将不同种类的访问日志放在不同的日志记录文件中，这是通过在 CustomLog中指定不同的记录类型来完成的。common表示普通的对单页面请求访问记录，referer表示每个页面的引用记录，可以看出一个页面中包含的请求数，agent表示对客户机的类型记录，显然可以将现有的combined 定义的设置行注释掉，并使用common、referer和agent作为CustomLog的参数，来为不同种类的日志分别指定日志记录文件。 <br/>　　显然，LogFormat是用于定义不同类型的日志进行记录时使用的格式， 这里 <br/>使用了以%开头的宏定义，以记录不同的内容。 <br/>　　如果这些参数指定的文件使用的是相对路径，那么就是相对于ServerRoot的 <br/>路径。 <br/><br/>　　ServerSignature On <br/>　　一些情况下，例如当客户请求的网页并不存在时，服务器将产生错误文档， <br/>缺省情况下由于打开了 ServerSignature选项，错误文档的最后一行将包含服务器的名字、Apache的版本等信息。有的管理员更倾向于不对外显示这些信息，就 <br/>可以将这个参数设置为Off，或者设置为Email，最后一行将替换为对 ServerAdmin 的Email提示。 <br/><br/>Alias /icons/ &quot;/www/icons/&quot; <br/>Options Indexes MultiViews <br/>AllowOverride None <br/>Order allow,deny <br/>Allow from all <br/><br/>　　Alias参数用于将URL与服务器文件系统中的真实位置进行直接映射，一般的 <br/>文档将在DocumentRoot 中进行查询，然而使用Alias定义的路径将直接映射到相 <br/>应目录下，而不再到DocumentRoot 下面进行查询。因此Alias可以用来映射一些 <br/>公用文件的路径，例如保存了各种常用图标的icons路径。这样使得除了使用符号连接之外，文档根目录（DocumentRoot）外的目录也可以通过使用了Alias映射，提供给浏览器访问。 <br/>　　定义好映射的路径之后，应该需要使用Directory语句设置访问限制。 <br/><br/>ScriptAlias /cgi-bin/ &quot;/www/cgi-bin/&quot; <br/>AllowOverride None <br/>Options None <br/>Order allow,deny <br/>Allow from all <br/>　　ScriptAlias也是用于URL路径的映射，但与Alias的不同在于，ScriptAlias 是用于映射CGI程序的路径，这个路径下的文件都被定义为CGI程序，通过执行它们来竦媒峁怯煞衿髦苯臃祷仄淠谌荨Ｈ笔∏榭鱿翪GI程序使用cgi-bin目录作为虚拟路径。 <br/><br/>　　# Redirect old-URI new-URL <br/>　　Redirect参数是用来重写URL的，当浏览器访问服务器上的一个已经不存在的资源的时候，服务器返回给浏览器新的URL，告诉浏览器从该URL中获取资源。这主要用于原来存在于服务器上的文档，改变了位置之后，而又希望能使用老URL能访问到，以保持与以前的URL兼容。 <br/><br/>IndexOptions FancyIndexing <br/>AddIconByEncoding (CMP,/icons/compressed.gif) x-compress x-gzip <br/>AddIconByType (TXT,/icons/text.gif) text/* <br/>AddIconByType (IMG,/icons/image2.gif) image/* <br/>AddIconByType (SND,/icons/sound2.gif) audio/* <br/>AddIconByType (VID,/icons/movie.gif) video/* <br/>AddIcon /icons/binary.gif .bin .exe <br/>AddIcon /icons/binhex.gif .hqx <br/>AddIcon /icons/tar.gif .tar <br/>AddIcon /icons/world2.gif .wrl .wrl.gz .vrml .vrm .iv <br/>AddIcon /icons/compressed.gif .Z .z .tgz .gz .zip <br/>AddIcon /icons/a.gif .ps .ai .eps <br/>AddIcon /icons/layout.gif .html .shtml .htm .pdf <br/>AddIcon /icons/text.gif .txt <br/>AddIcon /icons/c.gif .c <br/>AddIcon /icons/p.gif .pl .py <br/>AddIcon /icons/f.gif .for <br/>AddIcon /icons/dvi.gif .dvi <br/>AddIcon /icons/uuencoded.gif .uu <br/>AddIcon /icons/script.gif .conf .sh .shar .csh .ksh .tcl <br/>AddIcon /icons/tex.gif .tex <br/>AddIcon /icons/bomb.gif core <br/>AddIcon /icons/back.gif .. <br/>AddIcon /icons/hand.right.gif README <br/>AddIcon /icons/folder.gif ^^DIRECTORY^^ <br/>AddIcon /icons/blank.gif ^^BLANKICON^^ <br/>DefaultIcon /icons/unknown.gif <br/>#AddDescription &quot;GZIP compressed document&quot; .gz <br/>#AddDescription &quot;tar archive&quot; .tar <br/>#AddDescription &quot;GZIP compressed tar archive&quot; .tgz <br/>ReadmeName README <br/>HeaderName HEADER <br/>IndexIgnore .??* *~ *# HEADER* README* RCS CVS *,v *,t <br/><br/>当一个HTTP请求的URL为一个目录的时候，服务器返回这个目录中的索引文件。但如果一个目录中不存在缺省的索引文件，并且该服务器又许可显示目录文件列表的时候，就会显示出这个目录中的文件列表，为了使得这个文件列表能具有可理解性，而不仅仅是一个简单的列表，就需要前面的这些设置参数。 <br/>　　如果使用了IndexOptions FancyIndexing选项，可以让服务器产生的目录列 <br/>表中针对各种不同类型的文档引用各种图标。而哪种文件使用哪种图标，则使用 <br/>下面的 AddIconByEncoding、AddIconByType以及AddIcon来定义，分别依据MIME 的编码、类型以及文件的后缀来判断使用何种图标。如果不能确定文档使用的图标，就使用 DefaultIcon定义的缺省图标。 <br/>　　同样，使用AddDescription可以为不同类型的文档加入不同的描述。并且， <br/>服务器还在目录下，查询使用ReadmeName和HeaderName定义的文件（自动加上 . <br/>html后缀，如果没有发现，再使用.txt后缀进行搜索），如果发现了这些文件， <br/>就在文件列表之前首先显示这些文件的内容，以使得普通目录列表具备更大的可 <br/>理解性。 <br/>　　IndexIgnore让服务器在列出文件列表时忽略相应的文件， 这里使用模式配 <br/>置的方式定义文件名。 <br/><br/>AddEncoding x-compress Z <br/>AddEncoding x-gzip gz <br/>　　AddEncoding用于告诉一些使用压缩的MIME类型，这样可以让浏览器进行解压缩操作。 <br/><br/>AddLanguage en .en <br/>AddLanguage fr .fr <br/>AddLanguage de .de <br/>AddLanguage da .da <br/>AddLanguage el .el <br/>AddLanguage it .it <br/>LanguagePriority en fr de <br/><br/>　　一个HTML文档可以同时具备多个语言的版本，如对于file1.html文档可以具 <br/>备file1.html.en、file1.html.fr 等不同的版本，每个语言后缀必须使用 AddLanguage进行定义。这样服务器可以针对不同国家的客户，通过与浏览器进行协商，发送不同的语言版本。而LanguagePriority 定义不同语言的优先级，以便在浏览器没有特殊要求时，按照顺序使用不同的语言版本回应对file1.html 的请求。 <br/>这个国际化的能力实际的应用并不多。 <br/><br/>#AddType application/x-httpd-php .phtml <br/>#AddType application/x-httpd-php-source .phps <br/>　AddType参数可以为特定后缀的文件指定MIME类型，这里的设置将覆盖 mime.types中的设置。 <br/><br/>　　#AddHandler cgi-script .cgi <br/>　　AddHandler是用于指定非静态的处理类型，用于定义文档为一个非静态的文 <br/>档类型，需要进行处理，再向浏览器返回处理结果。例如上面注释中的设置是将以.cgi结尾的文件设置为cgi-script类型，那么服务器将启动这个CGI程序以进行处理。如果需要在前面AliasScript定义的路径之外执行CGI程序，就需要使用这个参数进行设置，此后以.cgi结尾的文件将被当作CGI程序执行。 <br/><br/>　　在配置文件、这个目录中的.htaccess以及其上级目录的.htaccess中必须允许执行CGI程序，这需要通过Options ExecCGI参数设定。 <br/><br/>#AddType text/html .shtml <br/>#AddHandler server-parsed .shtml <br/>　　另外一种动态进行处理的类型为server-parsed，由服务器自身预先分析网页内的标记，将标记更改为正确的HTML标识。由于server-parsed需要对text/html 类型的文档进行处理，因此首先定义了对应的.shtml为text/html类型。 <br/>　　然而要支持SSI，还要首先要在配置文件（或.htaccess）中使用Options Includes允许该目录下的文档可以为SSI类型，或使用Options IncludesNOExec让执行普通的SSI标志，但不执行其中引用的外部程序。 <br/><br/>　　另一种指定server-parsed类型的方式为使用XBitBack设置选项，如果将 XBitHack设置为On，服务器将检查所有text/html类型的文档（包括.html后缀的文档），如果发现文件属性具备执行位 “x&quot;，则服务器就认为它是服务器分析文档，需要服务器进行处理。推荐使用AddHandler进行设置，而将XBitBack 设置为Off，因为使用XBitBack将对所有的HTML文档都执行额外的检查，降低了效率。 <br/><br/>#AddHandler send-as-is asis <br/>#AddHandler imap-file map <br/>#AddHandler type-map var <br/>上面被注释的AddHandler用于支持Apache服务器的asis、map和var处理能力 <br/>。 <br/><br/># Action media/type /cgi-script/location <br/># Action handler-name /cgi-script/location <br/>　因为Apache内部提供的处理功能有限，因此可以使用Action为服务器定义外 <br/>部程序作为可处理的动态文档类型，这些外部程序与标准CGI程序相同，都是对输入的数据处理之后，再输出不同MIME类型的结果。例如要定义一个对特殊后缀wri都先执行wri2txt进行处理操作，再返回结果的操作，可以使用： <br/><br/>Action windows-writer /bin/wri2txt <br/>AddHandler windows-writer wri <br/>　更进一步，可以直接使用Action定义对某个MIME类型预先进行处理操作，这 <br/>需要例子中第一种格式的Action 参数设置方式。这样设置方式就不再需要额外的AddHandler用来将处理操作与文件后缀联系起来，而是使用Action直接处理MIME类型的文件。但如果文档后缀没有正式的MIME类型，还需要先定义一个MIME类型。 <br/><br/>#MetaDir .web <br/>#MetaSuffix .meta <br/>　Meta信息是在文档发送给客户之前，预先发送给客户浏览器一些数据，因此 <br/>浏览器可以通过HEAD请求来访问这些Meta信息而不必真正通过GET来返回全部文档数据。服务器通常发送给浏览器的是一些标准的HTTP头信息，如果要想增加额外的信息，就需要使用MetaDir来定义Meta数据存放的目录， 而MetaS uffix用于指定包含Meta数据的文件后缀。 <br/><br/>#ErrorDocument 500 &quot;The server made a boo boo. <br/>#ErrorDocument 404 /missing.html <br/>#ErrorDocument 404 /cgi-bin/missing_handler.pl <br/>#ErrorDocument 402 <br/>http://some.other_server.com/subscription_info.html <br/>　　如果客户请求的网页不存在，或者没有访问权限等情况发生时，服务器将产 <br/>生一个错误代码，同时也将回应客户浏览器一个标识错误的网页。 <br/>ErrorDocument就用于设置当出现哪个错误时应该回应客户浏览器那些内容，ErrorDocument的第一个参数为错误的序号，第二个参数为回应的数据，可以为简单的文本，本地网页，本地CGI程序，以及远程主机上的网页。 <br/><br/>BrowserMatch &quot;Mozilla/2&quot; nokeepalive <br/>BrowserMatch &quot;MSIE 4.0b2;&quot; nokeepalive downgrade-1.0 force-response-1.0 <br/>BrowserMatch &quot;RealPlayer 4.0&quot; force-response-1.0 <br/>BrowserMatch &quot;Java/1.0&quot; force-response-1.0 <br/>BrowserMatch &quot;JDK/1.0&quot; force-response-1.0 <br/>　BrowserMatch命令为特定的客户程序，设置特殊的参数，以保证对老版本浏 <br/>览器的兼容性，并支持新浏览器的新特性。 <br/><br/># <br/># SetHandler server-status <br/># Order deny,allow <br/># Deny from all <br/># Allow from .your_domain.com <br/># <br/># <br/># SetHandler server-info <br/># Order deny,allow <br/># Deny from all <br/># Allow from .your_domain.com <br/># <br/># <br/># Deny from all <br/># ErrorDocument 403 http://phf.apache.org/phf_abuse_log.cgi <br/># <br/><br/>　　用于设置访问控制的设置主要是针对目录和文件进行设置的，然而也可以针 <br/>对不同的URL进行访问控制的设置，这样就不必担心ScriptAlias、Alias是否将路径设置到了受控制的目录之外了。针对URL进行控制的语句为 Location语句，这样不但能对服务器上的文件、CGI提供保护，此外，它还能保护不能找到对应文件，而是由服务器本身提供的特殊功能URL。http://servername/server-status用于报告当前Apache服务器的状态，http://servername/server-info用于报告Apache 服务器的统计信息。与此相关的设置还有ExtendedStatus参数，可以让服务器输出更详细的的报告。 <br/><br/># <br/>#ProxyRequests On <br/># <br/># <br/># Order deny,allow <br/># Deny from all <br/># Allow from .your_domain.com <br/># <br/>#ProxyVia On <br/>#CacheRoot &quot;/www/proxy&quot; <br/>#CacheSize 5 <br/>#CacheGcInterval 4 <br/>#CacheMaxExpire 24 <br/>#CacheLastModifiedFactor 0.1 <br/>#CacheDefaultExpire 1 <br/>#NoCache a_domain.com another_domain.edu joes.garage_sale.com <br/><br/># <br/><br/>　　Apache服务器本身就具备代理的功能，然而这要求加载入mod_proxy模块。这能使用IfModule语句进行判断，如果存在mod_proxy模块，就使用ProxyRequests打开代理支持。此后的Directory用于设置对Proxy功能的访问权限设置，以及用于设置缓冲的各个参数设置。 <br/><br/>虚拟主机 <br/>#NameVirtualHost 12.34.56.78:80 <br/>#NameVirtualHost 12.34.56.78 <br/># <br/># ServerAdmin webmaster@host.some_domain.com <br/># DocumentRoot /www/docs/host.some_domain.com <br/># ServerName host.some_domain.com <br/># ErrorLog logs/host.some_domain.com-error_log <br/># CustomLog logs/host.some_domain.com-access_log common <br/># <br/><br/># <br/><br/>　　缺省设置文件中的这些内容是用于设置命名基础的虚拟主机服务器时使用。 <br/>其中NameVirtualHost 来指定虚拟主机使用的IP地址，这个IP地址将对应多个 DNS名字，如果Apache使用了Listen 参数控制了多个端口，那么就可以在这里加上端口号以进一步进行区分对不同端口的不同连接请求。此后，使用 VirtualHost 语句，使用NameVirtualHost指定的IP地址作参数，对每个名字都定义对应的虚拟主机设置。 <br/>　　虚拟主机是在一台Web服务器上，可以为多个单独域名提供Web服务，并且每个域名都完全独立，包括具有完全独立的文档目录结构及设置，这样域名之间完全独立，不但使用每个域名访问到的内容完全独立，并且使用另一个域名无法访 <br/>问其他域名提供的网页内容。 <br/>　　虚拟主机的概念对于ISP来讲非常有用，因为虽然一个组织可以将自己的网页挂在具备其他域名的服务器上的下级往址上，但使用独立的域名和根网址更为正式，易为众人接受。传统上，必须自己设立一台服务器才能达到单独域名的目的，然而这需要维护一个单独的服务器，很多小单位缺乏足够的维护能力，更为合适的方式是租用别人维护的服务器。ISP也没有必要为一个机构提供一个单独的服务器，完全可以使用虚拟主机能力，使服务器为多个域名提供Web服务，而且不同的服务互不干扰，对外就表现为多个不同的服务器。 <br/>　　有两种设定虚拟主机的方式，一种是基于HTTP 1.0标准，需要一个具备多IP <br/>地址的服务器，再配置DNS 服务器，给每个IP地址以不同的域名，最后才能配置Apache的配置文件，使服务器对不同域名返回不同的Web文档。由于这需要使用额外的IP地址，对每个要提供服务的域名都要使用单独的IP地址，因此这种方式实现起来问题较多。 <br/>　　可以在一个网络界面上绑定多个IP地址，Linux下需要使用ifconfig的 alias参数来进行这个配置，但此时会影响网络性能。 <br/>　　HTTP 1.1标准在协议中规定了对浏览器和服务器通信时，服务器能够跟踪浏 <br/>览器请求的是哪个主机名字。因此可以利用这个新特性，使用更轻松的方式设定 <br/>虚拟主机。这种方式不需要额外的IP地址，但需要新版本的浏览器支持。这种方 <br/>式已经成为建立虚拟主机的标准方式。 <br/>　　要建立非IP基础的虚拟主机，多个域名是不可少的配置，因为每个域名就对 <br/>应一个要服务的虚拟主机。因此需要更改DNS服务器的配置，为服务器增加多个C NAME选项，如： <br/><br/>linux IN A 192.168.1.64 <br/>vhost1 IN CNAME linux <br/>vhost2 IN CNAME linux <br/><br/>　基本的设置选项都是为了linux主机设定的，如果要为vhost1和vhost2设定 <br/>虚拟主机，就要使用VirtualHost语句定义不同的选项，在语句中可以使用配置文件前面中的大部分选项，而可以重新定义几乎所有的针对服务器的设置。 <br/><br/>NameVirtualHost 192.168.1.64 <br/><br/>DocumentRoot /www/data <br/>ServerName linux.example.org.cn <br/><br/>DocumentRoot /vhost1 <br/>ServerName vhost1.example.org.cn <br/><br/>DocumentRoot /vhost2 <br/>ServerName vhost2.example.org.cn <br/><br/>　　这里需要注意的是，VirtualHost的参数地址一定要和NameVirtualHost定义 <br/>的地址相一致，必须保证所有的值严格一致，Apache服务器才承认这些定义是为这个IP地址定义的虚拟主机。 <br/>　　此外，定义过NameVirtualHost之后，那么对这个IP地址的访问都被区分不同的虚拟主机进行处理，而对其他IP地址的访问，例如127.0.0.1，才应用前面定义的缺省选项。<br/><br/><br/>
]]>
</description>
</item><item>
<link>http://www.qixiaomudong.cn/read.php?154</link>
<title><![CDATA[配置Apache服务器 （一）]]></title> 
<author>七小木东 &lt;admin@yourname.com&gt;</author>
<category><![CDATA[网络&amp;服务]]></category>
<pubDate>Tue, 18 Jul 2006 06:37:58 +0000</pubDate> 
<guid>http://www.qixiaomudong.cn/read.php?154</guid> 
<description>
<![CDATA[ 
	Apache服务器的设置文件位于/usr/local/apache/conf/目录下，传统上使用三个配置文件httpd.conf,access.conf和srm.conf，来配置Apache服务器的行为。 <br/><br/>httpd.conf提供了最基本的服务器配置，是对守护程序httpd如何运行的技术描述；srm.conf是服务器的资源映射文件，告诉服务器各种文件的MIME类型，以及如何支持这些文件；access.conf用于配置服务器的访问权限，控制不同用户和计算机的访问限制；这三个配置文件控制着服务器的各个方面的特性，因此为了正常运行服务器便需要设置好这三个文件。 <br/><br/>　　除了这三个设置文件之外，Apache还使用mime.types文件用于标识不同文件 <br/>对应的MIME类型， magic文件设置不同MIME类型文件的一些特殊标识，使得 Apache 服务器从文档后缀不能判断出文件的MIME 类型时，能通过文件内容中的这些特殊标记来判断文档的MIME类型。 <br/><br/>bash-2.02$ ls -l /usr/local/apache/conf <br/>total 100 <br/>-rw-r--r-- 1 root wheel 348 Apr 16 16:01 access.conf <br/>-rw-r--r-- 1 root wheel 348 Feb 13 13:33 access.conf.default <br/>-rw-r--r-- 1 root wheel 30331 May 26 08:55 httpd.conf <br/>-rw-r--r-- 1 root wheel 29953 Feb 13 13:33 httpd.conf.default <br/>-rw-r--r-- 1 root wheel 12441 Apr 19 15:42 magic <br/>-rw-r--r-- 1 root wheel 12441 Feb 13 13:33 magic.default <br/>-rw-r--r-- 1 root wheel 7334 Feb 13 13:33 mime.types <br/>-rw-r--r-- 1 root wheel 383 May 13 17:01 srm.conf <br/>-rw-r--r-- 1 root wheel 357 Feb 13 13:33 srm.conf.default <br/><br/>　　事实上当前版本的Apache将原来httpd.conf、srm.conf与access.conf中的所有配置参数均放在了一个配置文件httpd.conf中，只是为了与以前的版本兼容的原因（使用这三个设置文件的方式来源于NCSA-httpd），才使用三个配置文件。而提供的access.conf和srm.conf文件中没有具体的设置。 <br/><br/>　　由于在新版本的Apache中，所有的设置都被放在了httpd.conf中，因此只需要调整这个文件中的设置。以下使用缺省提供的httpd.conf为例，解释Apache服 <br/>务器的各个设置选项。然而不必因为它提供设置的参数太多而烦恼，基本上这些 <br/>参数都很明确，也可以不加改动运行Apache服务器。但如果需要调整Apache服务 <br/>器的性能，以及增加对某种特性的支持，就需要了解这些设置参数的含义。 <br/><br/>　　关于Apache服务器的性能，在Internet上存在很大的争议，基本上使用Apache的使用者几乎都不怀疑它的优秀性能，Apache也支撑了很多著名的高负载的网站，但是在商业机构的评测中，Apache往往得分不高。很多人指出，在这些评测中，商业Web服务器及其操作系统往往由其专业公司的工程师进行过性能调整，而Free 的操作系统和Web服务器往往就使用其缺省配置或仅仅作很小的更改。需要指出的是，除了操作系统的性能调整之外，Apache 服务器本身的缺省配置绝不是最优化和最高效的，而是要适应几乎所有种类操作系统、所有种类硬件下的设置，多平台的软件不可能为特定平台和特定硬件提供最优化的缺省配置。因此要使用Apache的时候，性能调整是必不可少的。 <br/><br/>　　在商业评测中忽略了的另一个事实是，评测时往往对不同种类的功能进行比 <br/>较，例如使用Apache的标准CGI 的性能与ISAPI，NSAPI等服务器端API比较，事实上Apache服务器与此可以比较的功能为modperl ，FastCGI，与ASP类似的功能为PHP等等，只不过由于Apache的开放模式，这些功能是由独立的开发组，作为独立的模块来实现的。但是在评测中，测试人员没有加入相应的模块评测其性能。 <br/><br/>HTTP守护进程的运行参数 <br/><br/>　　httpd.conf中首先定义了一些httpd守护进程运行时需要的参数，来决定其运行方式和运行环境。 <br/><br/>　　ServerType standalone <br/>　　ServerType定义服务器的启动方式，缺省值为独⒎绞絪tandalone，httpd <br/>服务器将由其本身启动，并驻留在主机中监视连接请求。在Linux下将在启动文件 /etc/rc.d/rc.local/init.d/apache中自动启动Web服务器，这种方式是推荐设置。 <br/>　　启动Apache服务器的另一种方式是inet方式，使用超级服务器inetd监视连接请求并启动服务器。当需要使用inetd启动方式时，便需要更改为这个设置，并屏蔽/etc/rc.d/rc.local/init.d/apache文件，以及更改/etc/inetd.conf并重起inetd，那么Apache就能从inetd中启动了。 <br/>　　两种方式的区别是独立方式是由服务器自身管理自己的启动进程，这样在启 <br/>动时能立即启动服务器的多个副本，每个副本都驻留在内存中，一有连接请求不需要生成子进程就可以立即进行处理，对于客户浏览器的请求反应更快，性能较 <br/>高。而 inetd方式要由inetd发现有连接请求后才去启动http服务器，由于inetd 要监听太多的端口，因此反应较慢、效率较低，但节约了没有连接请求时Web服务器占用的资源。因此inetd方式只用于偶尔被访问并且不要求访问速度的服务器上。事实上inetd方式不适合http的突发和多连接的特性，因为一个页面可能包含多个图象，而每个图象都会引起一个连接请求，即使虽然访问人数造成教少，但瞬间的连接请求并不少，这就受到inetd性能的限制，甚至会影响由inetd启动的其他服务器程序。 <br/><br/>　　ServerRoot &quot;/usr/local&quot; <br/>　　ServerRoot用于指定守护进程httpd的运行目录，httpd在启动之后将自动将 <br/>进程的当前目录改变为这个目录，因此如果设置文件中指定的文件或目录是相对 <br/>路径，那么真实路径就位于这个ServerRoot定义的路径之下。 <br/>　　由于httpd会经常进行并发的文件操作，就需要使用加锁的方式来保证文件操作不冲突，由于NFS文件系统在文件加锁方面能力有限，因此这个目录应该是本地磁盘文件系统，而不应该使用NFS文件系统。 <br/><br/>　　#LockFile /var/run/httpd.lock <br/>　　LockFile参数指定了httpd守护进程的加锁文件，一般不需要设置这个参数， Apache服务器将自动在ServerRoot下面的路径中进行操作。但如果ServerRoot为NFS文件系统，便需要使用这个参数指定本地文件系统中的路径。 <br/><br/>　　PidFile /var/run/httpd.pid <br/>　　PidFile指定的文件将记录httpd守护进程的进程号，由于httpd能自动复制其自身，因此系统中有多个httpd进程，但只有一个进程为最初启动的进程，它为其他进程的父进程，对这个进程发送信号将影响所有的httpd进程。PidFILE定义的文件中就记录httpd父进程的进程号。 <br/><br/>　　ScoreBoardFile /var/run/httpd.scoreboard <br/>　　httpd使用ScoreBoardFile来维护进程的内部数据，因此通常不需要改变这个参数，除非管理员想在一台计算机上运行几个Apache服务器，这时每个Apache服务器都需要独立的设置文件htt pd.conf，并使用不同的ScoreBoardFile。 <br/><br/>　　#ResourceConfig conf/srm.conf <br/>　　#AccessConfig conf/access.conf <br/>　　这两个参数ResourceConfig和AccessConfig，就用于和使用 srm.conf 和 access.conf 设置文件的老版本Apache兼容。如果没有兼容的需要，可以将对应的设置文件指定为/dev/null，这将表示不存在其他设置文件，而仅使用httpd.conf 一个文件来保存所有的设置选项。 <br/><br/>　　Timeout 300 <br/>　　Timeout定义客户程序和服务器连接的超时间隔，超过这个时间间隔（秒）后服务器将断开与客户机的连接。 <br/><br/>　　KeepAlive On <br/>　　在HTTP 1.0中，一次连接只能作传输一次HTTP请求，而KeepAlive参数用于支持HTTP 1.1版本的一次连接、多次传输功能，这样就可以在一次连接中传递多个HTTP请求。虽然只有较新的浏览器才支持这个功能，但还是打开使用这个选项。 <br/><br/>　　MaxKeepAliveRequests 100 <br/>　　MaxKeepAliveRequests为一次连接可以进行的HTTP请求的最大请求次数。将 <br/>其值设为0将支持在一次连接内进行无限次的传输请求。事实上没有客户程序在一次连接中请求太多的页面，通常达不到这个上限就完成连接了。 <br/><br/>　　KeepAliveTimeout 15 <br/>　　KeepAliveTimeout测试一次连接中的多次请求传输之间的时间，如果服务器 <br/>已经完成了一次请求，但一直没有接收到客户程序的下一次请求，在间隔超过了 <br/>这个参数设置的值之后，服务器就断开连接。 <br/><br/>　　MinSpareServers 5MaxSpareServers 10 <br/>　　在使用子进程处理HTTP请求的Web服务器上，由于要首先生成子进程才能处理客户的请求，因此反应时间就有一点延迟。但是，Apache服务器使用了一个特殊技术来摆脱这个问题，这就是预先生成多个空余的子进程驻留在系统中，一旦有请求出现，就立即使用这些空余的子进程进行处理，这样就不存在生成子进程造成的延迟了。在运行中随着客户请求的增多，启动的子进程会随之增多，但这些服务器副本在处理完一次HTTP请求之后并不立即退出，而是停留在计算机中等待下次请求。但是空余的子进程副本不能光增加不减少，太多的空余子进程没有处理任务，也占用服务器的处理能力，因此也要限制空余副本的数量，使其保持一个合适的数量，使得既能及时回应客户请求，又能减少不必要的进程数量。 <br/>　　因此就可以使用参数MinSpareServers来设置最少的空余子进程数量， 以及 <br/>使用参数MaxSpareServers 来限制最多的空闲子进程数量，多余的服务器进程副 <br/>本就会退出。根据服务器的实际情况来进行设置，如果服务器性能较高，并且也 <br/>被频繁访问，就应该增大这两个参数的设置。对于高负载的专业网站，这两个值 <br/>应该大致相同，并且等同于系统支持的最多服务器副本数量，也减少不必要的副 <br/>本退出。 <br/><br/>　　StartServers 5 <br/>　　StartServers参数就是用来设置httpd启动时启动的子进程副本数量，这个参数与上面定义的MinSpareServers和MaxSpareServers参数相关，都是用于启动空闲子进程以提高服务器的反应速度的。这个参数应该设置为前两个值之间的一个数值，小于MinSpareServers和大于MaxS pareServers都没有意义。 <br/><br/>　　MaxClients 150 <br/>　　在另一方面，服务器的能力毕竟是有限的，不可能同时处理无限多的连接请 <br/>求，因此参数Maxclient s就用于规定服务器支持的最多并发访问的客户数，如果这个值设置得过大，系统在繁忙时不得不在过多的进程之间进行切换来为太多的客户进行服务，这样对每个客户的反应就会减慢，并降低了整体的效率。如果这个值设置的较小，那么系统繁忙时就会拒绝一些客户的连接请求。当服务器性能较高时，就可以适当增加这个值的设置。对于专业网站，应该使用提高服务器效率的策略，因此这个参数不能超过硬件本身的限制，如果频繁出现拒绝访问现象，就说明需要升级服务器硬件了。对于非专业网站，不太在意对客户浏览器的反应速度，或者认为反应速度较慢也比拒绝连接好，就也可以略微超过硬件条件来设置这个参数。 <br/>　　这个参数限制了MinSpareServers和MaxSpareServers的设置，它们不应该大 <br/>于这个参数的设置。 <br/><br/>　　MaxRequestsPerChild 30 <br/>　　使用子进程的方式提供服务的Web服务，常用的方式是一个子进程为一次连接服务，这样造成的问题就是每次连接都需要生成、退出子进程的系统操作，使得这些额外的处理过程占据了计算机的大量处理能力。因此最好的方式是一个子进程可以为多次连接请求服务，这样就不需要这些生成、退出进程的系统消耗，Apache就采用了这样的方式，一次连接结束后，子进程并不退出，而是停留在系统中等待下一次服务请求，这样就极大的提高了性能。 <br/>　　但由于在处理过程中子进程要不断的申请和释放内存，次数多了就会造成一 <br/>些内存垃圾，就会影响系统的稳定性，并且影响系统资源的有效利用。因此在一个副本处理过一定次数的请求之后，就可以让这个子进程副本退出，再从原始的 <br/>httpd进程中重新复制一个干净的副本，这样就能提高系统的稳定性。这样，每 <br/>个子进程处理服务请求次数由MaxRe questPerChild定义。 缺省的设置值为30， <br/>这个值对于具备高稳定性特点的Linux系统来讲是过于保守的设置，可以设置为1000甚至更高，设置为0支持每个副本进行无限次的服务处理。 <br/><br/>　　#Listen 3000 <br/>　　#Listen 12.34.56.78:80 <br/>　　#BindAddress * <br/>　　Listen参数可以指定服务器除了监视标准的80端口之外，还监视其他端口的 <br/>HTTP请求。由于FreeBSD系统可以同时拥有多个IP地址，因此也可以指定服务器只听取对某个BindAddress&lt; /B&gt;的IP地址的HTTP请求。如果没有配置这一项，则服务器会回应对所有IP的请求。 <br/>　　即使使用了BindAddress参数，使得服务器只回应对一个IP地址的请求，但是通过使用扩展的Listen参数，仍然可以让HTTP守护进程回应对其他IP地址的请求。此时Listen参数的用法与上面的第二个例子相同。这种比较复杂的用法主要用于设置虚拟主机。此后可以用VirtualHost参数定义对不同IP的虚拟主机，然而这种用法是较早的HTTP 1.0标准中设置虚拟主机的方法，每针对一个虚拟主机就需要一个IP地址，实际上用处并不大。在HTTP 1.1中，增加了对单IP地址多域名的虚拟主机的支持，使得虚拟主机的设置具备更大的意义。 <br/><br/>LoadModule mime_magic_module libexec/apache/mod_mime_magic.so <br/>LoadModule info_module libexec/apache/mod_info.so <br/>LoadModule speling_module libexec/apache/mod_speling.so <br/>LoadModule proxy_module libexec/apache/libproxy.so <br/>LoadModule rewrite_module libexec/apache/mod_rewrite.so <br/>LoadModule anon_auth_module libexec/apache/mod_auth_anon.so <br/>LoadModule db_auth_module libexec/apache/mod_auth_db.so <br/>LoadModule digest_module libexec/apache/mod_digest.so <br/>LoadModule cern_meta_module libexec/apache/mod_cern_meta.so <br/>LoadModule expires_module libexec/apache/mod_expires.so <br/>LoadModule headers_module libexec/apache/mod_headers.so <br/>LoadModule usertrack_module libexec/apache/mod_usertrack.so <br/>LoadModule unique_id_module libexec/apache/mod_unique_id.so <br/><br/>ClearModuleList <br/>AddModule mod_env.c <br/>AddModule mod_log_config.c <br/>AddModule mod_mime_magic.c <br/>AddModule mod_mime.c <br/>AddModule mod_negotiation.c <br/>AddModule mod_status.c <br/>AddModule mod_info.c <br/>AddModule mod_include.c <br/>AddModule mod_autoindex.c <br/>AddModule mod_dir.c <br/>AddModule mod_cgi.c <br/>AddModule mod_asis.c <br/>AddModule mod_imap.c <br/>AddModule mod_actions.c <br/>AddModule mod_speling.c <br/>AddModule mod_userdir.c <br/>AddModule mod_proxy.c <br/>AddModule mod_alias.c <br/>AddModule mod_rewrite.c <br/>AddModule mod_access.c <br/>AddModule mod_auth.c <br/>AddModule mod_auth_anon.c <br/>AddModule mod_auth_db.c <br/>AddModule mod_digest.c <br/>AddModule mod_cern_meta.c <br/>AddModule mod_expires.c <br/>AddModule mod_headers.c <br/>AddModule mod_usertrack.c <br/>AddModule mod_unique_id.c <br/>AddModule mod_so.c <br/>AddModule mod_setenvif.c <br/><br/>Apache服务器的一个重要特性就是其模块化的结构，这不但表现为其能在编 <br/>译时能通过新的模块加入新的功能，还表现为其模块可以动态加载入http服务程 <br/>序中，而不必载入不需要的模块。使用Apache的动态加载模块只需要设置好Load Module和AddModule参数就可以了，这种特性就是Apache的 DSO（Dynamic Shared Object）特性，然而要想充分使用DSO特性仍然不是一个简单的事情，不适当的改动这里的设置就可能造成服务器不能正常启动。因此如果不是要增加或减少服务器提供的功能，就不要改动这里的设置。 <br/><br/>　　上面这些列表就显示了Linux下的缺省Apache服务器支持的模块，事实上很 <br/>多模块是没有必要的，不必要模块不会被载入内存。模块可以静态连接到Apache 服务器内部，也可以这样动态加载，将Apache的特性都编译成动态可加载模块是该Port的做法，而不是Apache的缺省做法，这样就以牺牲很小的性能的同时，带来极大的灵活性。 <br/><br/>　　因而动态可加载的能力还是对性能有轻微的影响，因此可以重新编译Apache，将自己所需要的功能编译进Apache 服务器内部，可以让系统显得更为干净，效率也有轻微的提高。通常仅仅为了这一个目的就重新编译Apache是没有必要的，如果需要增加其他特性而重新编译Apache，不妨在增加其他模块的同时将所有的模块都静态连接入Apache 服务器。有的使用者更喜欢动态加载模块，那么也不妨全部都使用动态加载模块。 <br/><br/>　　这些模块都被放置到/usr/local/apache/libexec/目录下， 每个模块对应Apache服务器的一个特性。详细解释每个模块的功能需要相当多的篇幅，其中比较重要的特性将在后面相应的地方中进行解释，而具体每个模块的功能及用法就需要查看Apache的文档。 <br/><br/>　　#ExtendedStatus On <br/>　　Apache服务器可以通过特殊的HTTP请求，来报告自身的运行状态，打开这个 <br/>ExtendedStatus 参数可以让服务器报告更全面的运行状态信息。 <br/>
]]>
</description>
</item><item>
<link>http://www.qixiaomudong.cn/read.php?155</link>
<title><![CDATA[ 配置Apache服务器（二）]]></title> 
<author>七小木东 &lt;admin@yourname.com&gt;</author>
<category><![CDATA[网络&amp;服务]]></category>
<pubDate>Tue, 18 Jul 2006 06:37:54 +0000</pubDate> 
<guid>http://www.qixiaomudong.cn/read.php?155</guid> 
<description>
<![CDATA[ 
	主服务器设置 <br/>　　Apache服务器需要各种设置，以定义自己使用各种参数以提供Web服务。对于使用虚拟主机的情况，除了在虚拟主机的定义项中覆盖的设置之外（有的设置必须重新定义），这里的设置也是虚拟主机的缺省设置。 <br/><br/>　　Port 80 <br/>　　Port定义了Standalone模式下httpd守护进程使用的端口，标准端口是80。这个选项只对于以独立方式启动的服务器才有效，对于以inetd方式启动的服务器则在inetd.conf中定义使用哪个端口。 <br/><br/>　　在Unix下使用80端口需要root权限，一些管理员为了安全的原因，认为 httpd 服务器不可能没有安全漏洞，因而更愿意使用普通用户的权限来启动服务器，这样就不能使用80端口及其他小于1024的端口，而必须使用大于 1024的端口来启动httpd，一般情况下8000或8080也是常用的端口。而Apache httpd服务器本身可以在以root权限打开80端口后再改变为普通用户身份进行运行，这样就减少了危险性，因而就不需要考虑这个安全问题。但是如果普通用户也想安装配置自己的WWW服务器，那么就不得不使用大于1024的端口。 <br/><br/>　　User nobody <br/>　　Group nogroup <br/>　　User和Group配置是Apache的安全保证，Apache在打开端口之后，就将其本身设置为这两个选项设置的用户和组权限进行运行，这样就降低了服务器的危险性。这个选项也只用于 Standalone模式，inetd模式在inetd.conf中指定运行Apache的用户。由于服务器必须执行改变身份的setuid()操作，因此初始进程应该具备root权限，如果是使用非root用户来启动Aapche，这个配置就不会发挥作用。 <br/>　　缺省设置为nobody和nogroup，这个用户和组在系统中不拥有文件，保证了服务器本身和由它启动的CGI 进程没有权限更改文件系统。在某些情况下，例如为了运行CGI与Unix交互，也需要让服务器来访问服务器上的文件，如果仍然使用nobody和nogroup，那么系统中将会出现属于nobody的文件，这对于系统安全是不利的，因为其他程序也会以nobody和nogroup的权限执行某些操作，就有可能访问这些nobody拥有的文件，造成安全问题。一般情况下要为Web服务设定一个特定的用户和组，同时在这里更改用户和组设置。 <br/><br/>　　ServerAdmin you@your.address <br/>　　配置文件中应该改变的也许只有ServerAdmin， 这一项用于配置WWW服务器的管理员的email地址，这将在HTTP服务出现错误的条件下返回给浏览器，以便让Web使用者和管理员联系，报告错误。习惯上使用服务器上的webmaster作为WWW服务器的管理员，通过邮件服务器的别名机制，将发送到webmaster 的电子邮件发送给真正的Web管理员。 <br/><br/>　　#ServerName new.host.name <br/>　　缺省情况下，并不需要指定这个ServerName参数，服务器将自动通过名字解 <br/>析过程来获得自己的名字，但如果服务器的名字解析有问题（通常为反向解析不 <br/>正确），或者没有正式的DNS名字，也可以在这里指定IP地址。当ServerName设 <br/>置不正确的时候，服务器不能正常启动。 <br/>　　通常一个Web服务器可以具有多个名字，客户浏览器可以使用所有这些名字或IP地址来访问这台服务器，但在没有定义虚拟主机的情况下，服务器总是以自己的正式名字回应浏览器。ServerName就定义了Web服务器自己承认的正式名字，例如一台服务器名字（在DNS中定义了A类型）为exmaple.org.cn，同时为了方便记忆还定义了一个别名（CNAME记录）为www.exmaple.org.cn，那么Apache自动解析得到的名字就为example.org.cn，这样不管客户浏览器使用哪个名字发送请求，服务器总是告诉客户程序自己为 example.org.cn。虽然这一般并不会造成什么问题，但是考虑到某一天服务器可能迁移到其他计算机上，而只想通过更改DNS中的www别名配置就完成迁移任务，所以不想让客户在其书签中使用 Linux 记录下这个服务器的地址，就必须使用ServerName来重新指定服务器的正式名字。 <br/><br/>　　DocumentRoot &quot;/www/&quot; <br/>　　DocumentRoot定义这个服务器对外发布的超文本文档存放的路径，客户程序请求的UR L就被映射为这个目录下的网页文件。这个目录下的子目录，以及使用 <br/>符号连接指出的文件和目录都能被浏览器访问，只是要在URL上使用同样的相对目录名。 <br/><br/>　　注意，符号连接虽然逻辑上位于根文档目录之下，但实际上可以位于计算机 <br/>上的任意目录中，因此可以使客户程序能访问那些根文档目录之外的目录，这在 <br/>增加了灵活性的同时但减少了安全性。Apache在目录的访问控制中提供了 FollowSymLinks选项来打开或关闭支持符号连接的特性。 <br/><br/>Options FollowSymLinks <br/>AllowOverride None <br/>　　Apache服务器可以针对目录进行文档的访问控制，然而访问控制可以通过两 <br/>种方式来实现，一个是在设置文件 httpd.conf（或access.conf）中针对每个目 <br/>录进行设置，另一个方法是在每个目录下设置访问控制文件，通常访问控制文件 <br/>名字为.htaccess。虽然使用这两个方式都能用于控制浏览器的访问，然而使用配置文件的方法要求每次改动后重新启动httpd守护进程，比较不灵活，因此主要用于配置服务器系统的整体安全控制策略，而使用每个目录下的.htaccess文件设置具体目录的访问控制更为灵活方便。 <br/>　　Directory语句就是用来定义目录的访问限制的，这里可以看出它的标准语法，为一个目录定义访问限制。上例的这个设置是针对系统的根目录进行的，设置了允许符号连接的选项FollowSymLinks ，以及使用AllowOverride None表示不允许这个目录下的访问控制文件来改变这里进行的配置，这也意味着不用查看这个目录下的相应访问控制文件。 <br/>　　由于Apache对一个目录的访问控制设置是能够被下一级目录继承的，因此对 <br/>根目录的设置将影响到它的下级目录。注意由于AllowOverride None的设置，使 <br/>得Apache服务器不需要查看根目录下的访问控制文件，也不需要查看以下各级目 <br/>录下的访问控制文件，直至httpd.conf（或access.conf ）中为某个目录指定了 <br/>允许Alloworride，即允许查看访问控制文件。由于Apache对目录访问控制是采用的继承方式，如果从根目录就允许查看访问控制文件，那么Apache就必须一级一级的查看访问控制文件，对系统性能会造成影响。而缺省关闭了根目录的这个特性，就使得Apache从httpd.conf中具体指定的目录向下搜寻，减少了搜寻的级数，增加了系统性能。因此对于系统根目录设置AllowOverride None不但对于系统安全有帮助，也有益于系统性能。 <br/><br/>Options Indexes FollowSymLinks <br/>AllowOverride None <br/>Order allow,deny <br/>Allow from all <br/>　　这里定义的是系统对外发布文档的目录的访问设置，设置不同的 AllowOverride选项，以定义配置文件中的目录设置和用户目录下的安全控制文件的关系，而Options选项用于定义该目录的特性。 <br/>　　配置文件和每个目录下的访问控制文件都可以设置访问限制，设置文件是由 <br/>管理员设置的，而每个目录下的访问控制文件是由目录的属主设置的，因此管理 <br/>员可以规定目录的属主是否能覆盖系统在设置文件中的设置，这就需要使用 啊AllowOverride参数进行设置，通常可以设置的值为： <br/>AllowOverride的设置 对每个目录访士刂莆募饔玫挠跋?<br/>All 缺省值，使访问控制文件可以覆盖系统配置 <br/>None 服务器忽略访问控制文件的设置 <br/>Options 允许访问控制文件中可以使用Options参数定义目录的选项 <br/>FileInfo 允许访问控制文件中可以使用AddType等参数设置 <br/>AuthConfig 允许访问控制文件使用AuthName，AuthType等针对每个用户的认证机制，这使目录属主能用口令和用户名来保护目录 Limit 允许对访问目录的客户机的IP地址和名字进行限制 <br/>　　每个目录具备一定属性，可以使用Options来控制这个目录下的一些访问特性设置，以下为常用的特性选项： <br/><br/>Options设置 服务器特性设置 <br/>All 所有的目录特性都有效，这是缺省状态 <br/>None 所有的目录特性都无效 <br/>FollowSymLinks 允许使用符号连接，这将使浏览器有可能访问文档根目录 （DocumentRoot）之外的文档 SymLinksIfOwnerMatch 只有符号连接的目的与符号连接本身为同一用户所拥有时，才允许访问，这个设置将增加一些安全性 <br/>ExecCGI 允许这个目录下可以执行CGI程序 Indexes 允许浏览器可以生成这个目录下所有文件的索引，使得在这个目录下没有index.html（或其他索引文件）时，能向浏览器发送这个目录下的文件列表 <br/>　此外，上例中还使用了Order、Allow、Deny等参数，这是Limit语句中用来根据浏览器的域名和 IP地址来控制访问的一种方式。其中Order定义处理Allow和Deny的顺序，而Allow、Deny则针对名字或IP进行访问控制设置，上例使用allowfrom all，表示允许所有的客户机访问这个目录，而不进行任何限制。 <br/><br/>　　UserDir public_html <br/>　　当在一台Linux上运行Apache服务器时，这台计算机上的所有用户都可以有自己的网页路径，形如 http://example.org.cn/~user，使用波浪符号加上用户名就可以映射到用户自己的网页目录上。映射目录为用户个人主目录下的一个子目录，其名字就用UseDir这个参数进行定义，缺省为public_html。如果不想为正式的用户提供网页服务，使用DISABLED作UserDir的参数即可。 <br/><br/># <br/># AllowOverride FileInfo AuthConfig Limit <br/># Options MultiViews Indexes SymLinksIfOwnerMatch IncludesNoExec <br/># <br/># Order allow,deny <br/># Allow from all <br/># <br/># <br/># Order deny,allow <br/># Deny from all <br/># <br/># <br/><br/>　　这里可以看到Directory的另一个用法，即可以通过简单的模式匹配方法，针对分布在不同目录下的子目录定义访问控制权限。这样设置就需要Apache服务器对每个路径进行额外的处理，因此就会降低服务器的性能，所以缺省情况并没有打开这种访问限制。 <br/><br/>　　这里可以看到另外一个语句Limit，Limit语句就是用来针对具体的请求方法来设定访问控制的，其中可以使用GET、POST等各种服务器支持的请求方法做Lim <br/>it的参数，来设定对不同请求方法的访问限制。一般可以打开对GET、POST、 HEAD三种请求方法，而屏蔽其他的请求方法，以增加安全性。Limit语句中，可以用Order 、Allow、Deny，Allow和Deny中可以使用匹配的方法针对域名和IP进行限制，只是对于域名是从后向前匹配，对于IP地址则从前向后匹配。 <br/><br/>　　DirectoryIndex index.html <br/>　　很多情况下，URL中并没有指定文档的名字，而只是给出了一个目录名。那么Apache服务器就自动返回这个目录下由DirectoryIndex定义的文件，当然可以指定多个文件名字，系统会这个目录下顺序搜索。当所有由DirectoryIndex指定的文件都不存在时，Apache服务器可以根据系统设置，生成这个目录下的所有文件列表，提供用户选择。此时该目录的访问控制选项中的Indexes选项（Options Indexes ）必须打开，以使得服务器能够生成目录列表，否则Apache将拒绝访问。 <br/><br/>　　AccessFileName .htaccess <br/>　　AccessFileName定义每个目录下的访问控制文件的文件名，缺省为.htaccess，可以通过更改这个文件，来改变不同目录的访问控制限制。 <br/><br/>Order allow,deny <br/>Deny from all <br/>　　除了可以针对目录进行访问控制之外，还可以根据文件来设置访问控制，这 <br/>就是File语句的任务。使用File 语句，不管文件处于哪个目录，只要名字匹配， 就必须接受相应的访问控制。这个语句对于系统安全比较重要，例如上例将屏蔽所有的使用者不能访问.htaccess文件，这样就避免.htaccess中的关键安全信息不至于被客户获取。 <br/><br/>　　#CacheNegotiatedDocs <br/>　　缺省情况下如果代理服务器和Apache服务器协商是否缓存其网页，Apache给 <br/>予否定的回答，不希望自己的网页被代理服务器缓存。然而这样就不能有效的利用代理服务器的优势，因此可以设置CacheNegotiatieDocs 选项， 使得代理服务器可以对网页进行缓存。然而即使不设置这个选项，有的代理服务器（或通过调整设置）也能对网页进行缓存。 <br/><br/>　　UseCanonicalName On <br/>　　打开这个UseCanonicalName是Web服务器的标准做法，因为客户发送的大部分请求都是对本服务器的引用，这样服务器就能使用ServerName和Port选项的设置内容构建完整的URL，并回应客户，使浏览器能得到规范的URL。如果将这个参数设置为Off，那么Apache将使用从客户请求中获得服务器的名字和端口值（支持HTTP 1.1的客户的请求中将会有这些信息），重新构建URL。 <br/><br/>　　TypesConfig /usr/local/apache/etc/mime.types <br/>　　TypeConfig用于设置保存有不同的MIME类型数据的文件名，在Linux下缺省设置为/usr/local/apache/etc/mime.types。 <br/><br/>　　DefaultType text/plain <br/>　　如果Web服务器不能决定一个文档的缺省类型，这通常表示文档使用了非标准的后缀，那么服务器就使用 DefaultType定义的MIME类型将文档发送给客户浏览器。这里的设置为text/plain，这样设置的问题是，如果服务器不能判断出文档的MIME，那么大部分情况下这个文档为一个二进制文档，但使用 text/plain格式发送回去，浏览器将在内部打开它而不会提示保存。因此建议将这个设置更改为 <br/>application/octet-stream，这样浏览器将提示用户进行保存。 <br/><br/>MIMEMagicFile /usr/local/apache/etc/magic <br/>　　除了从文件的后缀出发来判断文件的MIME类型之外，Apache还可以进一步分 <br/>析文件的一些特征，来判断文件的真实MIME类型。这个功能是由mod_mime_magic 模块实现的，它需要一个记录各种MIME类型特征的文件，以进行分析判断。上面的设置是一个条件语句，如果载入了这个模块，就必须指定相应的标志文件magic的位置。 <br/>
]]>
</description>
</item><item>
<link>http://www.qixiaomudong.cn/read.php?153</link>
<title><![CDATA[ Apache的配置详解]]></title> 
<author>七小木东 &lt;admin@yourname.com&gt;</author>
<category><![CDATA[网络&amp;服务]]></category>
<pubDate>Tue, 18 Jul 2006 06:35:13 +0000</pubDate> 
<guid>http://www.qixiaomudong.cn/read.php?153</guid> 
<description>
<![CDATA[ 
	Apache 的安装 <br/>通常来说，大家在安装时可以选择安装WEB SERVER ，并在INTERNET SERVICES中开启httpd这一相服务，这样系统就会自动的安装好apache，并且在系统第一次启动时启动httpd进程。在作好一些相应的配置后，在你的Xwindows环境下打开NETSCAPE，并在URL中填入localhost 或本机的IP地址，就会访问到apache的默认的页面。 <br/>如果说你没有安装WEB SERVER ，你可以重新安装并选择UPDATE，挑选apache的软件包安装到本机。当然，如果你想要安装最新的版本，可以到http://www.apache.org/ 网站上去下载最新的版本。如果是原文件，需要做一些相应的配置，然后编译原文件。如果是下载的二进制文件，就可以? <br/>苯优渲媚愕腤EB 服务器。至于编译原文件后和配置工作，我们暂时不提，先讲一讲在安装系统时就安装了apache 的情况下的配置过程。 <br/><br/>系统启动时会去启动httpd的服务，通常没有改过配置，httpd是起不来的。报的错误是ServerName not idnetify. 这是由于默认的配置没有指定服务的名称，这时你可以手动修改配置文件就可以了。具体的方法是： <br/><br/>1. 编辑 /etc/httpd/conf/ 目录下的httpd.conf文件，找到ServerName 这一项参数，这一行是被注释掉的（前面有＃的符号）。去掉前面的在&quot;#&quot;符号，并在后面填入你的hostname或IP地址。 <br/>2. 从新启动httpd进程。 <br/># /etc/rc.d/init.d/httpd stop <br/># /etc/rc.d/init.d/httpd start <br/>然后在Xwindows的界面下启动netscape，在URL中输入localhost或本机的IP地址，就可以看到apache 的一个页面了，从这个页面上你可以看一看关于apache的文档，学习一下他的有关内容。 <br/>这样一个主页的进程就配置好了，你将自己的主页拷贝到/home/httpd 目录中，再用netsacpe访问自己的机子，就会发现现在显示的是你自己的主页。你的主页就这样配置好了，别的机子只要在浏览器中填入你的IP地址就可以访问到你的主页了。如果你想要有域名的话，就得另外申请了。 <br/><br/>注意有时会有下面的情况：当你用NETSACPE访问了你的页面，这时，你重新更换默认目录中的内容，可是不管你如何在NETSCAPE中RELOAD都无法调入你新的内容。 <br/>产生这种情况的原因是NETSCAPE直接调用CACHE中的内容，没有真正的读取你文档的内容。解决的方法是在NETSCAPE中清空CACHE。具体的步骤如下： <br/><br/>1. 选择菜单中的Edit <br/>2. 在最下面选择 Preference <br/>3. 在左边的菜单中选择Advanced <br/>4. 在他的下拉菜单中选择Cache <br/>5. 点击 Clear Disk Cache 和 Clear Memory Cache 按钮。 <br/>这样清空apache的配置<br/><br/>Apache 的安装 <br/>通常来说，大家在安装时可以选择安装WEB SERVER ，并在INTERNET SERVICES中开启httpd这一相服务，这样系统就会自动的安装好apache，并且在系统第一次启动时启动httpd进程。在作好一些相应的配置后，在你的Xwindows环境下打开NETSCAPE，并在URL中填入localhost 或本机的IP地址，就会访问到apache的默认的页面。 <br/>如果说你没有安装WEB SERVER ，你可以重新安装并选择UPDATE，挑选apache的软件包安装到本机。当然，如果你想要安装最新的版本，可以到http://www.apache.org/ 网站上去下载最新的版本。如果是原文件，需要做一些相应的配置，然后编译原文件。如果是下载的二进制文件，就可以? <br/>苯优渲媚愕腤EB 服务器。至于编译原文件后和配置工作，我们暂时不提，先讲一讲在安装系统时就安装了apache 的情况下的配置过程。 <br/><br/>系统启动时会去启动httpd的服务，通常没有改过配置，httpd是起不来的。报的错误是ServerName not idnetify. 这是由于默认的配置没有指定服务的名称，这时你可以手动修改配置文件就可以了。具体的方法是： <br/><br/>1. 编辑 /etc/httpd/conf/ 目录下的httpd.conf文件，找到ServerName 这一项参数，这一行是被注释掉的（前面有＃的符号）。去掉前面的在&quot;#&quot;符号，并在后面填入你的hostname或IP地址。 <br/>2. 从新启动httpd进程。 <br/># /etc/rc.d/init.d/httpd stop <br/># /etc/rc.d/init.d/httpd start <br/>然后在Xwindows的界面下启动netscape，在URL中输入localhost或本机的IP地址，就可以看到apache 的一个页面了，从这个页面上你可以看一看关于apache的文档，学习一下他的有关内容。 <br/>这样一个主页的进程就配置好了，你将自己的主页拷贝到/home/httpd 目录中，再用netsacpe访问自己的机子，就会发现现在显示的是你自己的主页。你的主页就这样配置好了，别的机子只要在浏览器中填入你的IP地址就可以访问到你的主页了。如果你想要有域名的话，就得另外申请了。 <br/><br/>注意有时会有下面的情况：当你用NETSACPE访问了你的页面，这时，你重新更换默认目录中的内容，可是不管你如何在NETSCAPE中RELOAD都无法调入你新的内容。 <br/>产生这种情况的原因是NETSCAPE直接调用CACHE中的内容，没有真正的读取你文档的内容。解决的方法是在NETSCAPE中清空CACHE。具体的步骤如下： <br/><br/>1. 选择菜单中的Edit <br/>2. 在最下面选择 Preference <br/>3. 在左边的菜单中选择Advanced <br/>4. 在他的下拉菜单中选择Cache <br/>5. 点击 Clear Disk Cache 和 Clear Memory Cache 按钮。 <br/>这样清空了NETSCAPE 的CACHE后，就可以看到你更新后的页面了。 <br/><br/>http 的命令行参数 <br/>httpd 是一个可执行的文件，他的位置是在/usr/bin目录里。用这个命令我们可以手动的启动一个WWW的服务，这样使得别人可以访问你的主页。他的具体参数是： <br/>-d serverroot <br/>这个参数告诉httpd在何处去取启动时所需的配置参数，serverroot是存放配置文件的命令名。 <br/>-f config <br/>配置文件的名称，默认的值是httpd.conf。如果没有给定目录，就会到serverroot的目录中取找这个文件。 <br/>-X <br/>启动单进程模式。意思是不会产生任何子进程，也就是你只能看到index.html这一页，点击上面的链接都不会有反应。 <br/>-v <br/>显示httpd的版本号。 <br/>-l <br/>显示编译进httpd的模块名称。 <br/>-? <br/>显示httpd 的参数 <br/>了解了上面的参数后，我们就可以手动的启动一个服务： <br/>＃httpd 杁 /etc/httpd/mywebconf<br/>
]]>
</description>
</item>
</channel>
</rss>