APACHE日志参数说明

在Apache的httpd.conf文件中,通过LogFormat和CustomLog指令可以实现自定义日志文件格式和内容的目的。
前段时间从运营部了解到公司项目天气预报15天查询网(http://tqybw.net),有出现很多404页,找到之后,做了修改,为了彻底解决这个问题,决定开启日志跟踪;
日志分析是网站开发应用一个非常重要的手段,可以帮助开发人员发现和解决很多问题!
LogFormat和CustomLog的格式化参数是一个字符串,这个字符串会在每次请求发生的时候,被记录到日志文件中去。
它可以包含被原样写入日志的文本字符串以及控制字符如:“\t”、“\n”, 其他的特殊字符均可通过反斜杠转义。请求本身的情况将通过在格式字符串中放置各种“%”转义的方式来记录。
下表列出了Apache日志格式字符串的含义
%% 百分号(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的取值范围为: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模块。

一些常见的格式串:
通用日志格式(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”

apache配置实例格式:

LogFormat "%h %l %u %t %T \"%r\" %>s %b \"%{Referer}i\" \"%{User-Agent}i\"" combined
LogFormat "%h %l %u %t \"%r\" %>s %b" common

<IfModule logio_module>
# You need to enable mod_logio.c to use %I and %O
LogFormat "%h %l %u %t \"%r\" %>s %b \"%{Referer}i\" \"%{User-Agent}i\" %I %O" combinedio
</IfModule>

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 这个警告信息表示在Eclipse中找不到适合的附加器(appenders)用于记录日志的logger(org.apache)。 在Eclipse中,log4j是一个用于记录日志的开源库。它使用logger对象来捕获应用程序中发生的事件,并将它们记录在指定的地方。附加器(appenders)负责处理这些日志事件,将它们发送到指定的目标,如控制台、文件或数据库。 在出现这个警告信息时,说明我们的程序代码中没有配置正确的附加器(appenders)来处理日志事件,并将其记录到适当的目标上。 要解决这个问题,我们需要在程序代码中正确配置log4j的附加器(appenders)。我们可以通过创建一个log4j.properties或log4j.xml配置文件来指定附加器和目标的相关信息。然后,在程序代码中加载这个配置文件,确保log4j可以正确地找到并使用这些附加器。 我们可以在配置文件中指定要使用的附加器类型(如ConsoleAppender、FileAppender等),并设置适当的属性,如文件路径、日志级别等。这样,log4j就会使用这些配置信息来初始化并创建相应的附加器,并将日志事件发送到指定的目标上。 通过正确配置log4j的附加器,我们可以有效地记录程序的日志,并方便地进行调试和错误追踪。 ### 回答2: .log4j)这个警告是由于在你的应用程序中没有配置 log4j 日志记录器的输出地点。log4j 是一个 Java 应用程序的日志记录工具,它允许你灵活地控制日志的输出方式。 当你在使用 log4j 的时候,你需要在你的应用程序中配置这个日志记录器。配置包括指定输出信息的格式和输出地点。如果你没有正确配置 log4j,它将无法找到日志输出地点,从而触发这个警告。 要解决这个问题,你需要检查你的项目中的 log4j 配置文件。通常,这个文件命名为 log4j.properties 或 log4j.xml。确保这个文件位于你的应用程序的类路径下,并且正确配置了输出地点。你可以在文件中使用不同的 appender 元素来配置日志的输出地点,例如文件 appender、控制台 appender 或者数据库 appender。 例如,如果你想要将日志输出到一个文件中,你可以在配置文件中添加以下内容: log4j.appender.File=org.apache.log4j.FileAppender log4j.appender.File.File=/path/to/your/logfile.log log4j.appender.File.layout=org.apache.log4j.PatternLayout log4j.appender.File.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss} %p %c{1} - %m%n 这样,log4j 将会将日志信息输出到指定的文件中。 总结来说,log4j:warn no appenders could be found for logger (org.apache.log4j) 的警告是由于缺少正确配置的 log4j 输出地点所致。你需要检查你的 log4j 配置文件,并确保正确配置了输出地点才能解决这个问题。 ### 回答3: log4j:warn no appenders could be found for logger (org.apache) 这个错误信息表示log4j在Eclipse中找不到适当的appender来处理日志消息。 Log4j是一个Java日志实用工具,它允许我们在应用程序中灵活地控制日志记录。一个appender是用来定义日志输出的目标,例如控制台、文件或数据库。当log4j无法找到合适的appender时,就会出现上述警告信息。 要解决这个问题,我们需要检查并确保以下几点: 1. 确认log4j配置文件存在:在Eclipse项目的src/main/resources目录下,通常会有一个log4j.properties或log4j.xml文件,它用于指定日志记录的配置。如果该文件不存在,或命名不正确,log4j就无法找到appender。 2. 检查配置文件中的appender定义:在log4j配置文件中,我们应该检查是否有定义至少一个appender,并且每个appender都有一个唯一的名称和正确的配置参数。例如,如果我们要将日志输出到一个文本文件,我们需要定义一个FileAppender,并设置正确的文件路径、编码等参数。 3. 确认日志记录器(logger)配置正确:log4j使用logger来控制不同类或包的日志记录级别和appender。在配置文件中,我们需要为相关的logger设置正确的级别和关联的appender。如果logger的日志级别设置过高,例如设置为ERROR而非DEBUG,那么更低级别的日志信息将被忽略。 4. 导正确的log4j库:在Eclipse项目的构建路径中,确保正确导了log4j的jar文件,这样才能使用log4j的功能。 通过检查以上几点,我们应该能够解决log4j:warn no appenders could be found for logger (org.apache)这个错误,并确保在Eclipse中正确记录和处理日志消息。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值