httpd.conf中文说明

# 基于 NCSA 服务的配置文件。 

#这是Apache服务器主要配置文件。 
#它包含服务器的影响服务器运行的配置指令。 
#参见;http://httpd.apache.org/docs-2.0/;>;以取得关于这些指令的详细信息 

#不要只是简单的阅读这些指令信息而不去理解它。 
#这里只是做了简单的说明,如果你没有参考在线文件,你就会被警告。 

#这些配置指令被分为下面三个部分: 
#1. 控制整个Apache服务器行为的部分(即全局环境变量) 
#2. 定义主要或者默认服务参数的指令,也为所有虚拟主机提供默认的设置参数 
#3. 虚拟主机的设置参数 

#配置和日志文件名:如果你指定的文件名以“/”开始(win32下以“dirver:/”), 
#服务器将使用绝对路径,如果文件名不是以“/”开始的,那么它将把ServerRoot 
#的值附加在文件名的前面,例如,对“logs/foo.log",如果ServerRoot的值 
#为“/usr/local/apache2”,则该文件应为“/usr/local/apache2/logs/foo.log” 

##第一区:全局环境参数 

#这里设置的参数将影响整个Apache服务器的行为; 
#例如Apache能够处理的并发请求的数量等。 

#ServerRoot:指出服务器保存其配置、出错和日志文件等的根目录。 

#注意!如果你想要将它指定为NFS或其它网络上的位置, 
#请一定要去阅读与LockFile有关的文档(可能在 
#;http://httpd.apache.org/docs-2.0/mo...n.html#lockfile;>; )。 
#这将会使你自己也能解决很多问题。 

#路径的结尾不要添加斜线。 

ServerRoot "/usr/loacl/apache2" 

#串行访问的锁文件必须保存在本地磁盘上 



#LockFile logs/accept.lock 



#ScoreBoardFile:用来保存内部服务进程信息的文件。 
#如果未指明(默认),记分板(scoreboard)将被保存在一个匿名的共享内存段中, 
#并且它不能被第三方软件所使用。 
#如果指定了,要确保不能使用两个Apache使用同一个记分板文件, 
#这个记分板文件必须保存在本地磁盘上。 



#ScoreBoardFile logs/apache_runtime_status 



#PidFile:记录服务器启动进程号的文件。 


PidFile logs/httpd.pid 


#Timeout:接收和发送前超时秒数 

Timeout 300 

#KeepAlive:是否允许稳固的连接(每个连接有多个请求), 
#设为"Off"则停用。 

KeepAlive On 

#MaxKeepAliveRequests:在稳固连接期间允许的最大请求数, 
#设为0表示无限制接入。 
#我们推荐你将其设为一个较大的值,以便提高性能 
MaxKeepAliveRequests 100 

#KeepAliveTimeout:在同一个连接上从同一台客户上接收请求的秒数 

KeepAliveTimeout 15 
## 
##Server-Pool大小设定(针对MPM的) 
## 
# prefork MPM 
# StartServers:启动时服务器启动的进程数 
# MinSpareServers:保有的备用进程的最小数目 
# MaxSpareServers:保有的备用进程的最大数目 
# MaxClients:服务器允许启动的最大进程数 
# MaxRequestsPerChild:一个服务进程允许的最大请求数 

StartServers 5 
MinSpareServers 5 
MaxSpareServers 10 
MaxClients 150 
MaxRequestPerChild 0 

# worker MPM 
# StartServers:服务器启动时的服务进程数目 
# MaxClients:允许同时连接的最大用户数目 
# MinSpareThreads:保有的最小工作线程数目 
# MaxSpareThreads:允许保有的最大工作线程数目 
# ThreadsPerChild:每个服务进程中的工作线程常数 
# MaxRequestsPerChild:服务进程中允许的最大请求数目 

StartServers 2 
MaxClients 150 
MinSpareThreads 25 
MaxSpareThreads 75 
ThreadsPerChild 25 
MaxRequestsPerChild 0 

# perchild MPM 
# NumServers:服务进程数量 
# StartThreads:每个服务进程中的起始线程数量 
# MinSpareThreads:保有的最小线程数量 
# MaxSpareThreads:保有的最大线程数量 
# MaxThreadsPerChild:每个服务进程允许的最大线程数 
# MaxRequestsPerChild:每个服务进程允许连接的最大数量 

NumServers 5 
StartThreads 5 
MinSpareThreads 5 
MaxSpareThreads 10 
MaxThreadsPerChild 20 
MaxRequestsPerChild 0 

# WinNT MPM 
# ThreadsPerChild:服务进程中工作线程常数 
# MaxRequestsPerChild:服务进程允许的最大请求数 

ThreadsPerChild 250 
MaxRequestsPerChild 0 

# BeOS MPM 
# StartThreads:服务器启动时启动的线程数 
# MaxClients:可以启动的最大线程数(一个线程等于一个用户) 
# MaxRequestsPerThread:每个线程允许的最大请求数 

StartThreads 10 
MaxClients 50 
MaxRequestsPerThread 10000 

# NetWare MPM 
# ThreadStachSize:为每个工作线程分配的堆栈尺寸 
# StartThreads:服务器启动时启动的线程数 
# MinSpareThreads:用于处理实发请求的空闲线程数 
# MaxSpareThreads:空闲线程的最大数量 
# MaxThreads:在同一时间活动的最大线程数 
# MaxRequestPerChild:一个线程服务请求的最大数量, 
# 推荐将其设置为0,以实现无限制的接入 

ThreadStackSize 65536 
StartThreads 250 
MinSpareThreads 25 
MaxSpareThreads 250 
MaxThreads 1000 
MaxRequestPerChild 0 

# OS/2 MPM 
# StartServers:启动的服务进程数量 
# MinSpareThreads:每个进程允许的最小空闲线程 
# MaxSpareThreads:每个进程允许的最大空闲线程 
# MaxRequestsPerChild:每个服务进程允许的最大连接数 

StartServers 2 
MinSpareThreads 5 
MaxSpareThreads 10 
MaxRequestsPerChild 0 


# Listen:允许你绑定Apache服务到指定的IP地址和端口上,以取代默认值 
# 参见;指令 
# 使用如下命令使Apache只在指定的IP地址上监听, 
# 以防止它在IP地址0.0.0.0上监听 

# Listen 12.34.56.78:80 
Listen 80 

# 动态共享支持(DSO) 

# 为了能够使用那些以DSO模式编译的模块中的函数,你必须有相应的“LoadModule”行, 
# 因此,在这里包含了这些指令,以便能在使用它之前激活。 
# 那些静态编译的模块不需要在这里列出 (即以“httpd -l”列出的模块) 

# 示例: 
# LoadModule foo_module modules/mod_foo.so 


# ExtendedStatus:当调用“server-status”时,控制Apache是产生“全”状态 
# 信息(ExtendedStatus On),还是产生基本信息(ExtendedStatus Off)。 
# 默认为off 

# ExtendedStatus On 
### 第二区:“主”服务配置 

# 这一区建立被 “主” 服务器用的指令值,以回应那些不被 ; 
# 定义处理的任何请求。 
# 这些数值也提供默认值给后面定义的;容器。 
# 如果;中有定义,那么这里定义的指令值将被 
# ;中的定义所覆盖。 




# 如果你想使httpd以另外的用户或组来运行,你必须在开始时以root方式启动 
# 然后再将它切换为你想要使用的用户或组。 

# User/Group:运行httpd的用户和组 
# 在SCO (ODT3)上使用“User nouser”和“Group nogroup” 
# 在HPUX上,你可能不能以nobody身份使用共享内存,建议创建一个www用户。 
# 注意一些核心(kernel)在组ID大于60000时拒绝setgid(Group)或semctl(IPC_SET), 
#节在这些系统上不要使用“Group #-1”。 

User nobody 
Group #-1 



# ServerAdmin:你的邮件地址,当发生问题时Apache将向你发出邮件。 
# 作为一个出错文档,这个地址显示在server-generated页上, 
# 例如:[email]admin@your-domain.com[/email] 

ServerAdmin [email]kreny@sina.com[/email] 

# ServerName指定Apache用于识别自身的名字和端口号。 
# 通常这个值是自动指定的,但是我们推荐你显式的指定它以防止启动时出错 

# 如果你为你的主机指定了一个无效的DNS名,server-generated重定向将不能工作。 
# 参见UseCanonicalName指令 

# 如果你的主机没有注册DNS名,在这里键入它的IP地址 
# 无论如何,你必须使用它的IP地址来提供服务, 
# 这里使用一种容易理解的方式重定向服务 
ServerName  ;www.dalouis.com:80; 

# UseCanonicalName:决定Apache如何构造URLS和 SERVER_NAME 和 SERVER_PORT 的指令。 
# 当设置为 “Off”时,Apache会使用用户端提供的主机名和端口号。 
# 当设置为“On”,Apache会使用ServerName指令的值。 

