设为首页 收藏本站
查看: 771|回复: 0

[经验分享] Apache 日志管理

[复制链接]

尚未签到

发表于 2016-12-30 09:23:31 | 显示全部楼层 |阅读模式
配置访问日志
CustomLog
CustomLog指令用来对服务器的请求进行日志记录。格式为:

格式1:CustomLog访问日志文件名记录格式说明串|格式昵称
格式2:CustomLog"|管道程序名访问日志文件名"记录格式说明串|格式昵称
其中:

访问日志文件名:除非文件位置用”/“开头,否则所制定的文件位置是相对于ServerRoot目录的相对路径
格式昵称:使用LogFormat指令将一个记录格式说明串赋以一个名称
记录格式说明串:用字符串和格式说明符(以%开头)指定日志记录的内容
管道程序名:管道符”|”后面紧跟着一个程序的路径,这个程序把日志从标准输入设备中读入并处理。
在Ubuntu的Apache默认配置中并没有使用CustomLog设置访问日志,若您希望记录访问日志,您需要在虚拟主机的配置文件中分别设置,例如:在/etc/apache2/sites-available/default中有如下的设置:

CustomLog/var/log/apache2/access.logcombined

LogFormat
为了便于分析Apache的访问日志,Apache的默认配置文件中,按记录的信息不同(用不同格式昵称说明不同的信息)将访问日志分为4类,并由LogFormat指令定义了昵称,如表所示。

格式分类格式昵称说明
普通日志格式(commonlogformat,CLF)common大多数日志分析软件都支持这种格式
参考日志格式(refererlogformat)referer记录客户访问站点的用户身份
代理日志格式(agentlogformat)agent记录请求的用户代理
综合日志格式(combinedlogformat)combined结合以上三种日志信息

LogFormat指令用于定义访问日志的记录格式。格式为:

LogFormat"记录格式说明串"格式昵称
从/etc/apache2/apache2.conf中可知,在Ubuntu的Apache中定义了下面的4种类型的访问日志:

LogFormat"%h%l%u%t\"%r\"%>s%b\"%{Referer}i\"\"%{User-Agent}i\""combined
LogFormat"%h%l%u%t\"%r\"%>s%b"common
LogFormat"%{Referer}i->%U"referer
LogFormat"%{User-agent}i"agent
由于综合日志格式简单地结合了3种日志信息,所以在配置访问日志时,要么使用一个综合文件进行记录,要么使用分离的多个(1-3)文件记录。通常使用一个综合日志格式文件进行记录,配置为:

CustomLog/var/log/apache2/access.logcombined

若使用3个文件分别进行记录,配置为:

CustomLog/var/log/apache2/access.logcommon
CustomLog/var/log/apache2/referer.logreferer
CustomLog/var/log/apache2/agent.logagent


下面的指令组:

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

与下面的指令等效:

CustomLoglogs/access_log"%h%l%u%t\"%r\"%>s%b"
通常我们配置访问日志时,使用先使用LogFormat指令定义格式昵称,然后再在CustomLog指令中引用昵称的方法。

格式说明符
在使用LogFormat和CustomLog指令中为了说明要记录的日志内容,可以使用的常用格式说明符如下表。

格式说明符说明
%v进行服务的服务器的标准名字ServerName,通常用于虚拟主机的日志记录中。
%h客户机的IP地址。
%l从identd服务器中获取远程登录名称,基本已废弃。
%u来自于认证的远程用户。
%t连接的日期和时间。
%rHTTP请求的首行信息,典型格式是“METHODRESOURCEPROTOCOL”,即“方法资源协议”。经常可能出现的METHOD是GET、POST和HEAD;RESOURCE是指浏览者向服务器请求的文档或URL;PROTOCOL通常是HTTP,后面再加上版本号,通常是HTTP/1.1。
%>s响应请求的状态代码,一般这项的值是200,表示服务器已经成功地响应浏览器的请求,一切正常;以3开头的状态代码表示由于各种不同的原因用户请求被重定向到了其他位置;以4开头的状态代码表示客户端存在某种错误;以5开头的状态代码表示服务器遇到了某个错误。
%b传送的字节数(不包含HTTP头信息),将日志记录中的这些值加起来就可以得知服务器在一天、一周或者一月内发送了多少数据。
%{Referer}i记录引用此资源的网页。
%U请求的URL路径,不包含查询串。
%{User-Agent}i使用的浏览器信息。

访问日志文件举例
下面是从一个访问日志文件中截取的3条记录。

$sudotac/var/log/apache2/access.log
192.168.0.66--[21/Jun/2007:22:07:58+0800]"GET/index.htmlHTTP/1.1"2001185"-""Mozilla/4.0(compatible;MSIE6.0;WindowsNT5.1;SV1;Maxthon;.NETCLR2.0.50727)"
192.168.0.77--[19/Jun/2007:21:03:33+0800]"GET/manual/style/manual.cssHTTP/1.1"4041203"http://192.168.0.100/manual/logs.html""Mozilla/4.0(compatible;MSIE6.0;WindowsNT5.0)"
192.168.0.66--[19/Jun/2007:19:21:55+0800]"GET/dokuwiki/lib/exe/css.php?s=printHTTP/1.1"304-"http://192.168.0.191/dokuwiki/doku.php""Mozilla/5.0(Windows;U;WindowsNT5.1;en-US;rv:1.8.0.12)Gecko/20070508Firefox/1.5.0.12"

将各项信息分离于下表所示。

格式说明符举例1举例2举例3
%h192.168.0.66192.168.1.77192.168.0.66
%l-(表示没有取得信息)--
%u---
%t[21/Jun/2007:22:07:58+0800][19/Jun/2007:21:03:33+0800][19/Jun/2007:19:21:55+0800]
%r“GET/index.htmlHTTP/1.1”“GET/manual/style/manual.cssHTTP/1.1”“GET/dokuwiki/lib/exe/css.php?s=printHTTP/1.1”
%>s200404304
%b11851203-
%{Referer}i”-”“http://192.168.0.100/manual/logs.html”“http://192.168.0.191/dokuwiki/doku.php”
%{User-Agent}i“Mozilla/4.0(compatible;MSIE6.0;WindowsNT5.1;SV1;Maxthon;.NETCLR2.0.50727)”“Mozilla/4.0(compatible;MSIE6.0;WindowsNT5.0)”“Mozilla/5.0(Windows;U;WindowsNT5.1;en-US;rv:1.8.0.12)Gecko/20070508Firefox/1.5.0.12”

由于整个格式说明字符串是放在”“之内的,所以若要输出的日志信息内含有引号,需要将”前加转义符\。例如:若要输出子串”GET/apache_pb.gifHTTP/1.0”,则格式字符串为\”%r\”。

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-321390-1-1.html 上篇帖子: apache httpclient 简述 下篇帖子: 如何启动和配置apache
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表