apache日志格式

July 22nd, 2010 | Tags: ,

LogFormatCustomLog指 令的格式化参数是一个字符串。这个字符串会在每次请求发生的时候,被记录到日志中去。它可以包含将被原样写入日志的文本字符串以及C风格的控制字 符”\n”和”\t”以实现换行与制表。文本中的引号和反斜杠应通过”\”来转义。

请求本身的情况将通过在格式字符串中放置各种”%“转义符的方法来记录,它们在写入日志文件时,根据下表的定义 进行转换:

格式字符串 描述
%% 百分号(Apache2.0.44或更高的版本)
%a 远端IP地址
%A 本机IP地址
%B 除HTTP头以外传送的字节数
%b 以CLF格式显示的除HTTP头以外传送的字节数,也就是当没有字节传送时显示’-‘ 而不是0。
%{Foobar}C 在请求中传送给服务 端的cookieFoobar的内容。
%D 服务器处理本请求所用时间,以微为单位。
%{FOOBAR}e 环境变量FOOBAR的 值
%f 文件名
%h 远端主机
%H 请求使用的协议
%{Foobar}i 发送到服务器的请求 头Foobar:的内容。
%l 远端登录名(由identd而来,如果支持的话),除非IdentityCheck设 为”On“,否则将得到一个”-”。
%m 请求的方法
%{Foobar}n 来自另一个模块的注解Foobar的 内容。
%{Foobar}o 应答头Foobar:的 内容。
%p 服务器服务于该请求的标准端口。
%P 为本请求提供服务的子进程的PID。
%{format}P 服务于该请求的PID或TID(线程ID),format的 取值范围为:pidtid(2.0.46及以后版本)以及hextid(需 要APR1.2.0及以上版本)
%q 查询字符串(若存在则由一个”?” 引导,否则返回空串)
%r 请求的第一行
%s 状态。对于内部重定向的请求,这个状态指的是原始请 求的状态,—%>s则指的是最后请求的状态。
%t 时间,用普通日志时间格式(标准英语格式)
%{format}t 时间,用strftime(3)指 定的格式表示的时间。(默认情况下按本地化格式)
%T 处理完请求所花时间,以秒为单位。
%u 远程用户名(根据验证信息而来;如果返回status(%s) 为401,可能是假的)
%U 请求的URL路径,不包含查询字符串。
%v 对该请求提供服务的标准ServerName
%V 根据UseCanonicalName指 令设定的服务器名称。
%X 请求完成时的连接状态:

X= 连接在应答完成前中断。
+= 应答传送完后继续保持连接。
-= 应答传送完后关闭连接。

(在1.3以后的版本中,这个指令是%c,但这样就和过去的SSL语法:%{var}c冲 突了)

%I 接收的字节数,包括请求头的数据,并且不能为零。要使用这个 指令你必须启用mod_logio模 块。
%O 发送的字节数,包括请求头的数据,并且不能为零。要使用这个 指令你必须启用mod_logio模 块。

修饰符

可以紧跟在”%”后面加上一个逗号分隔的状态码列表来限制记录的条目。例如,”%400,501{User-agent}i” 只记录状态码400和501发生时的User-agent头内容;不满足条件时用”-“代替。状态 码前还可以加上”!“前缀表示否定,”%!200,304,302{Referer}i“记录所有不 同于200,304,302的状态码发生时的Referer头内容。

“<”和”>”修饰符可以用来指定对于已被内部重定向的请求是选择原始的请求还是选择最终的请求。默认情况下,%s, %U, %T, %D, %r 使用原始请求,而所有其他格式串则选择最终请求。例如,%>s 可以用于记录请求的最终状态,而 %<u 则记录一个已经被内部重定向到非认证资源的请求的原始认证用户。

ps:时间格式还可以这样,比如%{%Y-%m-%d}t  这样显示的格式是2010-07-22

via:http://lamp.linux.gov.cn/Apache/ApacheMenu/mod/mod_log_config.html#formats

No comments yet.