UseCanonicalName Off 

# DocumentRoot:你的文档的根目录。默认情况下,所有的请求从这个目录进行应答。 
# 但是可以使用符号链接和别名来指向到其他的位置。 

DocumentRoot "/home/redhat/public_html" 

# Apache可以存取的每个目录都可以配置存取权限(包括它的子目录)。 

# 首先,我们配置一个高限制的特征。 
# 这将禁止访问文件系统所在的目录,并添加你希望允许访问的目录块。 
# 如下所示 

Order Deny,Allow 
Deny from all 


# 注意从这里开始你一定要明确地允许哪些特别的特征能够被使用。 
# - 所以,如果Apache没有象你所期待的那样工作的话, 
# 请检查你是否在下面明确的指定它可用。 


# 这将改变到你设置的DocumentRoot 



# Options:这个指令的值可以是“None”,“All”,或者下列选项的任意组合: 
# Indexes Includes FollowSymLinks SymLinksifOwnerMatch ExecCGI MultiViews 

# 注意,“MultiViews”必须被显式的指定,“Options All”不能为你提供这个特性。 

# 这个指令既复杂又重要,请参见 
#“ ;http://httpd.apache.org/docs-2.0/mo...〉酶?嗟男畔ⅰ?lt;/a>; 

Options FollowSymLinks 

# AllowOverride控制那些被放置在.htaccess文件中的指令。 
# 它可以是“All”,“None”,或者下列指令的组合: 
# Options FileInfo AuthConfig Limit 

AllowOverride None 

# 控制谁可以获得服务。 

Order allow,deny 
Allow from all 


# UserDir:指定在得到一个~user请求时将会添加到用户home目录后的目录名。 

UserDir public_html 
# 为防止在UserDir指令上的漏洞,对root用户设置 
# 象“./”这样的UserDir是非常有用的。 
# 如果你使用Apache 1.3或以上版本,我们强烈建议你 
# 在你的服务器配置文件中包含下面的行 
UserDir disabled root 

# 下面是一个使用UserDir指令使一个站点的目录具有只读属性的示例: 

# ; 
# AllowOverride FileInfo AuthConfig Limit Indexes 
# Options MultiViews Indexes SymLinksIfOwnerMatch IncludeNoExec 
# ; 
# Order allow,deny 
# Allow from all 
# ; 
# ; 
# Order deny,allow 
# Deny from all 
# ; 
# ; 

# DirectoryIndex:定义请求是一个目录时,Apache向用户提供服务的文件名 

# index.html.var文件(一个类型映象文件)用于提供一个文档处理列表, 
# 出于同样的目的,也可以使用MultiViews选项,但是它会非常慢。 

DirectoryIndex index.php index.html index.html.var 

# AccessFileName:在每个目录中查询为目录提供附加配置指令的文件的文件名。 
# 参见AllowOverride指令。 

AccessFileName .htaccess 

# 下面的行防止.htaccess和.htpasswd文件被Web客户查看。 


Order allow,deny 
Deny from all 


# Typeconfig:定义在哪里查询mime.types文件。 

TypeConfig conf/mime.types 

# DefaultType:定义当不能确定MIME类型时服务器提供的默认MIME类型。 
# 如果你的服务主要包含text或HTML文档,“text/plain”是一个好的选择; 
# 如果大多是二进制文档,诸如软件或图像,你应使用 
# “application/octer-stream”来防止浏览器象显示文本那样显示二进制文件。 

DefaultType text/plain 

# mod_mime_magic允许服务器从自己定义自己类型的文件中使用不同的线索(hints), 
# 这个MI广告gicFile指令定义hints定义所在的文件。 


MI广告gicFile conf/magic 


# HostnameLookups:指定记录用户端的名字还是IP地址,例如,本指令为on时 
# 记录主机名,如 ;www.apache.org;为off时记录IP地址,204.62.129.132。; 
# 默认值为off,这要比设为on好得多,因为如果设为on则每个用户端请求都将会 
# 至少造成对 nameserver 进行一次查询。 

HostnameLookups Off 

# EnableMMAP:控制是否进行内存转储(如果操作系统支持的话)。 
# 默认为on,如果你的服务器安装在网络文件系统上(NFS),请关闭它。 
# 在一些系统上,关闭它会提升系统性能(与文件系统类型无关); 
# 具体情况请参阅 ;http://httpd.apache.org/docs-2.0/mo...html#enablemmap; 

# EnableMMAP off 

# EnableSendfile:控制是否使用sendfile kernel支持发送文件 
# (如果操作系统支持的话)。默认为on,如果你的服务器安装在网络文件系统 
# (NFS)上,请你关闭它。 
# 参见 ;http://httpd.apache.org/docs-2.0/mo...#enablesendfile; 

# EnableSendfile off 

# ErrorLog:错误日志文件定位。 
# 如果你没有在;内定义ErrorLog指令,这个虚拟主机的错误信息 
# 将记录在这里。如果你在那儿定义了ErrorLog,这些错误信息将记录在你所 
# 定义的文件里,而不是这儿定义的文件。 

ErrorLog logs/error_log 

# LogLevel:控制记录在错误日志文件中的日志信息数量。 
# 可能的值包括:debug,info,notice,warn,error,crit,alert,emerg。 

LogLevel warn 

# 下面的指令为CustomLog指令定义格式别名。 

LogFormat "%h %l %u %t \"%r\" %>;s %b \"%{Referer}i\" \"%{User-Agent}i\"" combined 
LogFormat "%h %l %u %t \"%r\" %>;s %b" common 
LogFormat "%{Referer}i ->; %U" referer 
LogFormat "%{User-agent}i" agent 
# 你需要安装了mod_logio.c模块才能使用%I和%O。 
# LogFormat "%h %l %u %t \"%r\" %>;s %b \"%{Referer}i\" \"%{User-Agent}i\" %I %O" combinedio 

# 指定接入日志文件的定位和格式(一般日志格式)。 
# 如果你没有在;内定义这个指令,传输信息将记录在这里, 
# 如果你定义了这个指令,则记录在你指定的位置,而不是这儿定义的位置。 

CustomLog logs/access_log common 

# 如果你想要记录agent和referer信息,可以使用下面的指令 

# CustomLog logs/referer_log referer 
# CustomLog logs/agent_log agent 
#
# 如果你想要使用一个文件记录access,agent和referer信息, 
# 你可以如下定义这个指令: 

# CustomLog logs/access_log combined 

# ServerTokens 
# 这个指令定义包含在HTTP回应头中的信息类型。默认为“Full”, 
# 这表示在回应头中将包含模块中的操作系统类型和编译信息。 
# 可以设为列各值中的一个: 
# Full | OS | Minor | Minimal | Major | Prod 
# Full传达的信息最多,而Prod最少。 

ServerTokens Full 

# 随意的添加包含服务器版本和虚拟主机名字一行信息到server-generated输出页中 
# (内部错误文档,FTP目录列表,mod_status和mod_info输出等等,除了CGI错误 
# 或自定义的错误文档以外)。 
# 设为“EMail”将包含一个指向ServerAdmin的mailto:连接。 
# 可以为如下值:On | Off | EMail 

ServerSignature On 

# Aliases:在这时添加你需要的别名,格式如下: 
# Alias 别名 真实名 

# 注意,如果你在别名的未尾包含了“/”,那么在URL中也需要包含“/”。 
# 因此,“/icons”不是这个示例中的别名。 
# 如果别名中以“/”结尾,那么真实名也必须以“/”结尾, 
# 如果别名中省略了结尾的“/”,那么真实名也必须省略。 

# 我们使用别名“/icons/”来表示FancyIndexed目录列表,如果你不使用、 
# FancyIndexing,你可以注释掉它。 

# Alias /icons/ "/usr/local/apache2/icons/" 
# ; 
# Options Indexes MultiViews 
# AllowOverride None 
# Order allow,deny 
## Allow from all 
# ; 

# 这将改变ServerRoot/manual。这个别名提供了手册页所在的位置, 
# 即使你改变了你的DocumentRoot。如果你对有无手册页并不在意的话, 
# 你可以注释掉它。 

Alias /manual "/usr/loacl/apache2/manual" 

Options Indexes FollowSymLinks MultiViews IncludesNoExec 
AddOutputFilter Includes html 
Order allow,deny 
Allow from all 


# ScriptAlias:指定包含服务脚本的目录。 
# ScriptAliases 本质上与Aliases一样,除了这里的文档在请求时做为程序处理处理以外。 
# 尾部的“/”规则与Alias一样 

ScriptAlias /cgi-bin/ "/usr/loacl/apache2/cgi-bin/" 
# 这里是添加php 4支持的指令 
AddType application/x-httpd-php .php 
LoadModule php4_module modules/libphp4.so 


