apache开启日志记录,access.log
来源:互联网 发布:职业介绍所 知乎 编辑:程序博客网 时间:2024/06/06 01:47
apache开启日志记录,access.log
发现logs文件夹里面只有error.log
没有access.log
修改httpd.conf
# CustomLog "logs/access.log" common 去掉前面这个#号
*******************************************************************
log_format access '$remote_addr - $remote_user [$time_local] "$request" '
'$status $body_bytes_sent "$http_referer" '
'"$http_user_agent" $http_x_forwarded_for';
location ~ .*\.(gif|jpg|jpeg|png|bmp|swf)$
{
expires 30d;
access_log off;
}
location ~ .*\.(js|css)?$
{
expires 1d;
access_log off;
}
access_log /www/logs/9enjoy.com.log access;
'$status $body_bytes_sent "$http_referer" '
'"$http_user_agent" $http_x_forwarded_for';
location ~ .*\.(gif|jpg|jpeg|png|bmp|swf)$
{
expires 30d;
access_log off;
}
location ~ .*\.(js|css)?$
{
expires 1d;
access_log off;
}
access_log /www/logs/9enjoy.com.log access;
apache下两种方式:
1.只记录html,htm,php等文件
SetEnvIfNoCase Request_URI "(\.htm|\/|\.html|\.php)$" htm
CustomLog logs/9enjoy.com-access_log combined env=htm
CustomLog logs/9enjoy.com-access_log combined env=htm
2.排除法:
<FilesMatch “\.(ico|gif|jpg|png|bmp|swf|js|css)”>
SetEnv IMAGE 1
</FilesMatch>
CustomLog logs/9enjoy.com-access_log combined env=!IMAGE
SetEnv IMAGE 1
</FilesMatch>
CustomLog logs/9enjoy.com-access_log combined env=!IMAGE
******************************************************************
apache运行时会记录其处理的所有请求的相关信息.同时,也会记录在处理过程中发生异常状况的相关信息. LogFormat "%h %l %u %t \"%r\" %>s %b \"%{Referer}i\" \"%{User-Agent}i\"" combined LogFormat "%h %l %u %t \"%r\" %>s %b" common <IfModule logio_module> LogFormat "%h %l %u %t \"%r\" %>s %b \"%{Referer}i\" \"%{User-Agent}i\" %I %O" combinedio </IfModule> CustomLog "logs/access.log" common 等级名称介绍 emerg 紧急状况;服务器无法使用 alert 必须立刻采取动作 crit危急状况 error出现错误 warn警告 notice正常,但有情况要注意 info普通信息 debug调试级别信息,包括模块运行状态 设定一个等级后,日志文件中会记录它,以及它以上等级的日志.但不管设定为可值,永远都会记录notice等级的信息.
格式字符串 描述
服务器可以用多种格式将与请求相关的活动信息记录在多个日志文件中,不过却只能记录一份错误信息.
关于活动记录,它是在请求完成被处理后才会对日志内容进行写入.如一个大文件的上传,它是在文件上传完后才写入日志的.而错误信息是在错误发生时就写入.当然,错误的发生也是一瞬间的事.不会出现请求那种长时间处理.
有一种通用的显示日志的方式:CLF(common log format).格式是:
"%h %l %u %t \"%r\" %>s %b"
但随着发展,这种格式的内容不够多,人们又组织了另一种格式:
"%h %l %u %t \"%r\" %>s %b \"%{Referer}i\" \"%{User-agent}i\""
它能记住请求的浏览器版本及其他客户端软件的名称与版本等.
Apache自带有一个标准的日志模块:mod_log_config.另外,Apache 2.0还带有一个额外的模块:mod_logio.它是前者的加强版.而且在http://modules.apache.org的模块注册区还有其它的第三方模块可供使用.
例如,我的Apache的httpd.conf文件中有如下配置:
ErrorLog "logs/error.log"
LogLevel warn
<IfModule log_config_module>
</IfModule>
在我的Apache安装目录下的logs目录下有两个文件,就是上面配置的error.log和access.log
上面的配置先定义了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
根据UserCanonicalName指令设定的服务器名称。%X
请求完成时的连接状态:X
=连接在应答完成前中断。+
=应答传送完后继续保持连接。-
=应答传送完后关闭连接。(在1.3以后的版本中,这个指令是%c
,但这样就和过去的SSL语法:%{var}c
冲突了)
%I
接收的字节数,包括请求头的数据,并且不能为零。要使用这个指令你必须启用mod_logio模块。%O
发送的字节数,包括请求头的数据,并且不能为零。要使用这个指令你必须启用mod_logio模块。按照日或小时记录请求日志
======================================
使用CustomLog及rotatelogs(已经在apache的bin目录下包含:rotatelogs.exe.linux下目录可能不同):
CustomLog "| bin/rotatelogs logs/access_log.%Y-%m-%d 86400" combined
该配置会将日志输出到另一程序,而非文件.即:rotatelogs.exe.这样,我们就可以在不重启Apache的情况下来生成新的文件.该脚本会在指定时间自动开启新文件,并写入日志.
rotatelogs第一个参数是日志文件的文件路径和名:logs/access_log.%Y-%m-%d 86400 如果它包含有一个以上的%字符,则会被作为strftime(3)的格式字符串来处理;如上面的格式表示年月晶.否则,一个十位数长的更新时间( 秒为单位)会被附加到文件名上.如:若文件名为foo,则会产生如foo.1234567890的日志文件.而上面的文件则会产生:access_log.2011-04-25这样的文件.
第二个参数是两次更新时间的间隔(以秒为单位).当系统时间是此参数值的倍数时,它就会产生更新操作.如,一天有86400秒,若设定此境遇早每天午夜就会产生新的日志文件.
每月第一天更新日志文件
======================================
同样,也是用脚本来处理,不过是使用:rotate-log-monthly.pl来处理.但这个脚本不包括在apache安装包中,我们需要自己下载.格式如下:
CustomLog "| rotate-log-monthly.pl logs/access_log-%Y-%M" CLF
记录主机名而非IP地址
======================================
CustomLog "| bin/logresolve -c >> log/access_log.resolved" combined
logresolve 已经在bin下包括.
- apache开启日志记录,access.log
- 限制Apache日志access.log文件大小
- apache服务器访问日志access.log设置
- 关闭Apache other-vhosts-access-log 日志
- apache服务器访问日志access.log设置
- 关闭apache, error.log,access.log日志,防止输出
- Apache关闭VirtualHost的Log日志记录
- 解决Apache日志文件ACCESS.LOG太大的方法
- 通过Nginx,Tomcat访问日志(access log)记录请求耗时
- 通过Nginx,Tomcat访问日志(access log)记录请求耗时
- 开启cron.log日志
- 开启Log记录
- 清除error.log、access.log并限制Apache日志文件大小的方法
- 清除error.log、access.log并限制Apache日志文件大小的方法
- 清除error.log、access.log并限制Apache日志文件大小的方法
- 清除error.log、access.log并限制Apache日志文件大小的方法
- Apache log 日志分析
- cron 开启其日志 log
- Ubuntu 12.10 +Hadoop 1.2.1版本集群配置
- webkit入门准备
- Linux基础知识总结-文件管理
- NOTES.INI 在Full Text / KeyView 领域中的常用配置
- 支付宝与微信:移动支付的巅峰对决
- apache开启日志记录,access.log
- 通过压缩数据提高Domino网络传输性能
- 编程面试的10大算法概念汇总
- poj1442 treap版本&&priority_queue
- VS2013不支持HTML文件的解决办法
- 避免Gson使用时将一些字符自动转换为Unicode转义字符
- 关联规则挖掘:FP-Growth算法
- 如何在IBM Domino中使用第三方CA
- chrome 硬件渲染(GPU Accelerated Compositing in Chrome)