Apache 学习之 日志 : 1.日志规则介绍

我们之前说了日志的重要性,这次我们看下基本的写法规则

日志的语法规则,其实和sql等差不多,基本上是通用的了。有很多信息默认是不记录的, 需要根据实际应用场景自己选择。

首先有两个命令需要重点介绍:LogFormat和CustomLog

    LogFormat:将一组日志规则指定一个名字,后面可以方便的使用。

    CustomLog:指定日志的保存规则以及文件扩展名。

我们可以在Apache的配置文件httpd中找到这样一行文本:

     LogFormat "%h %l %u %t \"%r\" %>s %b" common

 这句话的意思是:创建一种名为common的日志,日志记录的内容是:"%h %l %u %t \"%r\" %>s %b"  这串字符代表的含义,按照定义时的顺序将含义写到日志文件中去。

具体的规则含义如下表:
     %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的取值范围为:pid和tid(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模块。
     

个别的规则例如%{Referer}i, 在“%”和变量之间放入了一个或者多个HTTP状态代码,则只有当请求返回的状态代码属于指定的状态代码之一时,变量所代表的内容才会被记录。例如,如果我们想要记录的是网站的所有无效链接,那么可以使用:  LogFormat %404{Referer}i BrokenLinks。 同样,如果我们想要记录那些状态代码不等于指定值的请求,可以使用这样的命令:LogFormat %!200U SomethingWrong   

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

一些常见的格式串:
     通用日志格式(CLF)

     "%h %l %u %t /"%r/" %>s %b"


     带虚拟主机的通用日志格式

     "%v %h %l %u %t /"%r/" %>s %b"

 

     NCSA扩展/组合日志格式

     "%h %l %u %t /"%r/" %>s %b /"%{Referer}i/" /"%{User-agent}i/""


     Referer日志格式

     "%{Referer}i -> %U"

 

     Agent(Browser)日志格式

     "%{User-agent}i"


     高大全的日志格式:

     LogFormat "%{x-forwarded-for}i %l %u %t \"%r\" %>s %b \"%{Referer}i\" \"%{Cookie}i\" \"%{User-Agent}i\" \"%{Content-Length}i\""

 
 
 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值