# 添加mod_cgid.c设置,mod_cgid提供使用cgid进行通讯的UNIX套接字的 
# 脚本接口路径。 

# Scriptsock logs/cgisock 


# 将"/usr/local/apache2/cgi-bin"改为你的ScriptAliased指定的CGI目录, 
# 如果你配置了的话。 


AllowOverride None 
Options None 
Order allow,deny 
Allow from all 


# Redirect允许你告诉客户端使用存在于服务器名字空间中的文档, 
# 而不是现在的,这帮助客户定位那些改变了位置的文档。 
# 例如: 
# Redirect permanent /foo  ;http://www.example.com/bar; 

# 控制server-generated目录列表显示的指令 


# IndexOptions:控制server-generated目录列表显示特征。 

IndexOptions FancyIndexing VersionSort 

# AddIcon* 指令告诉服务器不同扩展名的图象文件如何显示, 
# 只适用于FancyIndexed指令 

AddIconByEncoding (CMP,/icons/compressed.gif) x-compress x-gzip 
AddIconByType (TXT,/icons/text.gif) text
# 基于 NCSA 服务的配置文件。 

#这是Apache服务器主要配置文件。 
#它包含服务器的影响服务器运行的配置指令。 
#参见;http://httpd.ache.org/doc-2.0/;>;以取得关于这些指令的详细信息 

#不要只是简单的阅读这些指令信息而不去理解它。 
#这里只是做了简单的说明,如果你没有参考在线文件,你就会被警告。 

#这些配置指令被分为下面三个部分: 
#1. 控制整个Apache服务器行为的部分(即全局环境变量) 
#2. 定义主要或者默认服务参数的指令,也为所有虚拟主机提供默认的设置参数 
#3. 虚拟主机的设置参数 

#配置和日志文件名:如果你指定的文件名以“/”开始(win32下以“dirver:/”), 
#服务器将使用绝对路径,如果文件名不是以“/”开始的,那么它将把ServerRoot 
#的值附加在文件名的前面,例如,对“logs/foo.log",如果ServerRoot的值 
#为“/usr/local/apache2”,则该文件应为“/usr/local/apache2/logs/foo.log” 

##第一区:全局环境参数 

#这里设置的参数将影响整个Apache服务器的行为; 
#例如Apache能够处理的并发请求的数量等。 

#ServerRoot:指出服务器保存其配置、出错和日志文件等的根目录。 

#注意!如果你想要将它指定为NFS或其它网络上的位置, 
#请一定要去阅读与LockFile有关的文档(可能在 
#;http://httpd.apache.org/docs-2.0/mo...n.html#lockfile;>; )。 
#这将会使你自己也能解决很多问题。 

#路径的结尾不要添加斜线。 

ServerRoot "/usr/loacl/apache2" 

#串行访问的锁文件必须保存在本地磁盘上 



#LockFile logs/accept.lock 


#ScoreBoardFile:用来保存内部服务进程信息的文件。 
#如果未指明(默认),记分板(scoreboard)将被保存在一个匿名的共享内存段中, 
#并且它不能被第三方软件所使用。 
#如果指定了,要确保不能使用两个Apache使用同一个记分板文件, 
#这个记分板文件必须保存在本地磁盘上。 



#ScoreBoardFile logs/apache_runtime_status 



#PidFile:记录服务器启动进程号的文件。 


PidFile logs/httpd.pid 


#Timeout:接收和发送前超时秒数 

Timeout 300 

#KeepAlive:是否允许稳固的连接(每个连接有多个请求), 
#设为"Off"则停用。 

KeepAlive On 

#MaxKeepAliveRequests:在稳固连接期间允许的最大请求数, 
#设为0表示无限制接入。 
#我们推荐你将其设为一个较大的值,以便提高性能 
MaxKeepAliveRequests 100 

#KeepAliveTimeout:在同一个连接上从同一台客户上接收请求的秒数 

KeepAliveTimeout 15 
## 
##Server-Pool大小设定(针对MPM的) 
## 
# prefork MPM 
# StartServers:启动时服务器启动的进程数 
# MinSpareServers:保有的备用进程的最小数目 
# MaxSpareServers:保有的备用进程的最大数目 
# MaxClients:服务器允许启动的最大进程数 
# MaxRequestsPerChild:一个服务进程允许的最大请求数 

StartServers 5 
MinSpareServers 5 
MaxSpareServers 10 
MaxClients 150 
MaxRequestPerChild 0 

# worker MPM 
# StartServers:服务器启动时的服务进程数目 
# MaxClients:允许同时连接的最大用户数目 
# MinSpareThreads:保有的最小工作线程数目 
# MaxSpareThreads:允许保有的最大工作线程数目 
# ThreadsPerChild:每个服务进程中的工作线程常数 
# MaxRequestsPerChild:服务进程中允许的最大请求数目 

StartServers 2 
MaxClients 150 
MinSpareThreads 25 
MaxSpareThreads 75 
ThreadsPerChild 25 
MaxRequestsPerChild 0 

# perchild MPM 
# NumServers:服务进程数量 
# StartThreads:每个服务进程中的起始线程数量 
# MinSpareThreads:保有的最小线程数量 
# MaxSpareThreads:保有的最大线程数量 
# MaxThreadsPerChild:每个服务进程允许的最大线程数 
# MaxRequestsPerChild:每个服务进程允许连接的最大数量 

NumServers 5 
StartThreads 5 
MinSpareThreads 5 
MaxSpareThreads 10 
MaxThreadsPerChild 20 
MaxRequestsPerChild 0 

# WinNT MPM 
# ThreadsPerChild:服务进程中工作线程常数 
# MaxRequestsPerChild:服务进程允许的最大请求数 

ThreadsPerChild 250 
MaxRequestsPerChild 0 

# BeOS MPM 
# StartThreads:服务器启动时启动的线程数 
# MaxClients:可以启动的最大线程数(一个线程等于一个用户) 
# MaxRequestsPerThread:每个线程允许的最大请求数 

StartThreads 10 
MaxClients 50 
MaxRequestsPerThread 10000 

# NetWare MPM 
# ThreadStachSize:为每个工作线程分配的堆栈尺寸 
# StartThreads:服务器启动时启动的线程数 
# MinSpareThreads:用于处理实发请求的空闲线程数 
# MaxSpareThreads:空闲线程的最大数量 
# MaxThreads:在同一时间活动的最大线程数 
# MaxRequestPerChild:一个线程服务请求的最大数量, 
# 推荐将其设置为0,以实现无限制的接入 

ThreadStackSize 65536 
StartThreads 250 
MinSpareThreads 25 
MaxSpareThreads 250 
MaxThreads 1000 
MaxRequestPerChild 0 

# OS/2 MPM 
# StartServers:启动的服务进程数量 
# MinSpareThreads:每个进程允许的最小空闲线程 
# MaxSpareThreads:每个进程允许的最大空闲线程 
# MaxRequestsPerChild:每个服务进程允许的最大连接数 

StartServers 2 
MinSpareThreads 5 
MaxSpareThreads 10 
MaxRequestsPerChild 0 


# Listen:允许你绑定Apache服务到指定的IP地址和端口上,以取代默认值 
# 参见;指令 
# 使用如下命令使Apache只在指定的IP地址上监听, 
# 以防止它在IP地址0.0.0.0上监听 

# Listen 12.34.56.78:80 
Listen 80 

# 动态共享支持(DSO) 

# 为了能够使用那些以DSO模式编译的模块中的函数,你必须有相应的“LoadModule”行, 
# 因此,在这里包含了这些指令,以便能在使用它之前激活。 
# 那些静态编译的模块不需要在这里列出 (即以“httpd -l”列出的模块) 

# 示例: 
# LoadModule foo_module modules/mod_foo.so 


# ExtendedStatus:当调用“server-status”时,控制Apache是产生“全”状态 
# 信息(ExtendedStatus On),还是产生基本信息(ExtendedStatus Off)。 
# 默认为off 

# ExtendedStatus On 
### 第二区:“主”服务配置 

# 这一区建立被 “主” 服务器用的指令值,以回应那些不被 ; 
# 定义处理的任何请求。 
# 这些数值也提供默认值给后面定义的;容器。 
# 如果;中有定义,那么这里定义的指令值将被 
# ;中的定义所覆盖。 




# 如果你想使httpd以另外的用户或组来运行,你必须在开始时以root方式启动 
# 然后再将它切换为你想要使用的用户或组。 

# User/Group:运行httpd的用户和组 
# 在SCO (ODT3)上使用“User nouser”和“Group nogroup” 
# 在HPUX上,你可能不能以nobody身份使用共享内存,建议创建一个www用户。 
# 注意一些核心(kernel)在组ID大于60000时拒绝setgid(Group)或semctl(IPC_SET), 
#节在这些系统上不要使用“Group #-1”。 

User nobody 
Group #-1 



