默认情况下,基本模块建议加载。
mod_actionsLoadModule actions_module modules/mod_actions.so
说明 | 基于媒体类型或请求方法,为执行CGI脚本而提供 |
状态 | 基本(B) |
模块名 | actions_module |
此模块有两个指令。
Action 指令让你可以在对特定MIME类型文件(p_w_picpath/gif )请求的时候运行CGI脚本。
Script 指令让你能够在使用特定请求方法(GET,POST,PUT等)的时候运行CGI脚本。
Action 指令例子:
# 所有对MIME类型"p_w_picpath/gif"的请求都将被指定的CGI脚本/cgi-bin/p_w_picpaths.cgi进行处理
------------------------------------------
Action p_w_picpath/gif /cgi-bin/p_w_picpaths.cgi
------------------------------------------
# 与AddHandler 合用
#所有对具有扩展名".xyz"的文件的请求都将被指定的CGI脚本/cgi-bin/program.cgi进行处理。
-----------------------------------------------
AddHandler my-file-type .xyz
Action my-file-type /cgi-bin/program.cgi
--------------------------------------------------------
语法 Action action-type cgi-script [virtual]
作用域: server config, virtual host, directory, .htaccess。
cgi-script是一个URL路径,指向一个已经被用ScriptAlias或AddHandler指令指定为CGI脚本的资源。
可选的virtual修饰词关闭了对所请求的文件是否真实存在的检查。用在希望将Action使用于虚拟位置的时候
Script 指令例子:
-----------------------------------------------
# <ISINDEX>风格的搜索
Script GET /cgi-bin/search
# A CGI PUT 处理器
Script PUT /~bob/put.cgi
-------------------------------------------------------------
语法 Script method cgi-script
作用域 server config, virtual host, directory
method名大小写敏感,因此 Script PUT 和 Script put 具有完全不同的结果。
对应GET方法的脚本只有在提供了查询参数的时候才会被调用(例如:"foo.html?hi")。
将PHP以CGI方式安装到APACHE要用到此模块
--------------------------------------
ScriptAlias /php/ "/usr/local/php/"
AddType application/x-httpd-php .php
Action application/x-httpd-php "/php/php-cgi.exe"
---------------------------------------
=================================================================
mod_aliasLoadModule alias_module modules/mod_alias.so
说明 | 提供从文件系统的不同部分到文档树的映射和URL重定向 |
状态 | 基本(B) |
模块名 | alias_module |
此模块提供以下指令:
Alias 指令
AliasMatch 指令
Redirect 指令
RedirectMatch 指令
RedirectPermanent 指令
RedirectTemp 指令
ScriptAlias 指令
ScriptAliasMatch 指令
Alias 指令例子:
-------------------------------------------------
<IfModule alias_module>
Alias /phpmyadmin/ "/ftp/phpMyAdmin/"
<Directory "/ftp/phpMyAdmin/">
AllowOverride AuthConfig
Order allow,deny
Allow from all
</Directory>
</IfModule>
---------------------------------------------------
对"http://myserver/phpmyadmin/index.php"的请求,将返回"/ftp/phpMyAdmin/index.php"文件。仅匹配完整路径。对于使用正则表达式的匹配,参见AliasMatch指令。
语法 Alias URL-path file-path|directory-path
作用域 server config, virtual host
ScriptAlias 指令例子:
---------------------------------------------------------
<VirtualHost *:80>
DocumentRoot /var/www
ScriptAlias /cgi-bin/ /usr/lib/cgi-bin/
<Directory "/usr/lib/cgi-bin">
AllowOverride None
Options +ExecCGI -MultiViews +SymLinksIfOwnerMatch
Order allow,deny
Allow from all
</Directory>
Alias /doc/ "/usr/share/doc/"
<Directory "/usr/share/doc/">
Options Indexes MultiViews FollowSymLinks
AllowOverride None
Order deny,allow
Deny from all
Allow from 127.0.0.0/255.0.0.0 ::1/128
</Directory>
Alias /pics "/exports/flv12"
<Directory "/exports/flv12">
Options Indexes
AllowOverride AuthConfig FileInfo
Order allow,deny
Allow from all
</Directory>
</VirtualHost>
---------------------------------------------------
语法 ScriptAlias URL-path file-path|directory-path
作用域 server config, virtual host
ScriptAlias指令的行为与Alias指令相同,但同时它又标明此目录中含有应该由cgi-script处理器处理的CGI脚本。
=========================================================
mod_asisLoadModule asis_module modules/mod_asis.so
说明 | 发送自己包含HTTP头内容的文件 |
状态 | 基本(B) |
模块名 | asis_module |
send-as-is: 直接发送,不增加 HTTP 头。任何带有".asis"扩展名的文件的内容会被Apache原样发往客户端。
用法:
在httpd.conf里启用
-------------------------------
AddHandler send-as-is asis
-------------------------------------
此语句将MIME-type httpd/send-as-is指定给文件扩展名.asis.
用ASIS文件来重定向到另一个页面。
在主机的目录中添加index.asis
-----------------------------------------------------
DirectoryIndex index.asis index.html index.htm
--------------------------------------------------------
index.asis 的内容:
--------------------------------------------------
Status: 301 Now where did I leave that URL
Location: http://www.lowlife.org
Content-type: text/html
<HTML>
<HEAD>
<TITLE>Moved to http://www.lowlife.org</TITLE>
</HEAD>
<BODY>
This site has moved to http://www.lowlife.org
</BODY>
</HTML>
---------------------------------------------------------
注意:
1 "Status:"是必须的头;此数据应该是3位数字的HTTP应答码,跟随一段文字信息。
2 服务器总会在送给客户端的资料里加上"Date:"和"Server:"头,所以这两个头不应该包含在这个文件里。
3 服务器不会加上通常都会加上的"Last-Modified:"头。
===============================================================
mod_auth_basicLoadModule auth_basic_module modules/mod_auth_basic.so
说明 | 使用基本认证 |
状态 | 基本(B) |
模块名 | auth_basic_module |
mod_auth_basic 提供以下指令:
1 AuthBasicAuthoritative 指令 仅仅在将mod_auth_basic和未使用AuthBasicProvider进行配置的第三方模块联合使用的时候才需设置为off
2 AuthBasicProvider 指令 设置了该区域的(基本)认证支持者(Provider)。默认的file支持者由mod_authn_file模块实现。
此模块使用HTTP基本认证,在认证支持模块的帮助下查找用户名和密码,从而进行访问控制。通常至少需要和一个认证支持模块(如mod_authn_file)和一个授权支持模块(如mod_authz_user)一起使用。
能够提供认证支持者(Provider)的模块如下:
mod_authn_dbm,
mod_authn_file,
mod_authn_dbd,
mod_authnz_ldap 。
用户认证技术:
当访问一些网站的某些资源时,浏览器弹出一个对话框,要求输入用户名和密码来获取对资源的访问权。
mod_auth模块用存储在文本文件中的用户名、组名和密码来实现认证。
例子:
---------------------------------------------------------------
1 对/usr/local/apache/htdocs/members目录启用用户认证
<Directory /usr/local/apache/htdocs/members>
Options Indexes FollowSymLinks
allowoverride authconfig
order allow,deny
allow from all
</Directory>
其中,allowoverride authconfig一行表示允许对/usr/local/apache/htdocs/members目录下的文件进行用户认证。
2.在限制访问的目录/usr/local/apache/htdocs/members下建立一个文件.htaccess,其内容如下:
----------------------------------
AuthName \"会员区\"
AuthType basic
AuthBasicProvider file
AuthUserFile/usr/local/apache/members.txt
require valid-user
--------------------------------------------
文件.htaccess中常用的配置命令有以下几个:
1)AuthName命令:指定认证区域名称。区域名称是在提示要求认证的对话框中显示给用户的。
2)AuthType命令:指定认证类型。在HTTP1.0中,只有一种认证类型:basic。在HTTP1.1中有几种认证类型,如MD5。
3)AuthUserFile命令:指定一个包含用户名和密码的文本文件,每行一对。
4)AuthGroupFile命令:指定包含用户组清单和这些组的成员清单的文本文件。
5)require命令:指定哪些用户或组才能被授权访问。如:
require user user1 user2 (只有用户user1和user2可以访问)
require group managers (只有组managers中成员可以访问)
require valid-user (在AuthUserFile指定的文件中任何用户都可以访问)
3.利用Apache附带的程序htpasswd,生成包含用户名和密码的文本文件:/usr/local/apache/members.txt,每行内容格式为“用户名:密码”。
#cd /usr/local/apache/bin
#htpasswd -bc ../members.txt user1 1234
#htpasswd -b ../members.txt user2 5678
4. 允许组用户。需用3步骤添加单个用户
#vi /usr/local/apache/.htgroup
---------------------------
asb_readers:user1 user2
-----------------------------
修改.htaccess文件
-----------------------
AuthName \"会员区\"
AuthType basic
AuthBasicProvider file
AuthUserFile /usr/local/apache/members.txt
AuthGroupFile /usr/local/apache/.htgroup
require group asb_reader
--------------------------------------------
文本文件members.txt含有两个用户:user1,口令为1234;user2,口令为5678。注意,不要将此文本文件存放在Web文档的目录树中,以免被用户下载。
将用户密码保存在数据库中参照http://www.jb51.net/article/18319.htm
================================================================
mod_authn_alias mod_authn_anon mod_authn_dbd mod_authn_dbm mod_authn_default mod_authn_file mod_authnz_ldapLoadModule authn_alias_module modules/mod_authn_alias.so
LoadModule authn_anon_module modules/mod_authn_anon.so
LoadModule authn_dbd_module modules/mod_authn_dbd.so
LoadModule authn_dbm_module modules/mod_authn_dbm.so
LoadModule authn_default_module modules/mod_authn_default.so
LoadModule authn_file_module modules/mod_authn_file.so
LoadModule authnz_ldap_module modules/mod_authnz_ldap.so
以上七个都是扩展模块,为mod_auth提供认证支持。
mod_authn_alias 基于实际认证支持者创建扩展的认证支持者,并为它起一个别名以便于引用
mod_authn_anon 提供匿名用户认证支持
mod_authn_dbd 使用SQL数据库为认证提供支持
mod_authn_dbm 使用DBM数据库为认证提供支持
mod_authn_defaultLoadModule authn_default_module modules/mod_authn_default.so
说明 | 在未正确配置认证模块的情况下简单拒绝一切认证信息 |
状态 | 基本(B) |
模块名 | authn_default_module |
该模块是一个失败补救(fallback)模块,它在未正确配置认证模块(比如mod_auth_basic)的情况下默认不使用用户认证。
mod_authn_default 提供以下指令:
AuthDefaultAuthoritative 指令
将AuthDefaultAuthoritative明确设置为 Off 将允许将认证操作交由更底层的(在modules.c文件中定义的)模块来处理。通常并不存在更底层的模块,因为mod_authn_default已经被定义为非常底层的模块了。因此最好将AuthDefaultAuthoritative保持其默认值(On)。
mod_authn_fileLoadModule authn_file_module modules/mod_authn_file.so
说明 | 使用纯文本文件为认证提供支持 |
状态 | 基本(B) |
模块名 | authn_file_module |
该模块为认证前端mod_auth_basic)使用纯文本文件进行用户认证提供支持。使用mod_auth_basic的时候,可以通过在AuthBasicProvider指令中使用file值调用该模块。
mod_uathn_file 提供以下指令:
AuthUserFile 指令 设定一个纯文本文件的名称,其中包含用于认证的用户名/密码的列表,文件的路径如果不是绝对路径(也就是说,如果不是以斜杠开始的),则是相对于ServerRoot的相对路径。
==================================================================
mod_authz_dbm mod_authz_default mod_authz_groupfile mod_authz_host mod_authz_owner mod_authz_userLoadModule authz_dbm_module modules/mod_authz_dbm.so
LoadModule authz_default_module modules/mod_authz_default.so
LoadModule authz_groupfile_module modules/mod_authz_groupfile.so
LoadModule authz_host_module modules/mod_authz_host.so
LoadModule authz_owner_module modules/mod_authz_owner.so
LoadModule authz_user_module modules/mod_authz_user.so
以上6个模块为mod_auth提供授权支持。
mod_authz_default
说明 | 在未正确配置授权支持模块的情况下简单拒绝一切授权请求 |
状态 | 基本(B) |
模块名 | authz_default_module |
该模块是失败补救(fallback)模块,它在未正确配置授权支持模块(比如mod_authz_user或mod_authz_groupfile)的情况下简单拒绝一切授权请求。
mod_authz_default 提供以下指令:
AuthzDefaultAuthoritative 指令
mod_authz_user
说明 | 基于每个用户提供授权支持 |
状态 | 基本(B) |
模块名 | authz_user_module |
该模块可以允许或拒绝经过认证的用户访问受保护的区域。
mod_authz_user提供以下指令:
AuthzUserAuthoritative 指令
mod_authz_user有两种授权方式(二选一):
1 根据在Require user中列出的用户对访问进行控制,
2 根据require valid-user指令简单允许所有成功通过认证的用户进行访问。
mod_authz_groupfile
说明 | 使用纯文本文件为组提供授权支持 |
状态 | 基本(B) |
模块名 | authz_groupfile_module |
该模块可以根据经过认证的用户是否属于特定组来允许或拒绝访问受保护的区域。
为mod_auth提供:AuthGroupFile 指令。
AuthGroupFile 指令 指令设定一个文本文件的名称,这个纯文本文件包含用于执行用户认证的用户组列表。存放用户组列表文件的路径如果不是绝对路径,则是相对于ServerRoot的相对路径。
AuthzGroupFileAuthoritative 指令
mod_authz_host
说明 | 提供基于主机名、IP地址、请求特征的访问控制 |
状态 | 基本(B) |
模块名 | authz_host_module |
mod_authz_host提供的指令用在<Directory>, <Files>, <Location>段中,也用于.htaccess文件中控制对服务器特定部分的访问。
提供:Allow 指令,Deny 指令 ,Order 指令。
Order指令控制默认的访问状态与Allow和Deny指令生效的顺序。
Deny,Allow
Deny指令在Allow指令之前被评估。默认允许所有访问。任何不匹配Deny指令或者匹配Allow指令的客户都被允许访问。
Allow,Deny
Allow指令在Deny指令之前被评估。默认拒绝所有访问。任何不匹配Allow指令或者匹配Deny指令的客户都将被禁止访问。
===============================================================
mod_autoindexLoadModule autoindex_module modules/mod_autoindex.so
说明 | 自动对目录中的内容生成列表,类似于"ls"或"dir"命令 |
状态 | 基本(B) |
模块名 | autoindex_module |
如果没有指定目录索引页(index.html,index,php等),自动生成目录列表。
mod_autoindex提供以下指令:
AddAlt 将指定文件名的图标替换为文本
AddAltByEncoding 和AddAlt一样,只是方法是通过指定MIME编码(MIME-encoding)
AddAltByType 和AddAlt一样,只是方法是通过指定MIME内容类型(MIME content-type)
AddDescription 给文件(夹)添加描述,如果描述有空格,使用双引号包裹起来
AddIcon 指定文件名添加图标
AddIconByEncoding 和AddIcon一样,只是通过MIME编码来区分文件
AddIconByType 和AddIcon一样,只是通过MIME内容类型来区分文件
DefaultIcon 没有通过AddIcon*指定的文件则使用此默认图标
HeaderName 可以在索引列表的前面插入一个文件的内容。如果以“/”开头,则是相对于DocumentRoot目录。
IndexHeadInsert 在列表页面的<head>标签内插入html代码
IndexIgnore 使一些文件或文件扩展名不出现在目录列表中。
IndexOptions 开启高级索引
IndexOrderDefault 用于设定目录排序
IndexStyleSheet 输出页面的样式表
ReadmeName 在高级索引列表的最后插入一个文件
具体例子参考:
apache mod_autoindex 详解
=============================================================
LoadModule cgi_module modules/mod_cgi.so
说明 | 在非线程型MPM(prefork)上提供对CGI脚本执行的支持 |
状态 | 基本(B) |
模块名 | cgi_module |
任何具有MIME类型application/x-httpd-cgi或者被cgi-script处理器处理的文件都将被作为CGI脚本对待并由服务器运行,它的输出将被返回给客户端。可以通过两种途径使文件成为CGI脚本,一种是文件具有已由AddType指令定义的扩展名,另一种是文件位于ScriptAlias目录中。
在UNIX下使用多线程型的MPM时,应该使用模块mod_cgid代替本模块。在用户层面,这两个模块本质上是相同的。
mod_cgi提供以下指令:
ScriptLog 指令 CGI脚本错误日志文件的位置
ScriptLogBuffer 指令 限制记入日志文件的PUT或者POST内容的大小,防止如果接收到很大内容时日志文件的尺寸增加得太快太大。默认地,最多纪录1024字节
ScriptLogLength 指令 可以用来给CGI日志文件的大小设置一个上限。默认10385760bytes
================================================================
mod_cgid
说明 | 在线程型MPM(worker)上用一个外部CGI守护进程执行CGI脚本 |
状态 | 基本(B) |
模块名 | cgid_module |
只要编译时选择了多线程型的MPM支持,这个模块就会默认代替mod_cgi 。
==============================================================
mod_dirLoadModule dir_module modules/mod_dir.so
说明 | 指定目录索引文件以及为目录提供"尾斜杠"重定向 |
状态 | 基本(B) |
模块名 | mod_dir.c |
因为对目录的请求需要以一个"/"结尾,所以当服务器接收到对 http://servername/foo/dirname 的请求时,若dirname是一个目录,则mod_dir将会将其重定向到 http://servername/foo/dirname/ 。
mod_dir 提供以下指令:
DirectoryIndex 指令 定义 目录索引页(index.php,index.html)
DirectorySlash 指令 决定mod_dir是否通过在请求的URL结尾补上"/"使其重定向到其所指向的目录。
===============================================================
mod_envLoadModule env_module modules/mod_env.so
说明 | 允许Apache修改或清除传送到CGI脚本和SSI页面的环境变量 |
状态 | 基本(B) |
模块名 | env_module |
本模块用于控制传送给CGI脚本和SSI页面的环境变量。所传送的环境变量可以来自调用httpd进程的shell ,或者来自在配置过程中所设定(set)或撤销(unset)的变量。
mod_env提供以下指令:
PassEnv 指令 从调用httpd进程所在的shell中,指定一个或者更多个环境变量,传送到CGI脚本和SSI页面。
SetEnv 指令 设置一个环境变量,该变量将会传送到CGI脚本和SSI页面。
UnsetEnv 指令 在传送到CGI脚本和SSI页面的环境中,删除一个或者多个环境变量。
===============================================================
mod_filter
说明 | 根据上下文实际情况对输出过滤器进行动态配置 | ||
状态 | 基本(B) | ||
模块名 | filter_module |
提供以下指令:
FilterChain 指令 设置过滤链
FilterDeclare 指令 声明一个智能过滤器
FilterProtocol 指令 正确处理HTTP协议的处理规则
FilterProvider 指令 注册一个内容过滤器
FilterTrace 指令 从mod_filter获得debug信息
================================================================
mod_includeLoadModule include_module modules/mod_include.so
说明 | 实现服务端包含文档(SSI)处理 |
状态 | 基本(B) |
模块名 | include_module |
mod_include提供以下指令:
SSIEndTag 指令 SSI语句的结束符,默认为 "-->"
SSIStartTag 指令 SSI语句的开始符,默认为 "<!--#"
SSIErrorMsg 指令 自定义SSI错误
SSITimeFormat 指令 设置时间显示的格式
SSIUndefinedEcho 指令 未定义的变量显示时会被替换为此字符串
XBitHack 指令 控制服务器分析与MIME类型text/html有关的文件。设置为on,具有可执行权限的HTML文件被认为是SSI文件。
SSI的配置
---------------------------------------------------
<VirtualHost 206.171.50.50>
ServerName test.com
DocumentRoot /data/web/htdocs
ScriptAlias /data/web/cig-bin
<Directory /dat/web/htdocs/chapter07>
AddHandler server-parsed .shtml
AddType text/html .shtml
Options +Include
</Directory>
</VirtualHost>
----------------------------------------------
AddHandler server-parsed .shtml
此命令通知apache,用server-parsed程序处理shtml. server-parsed在mod_include模块中。
AddType text/html .shtml
apache将产生text/html内容类型的头标,告诉浏览器以HTML文档显示出来。
Options +Include
告诉apache使用Include支持
===============================================================
mod_isapiLoadModule isapi_module modules/mod_isapi.so
说明 | 仅限于在Windows平台上实现ISAPI扩展 |
状态 | 基本(B) |
模块名 | isapi_module |
本模块使得Windows上的Apache能有限地实现互联网服务扩展(比如调用ISAPI的动态连接库)。
==============================================================
mod_log_configLoadModule log_config_module modules/mod_log_config.so
说明 | 允许记录日志和定制日志文件格式 |
状态 | 基本(B) |
模块名 | log_config_module |
本模块提供了三个指令:
TransferLog指令用来指定日志文件,
LogFormat指令用来定义日志格式,
CustomLog指令可以同时完成指定日志文件和定义日志格式。
TransferLog和CustomLog指令在每个服务器上都可以被多次使用,以便将同一个请求记录到多个文件中。
=================================================================
mod_mimeLoadModule mime_module modules/mod_mime.so
说明 | 根据文件扩展名决定应答的行为(处理器/过滤器)和内容(MIME类型/语言/字符集/编码) |
状态 | 基本(B) |
模块名 | mime_module |
AddCharset, AddEncoding, AddLanguage, AddType指令都可以用于在文件的扩展名与文件的元信息之间建立映射关系。它们分别指明了文档的字符集、编码方式、语言、MIME类型(内容类型)。指令TypesConfig用来指定一个文件,它也包含了扩展名到MIME类型的映射关系。
指令AddHandler, AddOutputFilter, AddInputFilter控制了提供文档的模块或脚本的运作方式。MultiviewsMatch指令设定mod_negotiation模块在尝试Multiview匹配时,如何处理文件扩展名。
当mod_mime模块在元信息与文件的扩展名之间建立映射以后,core提供了一组指令用来建立某个给定范围内(也就是<Location>, <Directory>, <Files>)所有相关文件与特定的元信息之间的关联。这些指令包括ForceType, SetHandler, SetInputFilter, SetOutputFilter 。core的指令会覆盖任何在mod_mime模块中定义的文件扩展名映射。
mod_mime 提供以下指令:
AddCharset 指令 在给定的文件扩展名与特定的字符集之间建立映射
AddEncoding 指令 将一个或多个文件扩展名映射到一个MIME-encoding(编码方式)
AddHandler 指令 将一个或多个文件扩展名指定一个处理程序
AddInputFilter 指令 在文件扩展名与特定的输入过滤器之间建立映射
AddLanguage 指令 在文件扩展名与特定的语言之间建立映射。在内容协商中很有用。
AddOutputFilter 指令 在文件扩展名与特定的输出过滤器之间建立映射关系
AddType 指令 将文件扩展名列表映射到一个MIME-type(内容类型)
DefaultLanguage 指令 为所有文件设定特定的默认语言
ModMimeUsePathInfo 指令 将path_info当成是文件名的一个组成部分
MultiviewsMatch 指令 在使用MultiViews查询所匹配的文件时要包含的文件类型
RemoveCharset 指令 删除任何给定的扩展名与内容字符集之间的关联
RemoveEncoding 指令 删除任何给定的扩展名与内容编码方式之间的关联
RemoveHandler 指令 删除任何指定扩展名与处理器之间的关联
RemoveInputFilter 指令 删除指定扩展名与输入过滤器之间的关联
RemoveLanguage 指令 删除指定的扩展名与内容语言之间的关联
RemoveOutputFilter 指令 删除指定扩展名与输出过滤器之间的关联
RemoveType 指令 删除指定扩展名与内容类型之间的关联
TypesConfig 指令 指定mime.types文件的位置
=================================================================
mod_negotiationLoadModule negotiation_module modules/mod_negotiation.so
说明 | 提供内容协商支持 |
状态 | 基本(B) |
模块名 | negotiation_module |
内容协商,更准确的说应该是"内容选择",是从几个有效文档中选择一个最匹配客户端要求的文档的过程(如存在index.cn.html和index.en.html)。内容协商有两种实现方法。
使用类型表(一个包含type-map处理器信息的文件)明确地列出各变种的文件名。
使用"MultiViews"搜索(由Options指令中的MultiViews选项激活),即服务器执行一个隐含的文件名模式匹配,并在结果中选择。
提供以下命令:
CacheNegotiatedDocs 指令 允许经过内容协商的文档被代理服务器缓存。HTTP/1.1不建议使用。
ForceLanguagePriority 指令 指定无法匹配单个文档的情况下所采取的动作
LanguagePriority 指令 在客户端没有指示语言偏好的情况下,语言的优先级列表
==============================================================
mod_setenvifLoadModule setenvif_module modules/mod_setenvif.so
说明 | 根据客户端请求头字段设置环境变量 |
状态 | 基本(B) |
模块名 | setenvif_module |
mod_setenvif模块允许根据请求的不同方面匹配指定的正则表达式来设置环境变量。这些环境变量可由服务器的其他部分使用。
提供以下指令:
BrowserMatch 指令 基于客户端的User-Agent头有条件地设置环境变量
BrowserMatchNoCase 指令 基于不区分大小写的User-Agent头有条件地设置环境变量
SetEnvIf 指令 基于客户端的所有请求头标设置环境变量
SetEnvIfNoCase 指令 不区分大小写
指令按照他们在配置文件中出现的顺序生效。所以可以使用更多的复合序列,正如下例所示,如果浏览器是mozilla而非MSIE则会设置netscape 。
----------------------------------
BrowserMatch ^Mozilla netscape
BrowserMatch MSIE !netscape
--------------------------------------
================================================================
mod_status
说明 | 生成描述服务器状态的Web页面 |
状态 | 基本(B) |
模块名 | status_module |
本模块允许服务器管理员方便的检查服务器当前的运行状况。
提供以下指令:
ExtendedStatus 指令 为每个请求记录扩展的状态信息
使用<Location ..>容器定义apache状态显示的页面
<Location /apache-status>
SetHandler server-status
</Location>
然后使用www.mydomain.com/apache-status访问
www.mydomain.com/apache-status?refresh=N访问状态页面可以每N秒自动刷新一次。
www.mydomain.com/apache-status?auto 显示简化的信息
输出的详细信息如下:
正在伺服请求的子进程(线程或进程)数量
空闲的子进程数量
每个子进程的状态:已完成的请求数、已发送的字节数。(*)
总访问数和已发送的字节总数(*)
服务器自启动/重启以来经过的时间,服务器已经运行的时间。
平均每秒请求数,平均每秒发送的字节数,平均每个请求发送的字节数。(*)
每个子进程的当前CPU使用百分率,以及Apache的当前总计CPU使用百分率。(*)
当前正在被处理的主机和请求(*)
在apache的support目录下的log_server_status的Perl脚本将状态信息保存在文本文件中
======================================================
mod_userdir
说明 | 允许用户从自己的主目录中提供页面(使用"/~username") |
状态 | 基本(B) |
模块名 | userdir_module |
此模块允许使用类似http://example.com/~user/
的语法来访问用户网站目录。
UserDir 指令 用户网站目录的位置
2.1.4及以后的版本中,默认不开启用户网站目录。在未设置UserDir指令的情况下将使用"UserDir public_html"默认值。