# ServerAdmin:你的邮件地址,当发生问题时Apache将向你发出邮件。 
# 作为一个出错文档,这个地址显示在server-generated页上, 
# 例如:[email]admin@your-domain.com[/email] 

ServerAdmin [email]kreny@sina.com[/email] 

# ServerName指定Apache用于识别自身的名字和端口号。 
# 通常这个值是自动指定的,但是我们推荐你显式的指定它以防止启动时出错 

# 如果你为你的主机指定了一个无效的DNS名,server-generated重定向将不能工作。 
# 参见UseCanonicalName指令 

# 如果你的主机没有注册DNS名,在这里键入它的IP地址 
# 无论如何,你必须使用它的IP地址来提供服务, 
# 这里使用一种容易理解的方式重定向服务 
ServerName  ;www.dalouis.com:80; 

# UseCanonicalName:决定Apache如何构造URLS和 SERVER_NAME 和 SERVER_PORT 的指令。 
# 当设置为 “Off”时,Apache会使用用户端提供的主机名和端口号。 
# 当设置为“On”,Apache会使用ServerName指令的值。 

UseCanonicalName Off 

# DocumentRoot:你的文档的根目录。默认情况下,所有的请求从这个目录进行应答。 
# 但是可以使用符号链接和别名来指向到其他的位置。 

DocumentRoot "/home/redhat/public_html" 

# Apache可以存取的每个目录都可以配置存取权限(包括它的子目录)。 

# 首先,我们配置一个高限制的特征。 
# 这将禁止访问文件系统所在的目录,并添加你希望允许访问的目录块。 
# 如下所示 

Order Deny,Allow 
Deny from all 


# 注意从这里开始你一定要明确地允许哪些特别的特征能够被使用。 
# - 所以,如果Apache没有象你所期待的那样工作的话, 
# 请检查你是否在下面明确的指定它可用。 


# 这将改变到你设置的DocumentRoot 



# Options:这个指令的值可以是“None”,“All”,或者下列选项的任意组合: 
# Indexes Includes FollowSymLinks SymLinksifOwnerMatch ExecCGI MultiViews 

# 注意,“MultiViews”必须被显式的指定,“Options All”不能为你提供这个特性。 

# 这个指令既复杂又重要,请参见 
#“ ;http://httpd.apache.org/docs-2.0/mo...〉酶?嗟男畔ⅰ?lt;/a>; 

Options FollowSymLinks 

# AllowOverride控制那些被放置在.htaccess文件中的指令。 
# 它可以是“All”,“None”,或者下列指令的组合: 
# Options FileInfo AuthConfig Limit 

AllowOverride None 

# 控制谁可以获得服务。 

Order allow,deny 
Allow from all 


# UserDir:指定在得到一个~user请求时将会添加到用户home目录后的目录名。 

UserDir public_html 
# 为防止在UserDir指令上的漏洞,对root用户设置 
# 象“./”这样的UserDir是非常有用的。 
# 如果你使用Apache 1.3或以上版本,我们强烈建议你 
# 在你的服务器配置文件中包含下面的行 
UserDir disabled root 

# 下面是一个使用UserDir指令使一个站点的目录具有只读属性的示例: 

# ; 
# AllowOverride FileInfo AuthConfig Limit Indexes 
# Options MultiViews Indexes SymLinksIfOwnerMatch IncludeNoExec 
# ; 
# Order allow,deny 
# Allow from all 
# ; 
# ; 
# Order deny,allow 
# Deny from all 
# ; 
# ; 

# DirectoryIndex:定义请求是一个目录时,Apache向用户提供服务的文件名 

# index.html.var文件(一个类型映象文件)用于提供一个文档处理列表, 
# 出于同样的目的,也可以使用MultiViews选项,但是它会非常慢。 

DirectoryIndex index.php index.html index.html.var 

# AccessFileName:在每个目录中查询为目录提供附加配置指令的文件的文件名。 
# 参见AllowOverride指令。 

AccessFileName .htaccess 

# 下面的行防止.htaccess和.htpasswd文件被Web客户查看。 


Order allow,deny 
Deny from all 


# Typeconfig:定义在哪里查询mime.types文件。 

TypeConfig conf/mime.types 

# DefaultType:定义当不能确定MIME类型时服务器提供的默认MIME类型。 
# 如果你的服务主要包含text或HTML文档,“text/plain”是一个好的选择; 
# 如果大多是二进制文档,诸如软件或图像,你应使用 
# “application/octer-stream”来防止浏览器象显示文本那样显示二进制文件。 

DefaultType text/plain 

# mod_mime_magic允许服务器从自己定义自己类型的文件中使用不同的线索(hints), 
# 这个MI广告gicFile指令定义hints定义所在的文件。 


MI广告gicFile conf/magic 


# HostnameLookups:指定记录用户端的名字还是IP地址,例如,本指令为on时 
# 记录主机名,如 ;www.apache.org;为off时记录IP地址,204.62.129.132。; 
# 默认值为off,这要比设为on好得多,因为如果设为on则每个用户端请求都将会 
# 至少造成对 nameserver 进行一次查询。 

HostnameLookups Off 

# EnableMMAP:控制是否进行内存转储(如果操作系统支持的话)。 
# 默认为on,如果你的服务器安装在网络文件系统上(NFS),请关闭它。 
# 在一些系统上,关闭它会提升系统性能(与文件系统类型无关); 
# 具体情况请参阅 ;http://httpd.apache.org/docs-2.0/mo...html#enablemmap; 

# EnableMMAP off 

# EnableSendfile:控制是否使用sendfile kernel支持发送文件 
# (如果操作系统支持的话)。默认为on,如果你的服务器安装在网络文件系统 
# (NFS)上,请你关闭它。 
# 参见 ;http://httpd.apache.org/docs-2.0/mo...#enablesendfile; 

# EnableSendfile off 

# ErrorLog:错误日志文件定位。 
# 如果你没有在;内定义ErrorLog指令,这个虚拟主机的错误信息 
# 将记录在这里。如果你在那儿定义了ErrorLog,这些错误信息将记录在你所 
# 定义的文件里,而不是这儿定义的文件。 

ErrorLog logs/error_log 

# LogLevel:控制记录在错误日志文件中的日志信息数量。 
# 可能的值包括:debug,info,notice,warn,error,crit,alert,emerg。 

LogLevel warn 

# 下面的指令为CustomLog指令定义格式别名。 

LogFormat "%h %l %u %t \"%r\" %>;s %b \"%{Referer}i\" \"%{User-Agent}i\"" combined 
LogFormat "%h %l %u %t \"%r\" %>;s %b" common 
LogFormat "%{Referer}i ->; %U" referer 
LogFormat "%{User-agent}i" agent 
# 你需要安装了mod_logio.c模块才能使用%I和%O。 
# LogFormat "%h %l %u %t \"%r\" %>;s %b \"%{Referer}i\" \"%{User-Agent}i\" %I %O" combinedio 

# 指定接入日志文件的定位和格式(一般日志格式)。 
# 如果你没有在;内定义这个指令,传输信息将记录在这里, 
# 如果你定义了这个指令,则记录在你指定的位置,而不是这儿定义的位置。 

CustomLog logs/access_log common 

# 如果你想要记录agent和referer信息,可以使用下面的指令 

# CustomLog logs/referer_log referer 
# CustomLog logs/agent_log agent 

# 如果你想要使用一个文件记录access,agent和referer信息, 
# 你可以如下定义这个指令: 

# CustomLog logs/access_log combined 

# ServerTokens 
# 这个指令定义包含在HTTP回应头中的信息类型。默认为“Full”, 
# 这表示在回应头中将包含模块中的操作系统类型和编译信息。 
# 可以设为列各值中的一个: 
# Full | OS | Minor | Minimal | Major | Prod 
# Full传达的信息最多,而Prod最少。 

ServerTokens Full 

# 随意的添加包含服务器版本和虚拟主机名字一行信息到server-generated输出页中 
# (内部错误文档,FTP目录列表,mod_status和mod_info输出等等,除了CGI错误 
# 或自定义的错误文档以外)。 
# 设为“EMail”将包含一个指向ServerAdmin的mailto:连接。 
# 可以为如下值:On | Off | EMail 

ServerSignature On 

# Aliases:在这时添加你需要的别名,格式如下: 
# Alias 别名 真实名 

# 注意,如果你在别名的未尾包含了“/”,那么在URL中也需要包含“/”。 
# 因此,“/icons”不是这个示例中的别名。 
# 如果别名中以“/”结尾,那么真实名也必须以“/”结尾, 
# 如果别名中省略了结尾的“/”,那么真实名也必须省略。 

# 我们使用别名“/icons/”来表示FancyIndexed目录列表,如果你不使用、 
# FancyIndexing,你可以注释掉它。 

# Alias /icons/ "/usr/local/apache2/icons/" 
# ; 
# Options Indexes MultiViews 
# AllowOverride None 
# Order allow,deny 
## Allow from all 
# ; 

# 这将改变ServerRoot/manual。这个别名提供了手册页所在的位置, 
# 即使你改变了你的DocumentRoot。如果你对有无手册页并不在意的话, 
# 你可以注释掉它。 

Alias /manual "/usr/loacl/apache2/manual" 

Options Indexes FollowSymLinks MultiViews IncludesNoExec 
AddOutputFilter Includes html 
Order allow,deny 
Allow from all 


# ScriptAlias:指定包含服务脚本的目录。 
# ScriptAliases 本质上与Aliases一样,除了这里的文档在请求时做为程序处理处理以外。 
# 尾部的“/”规则与Alias一样 

ScriptAlias /cgi-bin/ "/usr/loacl/apache2/cgi-bin/" 
# 这里是添加php 4支持的指令 
AddType application/x-httpd-php .php 
LoadModule php4_module modules/libphp4.so 


# 添加mod_cgid.c设置,mod_cgid提供使用cgid进行通讯的UNIX套接字的 
# 脚本接口路径。 

# Scriptsock logs/cgisock 


# 将"/usr/local/apache2/cgi-bin"改为你的ScriptAliased指定的CGI目录, 
# 如果你配置了的话。 


AllowOverride None 
Options None 

Order allow,deny 
Allow from all 


# Redirect允许你告诉客户端使用存在于服务器名字空间中的文档, 
# 而不是现在的,这帮助客户定位那些改变了位置的文档。 
# 例如: 
# Redirect permanent /foo  ;http://www.example.com/bar; 

# 控制server-generated目录列表显示的指令 


# IndexOptions:控制server-generated目录列表显示特征。 

IndexOptions FancyIndexing VersionSort 

# AddIcon* 指令告诉服务器不同扩展名的图象文件如何显示, 
# 只适用于FancyIndexed指令 

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

[  本帖最后由 HonestQiao 于 2005-12-23 22:45 编辑 ]



 niao5929 回复于:2004-12-28 11:09:51

好文


 jyhuang 回复于:2004-12-28 21:31:11

好文


 zf8783 回复于:2004-12-29 10:02:01

谢谢,好东西


 neeao 回复于:2004-12-30 14:03:12

好东西!谢了!


 puvttd 回复于:2004-12-30 14:54:56

顶一下...
好东西..


 bobar 回复于:2005-01-04 09:33:49

太好了,正在学习中


 liqiang1027 回复于:2005-01-04 11:42:11

真的是不错,谢谢,收了。


 linux981 回复于:2005-01-15 08:27:33

各朋友

    如果你们在使用的过程有成功的例子,也可以发贴分享分享呀!


 bwqing 回复于:2005-01-16 01:39:41

确实应该顶,又学到了.


 powiyou 回复于:2005-01-21 11:49:45

强烈需要的东西


 山东老头 回复于:2005-01-21 17:05:18

不错,谢谢楼主!


 erqie 回复于:2005-10-16 00:59:38

谢谢!


 sliny 回复于:2005-10-29 18:59:40

刚学习APACHE,谢谢!


 bugkill 回复于:2005-10-29 19:03:59

Apache2 的httpd.conf 翻译http://www.chinaunix.net 作者:casino19802002 发表于:2004-07-09 08:13:05 


基于NCSA 服务的配置文件。
这是Apache 服务器主要配置文件。
它包含服务器的影响服务器运行的配置指令。
参见; 以取得关于这些指令的详细信息
不要只是简单的阅读这些指令信息而不去理解它。
这里只是做了简单的说明,如果你没有参考在线文件,你就会被警告。
这些配置指令被分为下面三个部分:
#1. 控制整个Apache 服务器行为的部分(即全局环境变量)
#2. 定义主要或者默认服务参数的指令,也为所有虚拟主机提供默认的设置参数
#3. 虚拟主机的设置参数
配置和日志文件名:如果你指定的文件名以“/”开始(win32 下以“dirver:/”),
服务器将使用绝对路径,如果文件名不是以“/”开始的,那么它将把ServerRoot
的值附加在文件名的前面,例如,对“logs/foo.log" ,如果ServerRoot 的值
为“/usr/local/apache2”,则该文件应为“/usr/local/apache2/logs/foo.log”
##第一区:全局环境参数
这里设置的参数将影响整个Apache 服务器的行为; 例如Apache 能够处理的并发请求的数量等。
ServerRoot: 指出服务器保存其配置、出错和日志文件等的根目录。
注意!如果你想要将它指定为NFS 或其它网络上的位置,请一定要去阅读与LockFile 有关的文档(可能在;) 。这将会使你自己也能解决很多问题。
路径的结尾不要添加斜线。
erverRoot "/usr/loacl/apache2" 
串行访问的锁文件必须保存在本地磁盘上
IfModule !mpm_winnt.c>; IfModule !mpm_neware.c>; 
LockFile logs/accept.lock
/IfModule>; 
/IfModule>; 

ScoreBoardFile: 用来保存内部服务进程信息的文件。
如果未指明(默认),记分板(scoreboard)将被保存在一个匿名的共享内存段中,
并且它不能被第三方软件所使用。
如果指定了,要确保不能使用两个Apache 使用同一个记分板文件,
这个记分板文件必须保存在本地磁盘上。

IfModule !mpm_netware.c>;
IfModule !perchild.c>;
ScoreBoardFile logs/apache_runtime_status
IfModule>; 
IfModule>; 
PidFile: 记录服务器启动进程号的文件。
IfModule !mpm_neware.c>; dFile logs/httpd.pid /IfModule>; 
Timeout: 接收和发送前超时秒数
meout 300 
KeepAlive: 是否允许稳固的连接(每个连接有多个请求), 设为"Off" 则停用。
eepAlive On 
MaxKeepAliveRequests: 在稳固连接期间允许的最大请求数,设为0 表示无限制接入。我们推荐你将其设为一个较大的值,以便提高性能
MaxKeepAliveRequests 100 
KeepAliveTimeout: 在同一个连接上从同一台客户上接收请求的秒数
eepAliveTimeout 15 
## 
##Server-Pool 大小设定(针对MPM 的)
## 
prefork MPM StartServers: 启动时服务器启动的进程数MinSpareServers: 保有的备用进程的最小数目MaxSpareServers: 保有的备用进程的最大数目MaxClients: 服务器允许启动的最大进程数MaxRequestsPerChild: 一个服务进程允许的最大请求数IfModule prefork.c>; artServers 5 MinSpareServers 5 MaxSpareServers 10 MaxClients 150 MaxRequestPerChild 0 /IfModule>; 
worker MPM StartServers: 服务器启动时的服务进程数目MaxClients: 允许同时连接的最大用户数目
MinSpareThreads: 保有的最小工作线程数目MaxSpareThreads: 允许保有的最大工作线程数目ThreadsPerChild: 每个服务进程中的工作线程常数MaxRequestsPerChild: 服务进程中允许的最大请求数目IfModule worker.c>; artServers 2 MaxClients 150 MinSpareThreads 25 MaxSpareThreads 75 hreadsPerChild 25 MaxRequestsPerChild 0 /IfModule>; 
perchild MPM NumServers: 服务进程数量StartThreads: 每个服务进程中的起始线程数量MinSpareThreads: 保有的最小线程数量MaxSpareThreads: 保有的最大线程数量MaxThreadsPerChild: 每个服务进程允许的最大线程数MaxRequestsPerChild: 每个服务进程允许连接的最大数量IfModule perchild.c>; umServers 5 
artThreads 5 MinSpareThreads 5 MaxSpareThreads 10 MaxThreadsPerChild 20 MaxRequestsPerChild 0 /IfModule>; 
WinNT MPM ThreadsPerChild: 服务进程中工作线程常数MaxRequestsPerChild: 服务进程允许的最大请求数IfModule mpm_winnt.c>; hreadsPerChild 250 MaxRequestsPerChild 0 /IfModule>; 
BeOS MPM StartThreads: 服务器启动时启动的线程数MaxClients: 可以启动的最大线程数(一个线程等于一个用户) MaxRequestsPerThread: 每个线程允许的最大请求数IfModule beos.c>; artThreads 10 MaxClients 50 
MaxRequestsPerThread 10000 /IfModule>; 
NetWare MPM ThreadStachSize: 为每个工作线程分配的堆栈尺寸StartThreads: 服务器启动时启动的线程数MinSpareThreads: 用于处理实发请求的空闲线程数MaxSpareThreads: 空闲线程的最大数量MaxThreads: 在同一时间活动的最大线程数MaxRequestPerChild: 一个线程服务请求的最大数量,推荐将其设置为0,以实现无限制的接入
IfModule mpm_netware.c>; hreadStackSize 65536 artThreads 250 MinSpareThreads 25 MaxSpareThreads 250 MaxThreads 1000 MaxRequestPerChild 0 /IfModule>; 
OS/2 MPM StartServers: 启动的服务进程数量MinSpareThreads: 每个进程允许的最小空闲线程MaxSpareThreads: 每个进程允许的最大空闲线程MaxRequestsPerChild: 每个服务进程允许的最大连接数IfModule mpmt_os2.c>; artServers 2 MinSpareThreads 5 MaxSpareThreads 10 MaxRequestsPerChild 0 /IfModule>; 
Listen: 允许你绑定Apache 服务到指定的IP 地址和端口上,以取代默认值参见; 指令使用如下命令使Apache 只在指定的IP 地址上监听, 以防止它在IP 地址0.0.0.0 上监听
Listen 12.34.56.78:80 
listen 80 
动态共享支持(DSO) 为了能够使用那些以DSO 模式编译的模块中的函数,你必须有相应的“LoadModule”行,因此,在这里包含了这些指令,以便能在使用它之前激活。那些静态编译的模块不需要在这里列出 (即以“httpd -l”列出的模块) 
示例: 
LoadModule foo_module modules/mod_foo.so 
ExtendedStatus:当调用“server-status”时,控制Apache 是产生“全”状态信息(ExtendedStatus On),还是产生基本信息(ExtendedStatus Off )。默认为off 
ExtendedStatus On 
### 第二区:“主”服务配置
这一区建立被“主” 服务器用的指令值,以回应那些不被; 定义处理的任何请求。这些数值也提供默认值给后面定义的; 容器。如果; 中有定义,那么这里定义的指令值将被; 中的定义所覆盖。
IfModule !mpm_winnt.c>; IfModule !mpm_neware.c>; 
如果你想使httpd 以另外的用户或组来运行,你必须在开始时以root 方式启动
然后再将它切换为你想要使用的用户或组。

User/Group: 运行httpd 的用户和组
在SCO (ODT3) 上使用“User nouser”和“Group nogroup”
在HPUX 上,你可能不能以nobody 身份使用共享内存,建议创建一个www 用户。
注意一些核心(kernel )在组ID 大于60000 时拒绝setgid(Group) 或semctl(IPC_SET),
节在这些系统上不要使用“Group #-1”。

ser nobody roup #-1 /IfModule>; /IfModule>; 
ServerAdmin: 你的邮件地址,当发生问题时Apache 将向你发出邮件。作为一个出错文档,这个地址显示在server-generated 页上, 例如:admin@your-domain.com 
erverAdmin  kreny@sina.com 
ServerName 指定Apache 用于识别自身的名字和端口号。通常这个值是自动指定的,但是我们推荐你显式的指定它以防止启动时出错
如果你为你的主机指定了一个无效的DNS 名,server-generated 重定向将不能工作。参见UseCanonicalName 指令
如果你的主机没有注册DNS 名,在这里键入它的IP 地址无论如何,你必须使用它的IP 地址来提供服务,这里使用一种容易理解的方式重定向服务
erverName  www.dalouis.com:80 
UseCanonicalName: 决定Apache 如何构造URLS 和SERVER_NAME 和SERVER_PORT 的指令。当设置为“Off”时,Apache 会使用用户端提供的主机名和端口号。当设置为“On”,Apache 会使用ServerName 指令的值。seCanonicalName Off 
DocumentRoot: 你的文档的根目录。默认情况下,所有的请求从这个目录进行应答。但是可以使用符号链接和别名来指向到其他的位置。
ocumentRoot "/home/redhat/public_html" 
Apache 可以存取的每个目录都可以配置存取权限(包括它的子目录)。
首先,我们配置一个高限制的特征。
这将禁止访问文件系统所在的目录,并添加你希望允许访问的目录块。如下所示
Directory />; rder Deny,Allow eny from all /Directory>; 
注意从这里开始你一定要明确地允许哪些特别的特征能够被使用。-所以,如果Apache 没有象你所期待的那样工作的话, 请检查你是否在下面明确的指定它可用。
这将改变到你设置的DocumentRoot 
Directory "/home/redhat/public_html">; 
Options :这个指令的值可以是“None”,“All”,或者下列选项的任意组合: Indexes Includes FollowSymLinks SymLinksifOwnerMatch ExecCGI MultiViews 
注意,“MultiViews”必须被显式的指定,“Options All”不能为你提供这个特性。
这个指令既复杂又重要,请参见“http://httpd.apache.org/docs-2.0/mod/core.html#optioins”以取得更多的信息。
ptions FollowSymLinks 
AllowOverride 控制那些被放置在.htaccess 文件中的指令。
它可以是“All”,“None”,或者下列指令的组合: Options FileInfo AuthConfig Limit 
llowOverride None 
控制谁可以获得服务。
rder allow,deny llow from all 

UserDir: 指定在得到一个~user 请求时将会添加到用户home 目录后的目录名。
serDir public_html 
为防止在UserDir 指令上的漏洞,对root 用户设置象“./”这样的UserDir 是非常有用的。如果你使用Apache 1.3 或以上版本,我们强烈建议你在你的服务器配置文件中包含下面的行
serDir disabled root 
下面是一个使用UserDir 指令使一个站点的目录具有只读属性的示例: 
; AllowOverride FileInfo AuthConfig Limit Indexes Options MultiViews Indexes SymLinksIfOwnerMatch IncludeNoExec ; Order allow,deny Allow from all ; ; Order deny,allow Deny from all ; ; 
DirectoryIndex: 定义请求是一个目录时,Apache 向用户提供服务的文件名index.html.var 文件(一个类型映象文件)用于提供一个文档处理列表,出于同样的目的,也可以使用MultiViews 选项,但是它会非常慢。
irectoryIndex index.php index.html index.html.var 
AccessFileName: 在每个目录中查询为目录提供附加配置指令的文件的文件名。参见AllowOverride 指令。
ccessFileName .htaccess 
下面的行防止.htaccess 和.htpasswd 文件被Web 客户查看。
Files ~ "^\.ht">; rder allow,deny eny from all /Files>; 
Typeconfig: 定义在哪里查询mime.types 文件。
ypeConfig conf/mime.types 
DefaultType: 定义当不能确定MIME 类型时服务器提供的默认MIME 类型。如果你的服务主要包含text 或HTML 文档,“text/plain”是一个好的选择; 如果大多是二进制文档,诸如软件或图像,你应使用“application/octer-stream”来防止浏览器象显示文本那样显示二进制文件。
efaultType text/plain 
mod_mime_magic 允许服务器从自己定义自己类型的文件中使用不同的线索(hints), 这个MI广告gicFile 指令定义hints 定义所在的文件。
IfModule mod_mime_magic.c>; MI广告gicFile conf/magic /IfModule>; 
HostnameLookups :指定记录用户端的名字还是IP 地址,例如,本指令为on 时记录主机名,如www.apache.org;为off 时记录IP 地址,204.62.129.132 。默认值为off ,这要比设为on 好得多,因为如果设为on 则每个用户端请求都将会至少造成对nameserver 进行一次查询。
ostnameLookups Off 
EnableMMAP: 控制是否进行内存转储(如果操作系统支持的话)。默认为on,如果你的服务器安装在网络文件系统上(NFS),请关闭它。在一些系统上,关闭它会提升系统性能(与文件系统类型无关); 具体情况请参阅http://httpd.apache.org/docs-2.0/mod/core.html#enablemmap 
EnableMMAP off 
EnableSendfile: 控制是否使用sendfile kernel 支持发送文件(如果操作系统支持的话)。默认为on,如果你的服务器安装在网络文件系统(NFS)上,请你关闭它。参见http://httpd.apache.org/docs-2.0/mod/core.html#enablesendfile 
EnableSendfile off 
ErrorLog: 错误日志文件定位。如果你没有在; 内定义ErrorLog 指令,这个虚拟主机的错误信息将记录在这里。如果你在那儿定义了ErrorLog ,这些错误信息将记录在你所定义的文件里,而不是这儿定义的文件。
rrorLog logs/error_log 
LogLevel:控制记录在错误日志文件中的日志信息数量。可能的值包括:debug,info,notice,warn,error,crit,alert,emerg 。
ogLevel warn 
下面的指令为CustomLog 指令定义格式别名。
ogFormat "%h %l %u %t \"%r\" %>;s %b \"%{Referer}i\" \"%{User-Agent}i\"" combined ogFormat "%h %l %u %t \"%r\" %>;s %b" common ogFormat "%{Referer}i ->; %U" referer ogFormat "%{User-agent}i" agent 
你需要安装了mod_logio.c 模块才能使用%I 和%O。
LogFormat "%h %l %u %t \"%r\" %>;s %b \"%{Referer}i\" \"%{User-Agent}i\" %I %O" combinedio 
指定接入日志文件的定位和格式(一般日志格式)。如果你没有在; 内定义这个指令,传输信息将记录在这里,如果你定义了这个指令,则记录在你指定的位置,而不是这儿定义的位置。
ustomLog logs/access_log common 
如果你想要记录agent 和referer 信息,可以使用下面的指令
CustomLog logs/referer_log referer CustomLog logs/agent_log agent 
如果你想要使用一个文件记录access,agent 和referer 信息,你可以如下定义这个指令:
CustomLog logs/access_log combined 
ServerTokens 这个指令定义包含在HTTP 回应头中的信息类型。默认为“Full”, 这表示在回应头中将包含模块中的操作系统类型和编译信息。可以设为列各值中的一个:
Full | OS | Minor | Minimal | Major | Prod Full 传达的信息最多,而Prod 最少。
erverTokens Full 
随意的添加包含服务器版本和虚拟主机名字一行信息到server-generated 输出页中(内部错误文档,FTP 目录列表,mod_status 和mod_info 输出等等,除了CGI 错误或自定义的错误文档以外)。设为“EMail”将包含一个指向ServerAdmin 的mailto: 连接。可以为如下值:On | Off | EMail 
erverSignature On 
Aliases: 在这时添加你需要的别名,格式如下:Alias 别名真实名注意,如果你在别名的未尾包含了“/”,那么在URL 中也需要包含“/”。因此,“/icons”不是这个示例中的别名。如果别名中以“/”结尾,那么真实名也必须以“/”结尾, 如果别名中省略了结尾的“/”,那么真实名也必须省略。
我们使用别名“/icons/”来表示FancyIndexed 目录列表,如果你不使用、FancyIndexing ,你可以注释掉它。
Alias /icons/ "/usr/local/apache2/icons/" 
; Options Indexes MultiViews AllowOverride None Order allow,deny ## Allow from all ; 
这将改变ServerRoot/manual 。这个别名提供了手册页所在的位置,即使你改变了你的DocumentRoot 。如果你对有无手册页并不在意的话, 你可以注释掉它。
lias /manual "/usr/loacl/apache2/manual" 
Directory "/usr/local/apache2/manual">; ptions Indexes FollowSymLinks MultiViews IncludesNoExec ddOutputFilter Includes html rder allow,deny llow from all /Directory>; 
ScriptAlias: 指定包含服务脚本的目录。ScriptAliases 本质上与Aliases 一样,除了这里的文档在请求时做为程序处理处理以外。尾部的“/”规则与Alias 一样
criptAlias /cgi-bin/ "/usr/loacl/apache2/cgi-bin/" 
这里是添加php 4 支持的指令ddType application/x-httpd-php .php oadModule php4_module modules/libphp4.so 
IfModule mod_cgid.c>; 
添加mod_cgid.c 设置,mod_cgid 提供使用cgid 进行通讯的UNIX 套接字的脚本接口路径。
Scriptsock logs/cgisock /IfModule>; 
将"/usr/local/apache2/cgi-bin" 改为你的ScriptAliased 指定的CGI 目录, 如果你配置了的话。
Directory "/usr/local/apache2/cgi-bin">; llowOverride None ptions None rder allow,deny llow from all /Directory>; 
Redirect 允许你告诉客户端使用存在于服务器名字空间中的文档,
而不是现在的,这帮助客户定位那些改变了位置的文档。
例如:

Redirect permanent /foo http://www.example.com/bar 
控制server-generated 目录列表显示的指令
IndexOptions: 控制server-generated 目录列表显示特征。
dexOptions FancyIndexing VersionSort 
AddIcon* 指令告诉服务器不同扩展名的图象文件如何显示, 只适用于FancyIndexed 指令
ddIconByEncoding (CMP,/icons/compressed.gif) x-compress x-gzip
ddIconByType (TXT,/icons/text.gif) text/*
ddIconByType (IMG,/icons/image2.gif) image/*
ddIconByType (SND,/icons/sound2.gif) audio/*
ddIconByType (VID,/icons/movie.gif) video/*

ddIcon /icons/binary.gif .bin .exe
ddIcon /icons/binhex.gif .hqx

ddIcon /icons/tar.gif .tar ddIcon /icons/world2.gif .wrl .wrl.gz .vrml .vrm .iv ddIcon /icons/compressed.gif .Z .z .tgz .gz .zip ddIcon /icons/a.gif .ps .ai .eps ddIcon /icons/layout.gif .html .shtml .htm .pdf ddIcon /icons/text.gif .txt ddIcon /icons/c.gif .c ddIcon /icons/p.gif .pl .py ddIcon /icons/f.gif .for ddIcon /icons/dvi.gif .dvi ddIcon /icons/uuencoded.gif .uu ddIcon /icons/script.gif .conf .sh .shar .csh .ksh .tcl ddIcon /icons/tex.gif .tex 
ddIcon /icons
ddIcon /iconsddIcon /iconsddIcon /iconsddIcon /icons
/bomb.gif core

/back.gif ..
/hand.right.gif README
/folder.gif ^^DIRECTORY^^
/blank.gif ^^BLANKICON^^

DefaultIcon 为那些没有显式定义图标的文件提供处理
efaultIcon /icons/unknown.gif 
AddDescription 允许你在server-generated 索引后放置一个简短的说明。只对FancyIndexed 指令有效。格式:AddDescription " 说明" 文件名
AddDescription "GZIP compressed document" .gz AddDescription "tar archive" .tar AddDescription "GZIP compressed tar archive" .tgz 
ReadmeName 指定服务器默认查找的README 文件的名字,并添加到目录列表中
HeaderName 指定目录列表前缀文件的文件名ReadmeName README.html eaderName HEADER.html 
IndexIgnore 指定目录索引忽略并且不包含在列表中的文件名集合, 支持shell 类型的通配符。
dexIgnore .??* *~ *# HEADER* README* RCS CVS *,v *,t 
AddEncoding 允许你在信息传送中使用(Mosaic/X 2.1+) 解压缩信息,注意:不是所有的浏览器都支持这个选项。尽管名字相似,但是下列的指令与上面的FancyIndexing 定制指令不同。
ddEncoding x-compress Z ddEncoding x-gzip gz tgz 
DefaultLanguage 和AddLanguage 允许你指定文档的语言。这使你可以让用户用容易理解的语言浏览文档。
指定默认的语言,这意味着所有没有指定语言的包都将使用该语言。多数情况下,你也许并不想设置它,除非你确信这样做是正确的。通常,不使用确定的语言比使用错误的语言要好。
DefaultLanguage nl 
注意1:作为语言关键字的词缀毫无疑问是不能一样的--采用波兰文的文档(网络标准语言代码是pl)将希望使用“AddLanguage pl .po” 来避免与perl 脚本的一般词缀产生二义性。
注意2: 下面的例子举例说明在一些范例中语言的二字符缩写与它的国家的二字符缩写不相同,例如“Danmark/dk” 和“Danmark/da” 的比较. 
注意3: 在“ltz” 的情况下我们使用三字符词缀,违犯了RFC 的规定,运行中将修复它并使用RFC1766 标准取得参考数据。
Danish (da) -Dutch (nl) -English (en) -Estonian (et)
French (fr) -German (de) -Greek-Modern (el)
Italian (it) -Norwegian (no) -Norwegian Nynorsk (nn) -Korean (ko)
Portugese (pt) -Luxembourgeois* (ltz)
Spanish (es) -Swedish (sv) -Catalan (ca) -Czech(cz)
Polish (pl) -Brazilian Portuguese (pt-br) - Japanese (ja)
Russian (ru) -Croatian (hr)

ddLanguage da .dk
ddLanguage nl .nl
ddLanguage en .en
ddLanguage et .et
ddLanguage fr .fr

ddLanguage de .de ddLanguage he .he ddLanguage el .el ddLanguage it .it ddLanguage ja .ja ddLanguage pl .po ddLanguage ko .ko ddLanguage pt .pt ddLanguage nn .nn ddLanguage no .no ddLanguage pt-br .pt-br ddLanguage ltz .ltz ddLanguage ca .ca ddLanguage es .es ddLanguage sv .sv ddLanguage cz .cz ddLanguage ru .ru ddLanguage tw .tw ddLanguage zh-tw .tw ddLanguage hr .hr 
LanguagePriority 允许你在会话过程中优先使用一些语言。以优先次序递减的方式列出它们。我们或多或少地采用按字母排列顺序的方式排列它们。也许你想要改变这个顺序。
anguagePriority en da nl et fr de el it ja ko no pl pt pt-br ltz ca es sv tw 
ForceLanguagePriority 允许你为MULTIPLE CHOICES(Prefer)[ 在通讯的情况下] 或NOT ACCEPTABLE(Fallback)[ 没有可接受的语言匹配的情况]提供一个结果页。
orceLanguagePriority Prefer Fallback 
为发送出的所有页指定默认的字符集,这总是一个好主意,并且为你的web 站点的国际化打开了大门,这不正是你曾经想要的吗。同样地,指定默认字符集有一些小的损害,如一个使用iso-8859-1(latin1) 标准命令的页面,除非以别的方式指定例如你仅仅以显式方式声明它。也有一些与那些总是鼓励你使用默认字符集的javascropt 和URL 语法有关的浏览器安全原因。
AddDefaultCharset ISO-8859-1 ddDefaultCharse GB2312 
一般以文件扩展名的方式使用字符集。也许你想要避免与语言扩展发生碰撞,除非你在每次改变后都做了很好的测试。参见http://www.iana.org/assignments/character-sets 以取得字符集的名字列表和它们各自的RFCs 。
ddCharset ISO-8859-1 .iso8859-1 .latin1 ddCharset ISO-8859-2 .iso8859-2 .latin2 .cen ddCharset ISO-8859-3 .iso8859-3 .latin3 ddCharset ISO-8859-4 .iso8859-4 .latin4 ddCharset ISO-8859-5 .iso8859-5 .latin5 .cyr .iso-ru ddCharset ISO-8859-6 .iso8859-6 .latin6 .arb ddCharset ISO-8859-7 .iso8859-7 .latin7 .grk ddCharset ISO-8859-8 .iso8859-8 .latin8 .heb ddCharset ISO-8859-9 .iso8859-9 .latin9 .trk ddCharset ISO-2022-JP .iso2022-jp .jis ddCharset ISO-2022-KR .iso2022-kr .kis ddCharset ISO-2022-CN .iso2022-cn .cis ddCharset Big5 .Big5 .big5 
对于俄语,使用了多个字符集(如何使用主要依靠客户端): 
ddCharset WINDOWS-1251 .cp-1251 .win-1251 ddCharset CP866 .cp866 
ddCharset KOI8-r .koi8-r .koi8-ru ddCharset KOI8-ru .koi8-uk .ua ddCharset ISO-10646-UCS-2 .ucs2 ddCharset ISO-10646-UCS-4 .ucs4 ddCharset UTF-8 .utf8 
下面的字符集没有映射到一个特定的标准(iso) 上,但是它们在浏览器中被广泛的支持。注意那些大写字母。(它不应该,但是它是为兼容一些浏览器而做) 
参见http://www.iana.org/assianments/character-sets 以取得它们的列表。但是浏览器支持较少。
ddCharset GB2312 .gb2312 .gb ddCharset utf-7 .utf7 ddCharset utf-8 .utf8 ddCharset big5 .big5 .b5 ddCharset EUC-TW .euc-tw ddCharset EUC-JP .euc-jp ddCharset EUC-KR .euc-kr ddCharset shift_jis .sjis 
AddType 允许你为指定的文件类型添加或覆盖mime.types 文件中配置的MIME 
ddType application/x-tar .tgz ddType image/x-icon .ico 
AddHandler 允许你映射确定的文件扩展名到“handlers”:
与文件类型无关的行为。这既能编译到服务器中也可以添加到Action 指令
中(看下面)。
为了在ScriptAliased 指令指定的以外使用CGI 脚本:
(要使它可用,你还需要在Options 中添加“ExecCGI”。

AddHandler cgi-script .cgi 
对于那些包含他们自己的HTTP 头的文件
AddHandler send-as-is asis 
对于server-parsed imagemap 文件:
AddHandler imap-file map 
agemap 文件: 
AddHandler imap- 文件映像
对于类型映像:(转移资源)
这是默认的设定以允许Apache 的“It Worked”页能多种语言分发)。

ddHandler type-map var 
过滤器允许你在将它发送到客户端前进行处理。
为了在服务器端分析包含(SSI)的.shtml 文档: (要执行这个指令,你还需要在Options 指令中添加“Includes”。)
AddType text/html .shtml 
AddOutputFilter INCLUDES .shtml 
Action 让你定义当调用匹配的媒体文件时将要执行的脚本。这将减少那些经常使用的CGI 脚本的URL 路径名的重复输入。格式:Action media/type /cgi-script/location 格式:Action handler-name /cgi-script/location 
可配置的错误应答有三种风格:
1)plain text 2)local redirects 3) external redirects

一些示例: 
ErrorDocument 500 "The server made a boo boo."
ErrorDocument 404 /missing.html
ErrorDocument 404 "/cgi-bin/missing_handler.pl"
ErrorDocument 402 http://www.example.com/subscription_info.html

综合应用这些指令,我们可以创建一个国际化的出错应答。

我们使用Alias 来重定向任意/error/HTTP_;.html.var 应答到我们的多语言错误消息集合。使用正确的文本替代它。
通过加入下面的行,你就能够改变这些消息的显示,而不必改变HTTP_;.html.var 文件。
Alias /error/include/ "/your/include/path/" 
以将/usr/local/apache2/error/include/ 下的文件拷贝到/your/inclue/path/ 下开始,你可以创建你自己的文件集合,甚至是其于每个虚拟主机的。不管你的ServerSignature 如何设置,默认的包含文件将显示你的Aapche 版本号和你的ServerAdmin 邮件地址
国际化的错误文档需要mod_alias,mod_include 和mod_negotiation 三个模块。要激活它们,取消下面30 行的注释符号
Alias /error/ "/usr/local/apache2/error/"

;
AllowOverride None
Options IncludesNoExec

AddOutputFilter Includes html AddHandler type-map var Order allow,deny Allow from all LanguagePriority en de es fr it nl sv ForceLanguagePriority Prefer Fallback ; 
ErrorDocument 400 /error/HTTP_BAD_REQUEST.html.var ErrorDocument 401 /error/HTTP_UNAUTHORIZED.html.var ErrorDocument 403 /error.php 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_SERVICE_UNAVAILABLE.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 
下面的命令更改标准的HTTP 应答行为以处理己知的浏览器问题。
rowserMatch "Mozilla/2" nokeepalive rowserMatch "MSIE 4\.0b2;" nokeepalive downgrade-1.0 force-response-1.0 rowserMatch "RealPlayer 4\.0" force-response-1.0 rowserMatch "Java/1\.0" force-response-1.0 rowserMatch "JDK/1\.0" force-response-1.0 
下面命令关闭对那些没有尾部“/”的目录的非GET 请求的重定向, 这些命令修复了微软的采用DAV 方法不能正确处理重定向的WEB 文件夹的问题。Apple 下的DAV 文件系统和Gnome 下的VFS 对DAV 的支持也是采用这样的方法进行处理的。
rowserMatch "Microsoft Data Access Internet Publishing Provider" redirect-carefully rowserMatch "^WebDrive" redirect-carefully rowserMatch "^WebDAVFS/1.[012]" redirect-carefully rowserMatch "^gnome-vfs" redirect-carefully 
允许你使用URL:http://servername/server-status 来通过mod_status 生成并报告服务器状态信息。改变.example.com 为你自己的域名。
; SetHandler server-status Order deny,allow Deny from all Allow from .example.com ; 
允许使用URL:http://servername/server-info 来远程报告服务器配置信息
; SetHandler server-info Order deny,allow Deny from all Allow from .example.com 
。名域的自己为你”.example.com“变改)。支持mod_info.c 要需( 

代理服务器命令,去掉下面的行使代理服务可用。
; ProxyRequests On ; Order deny,allow Deny from all Allow from .example.com ; 
安装或关闭HTTP/1.1“通道”头处理。(“Full”添加服务器版本信息,“Block”移掉所有输出“通道”头信息。可以设为下面各选项之一:Off | On | Full | Block 
ProxyVia On 
最好为代理服务安装高速缓冲,去掉下面几行的注释符号: (没有CacheRoot 则不缓冲) 
CacheRoot "/usr/local/apache2/proxy" CacheSize 5 CacheGcInterval 4 CacheMaxExpire 24 CacheLastModifiedFactor 01 CacheDefaultExpire 1 NoCache a-domain.com another-domain.edu joes.garage-sale.com 

代理命令结束。
附加的特定模块配置。
IfModule mod_ssl.c>; clude conf/ssl.conf /IfModule>; 
## 第三区:虚拟主机
VirtualHost: 你可以通过设置虚拟主机容器以实现在你的主机上保有多个域名/主机名。大多数配置信息只使用基于名字的虚拟主机,因此服务器不必担心IP 地址的问题,下面的命令以*号代替虚拟主机名。
在你试着配置你的虚拟主机以前,请参见URL:http://httpd.apache.org/docs -2.0/vhosts/>; 以取得更多的信息。
你可以使用命令行选项“-S”来检验你的虚拟主机配置。
使用基于名字的虚拟主机。
NameVirtualHost * 
虚拟主机示例:
几乎所有的Apache 命令都可以在虚拟主机容器中使用。
第一个虚拟主机区是用于向服务名未知的请求进行应答的配置。

; 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 commom ; 
om http://www.linuxaid.com.cn/forum/

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/183473/viewspace-667814/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/183473/viewspace-667814/

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值