Chinaunix

标题: AWStats: Apache/IIS的日志分析工具 [打印本页]

作者: 我为鹤狂    时间: 2006-06-23 21:32
标题: AWStats: Apache/IIS的日志分析工具

版权声明:可以任意转载,转载时请务必以超链接形式标明文章原始出处和作者信息及本声明

http://www.chedong.com/tech/awstats.html
关键词:awstats web log analysis apache iis 日志 分析 open source
你完全不必耐心看完所有内容:简要安装说明如下
安装
====
http://sourceforge.net/projects/awstats/ 下载安装包后:
GNU/Linux:tar zxf awstats-version.tgz
awstats的脚本和静态文件缺省都在wwwroot目录下:将cgi-bin目录下的文件都部署awstats.pl程序到 /home/apache/cgi-bin/awstats/ 下
mv awstats-version/wwwroot/cgi-bin /path/to/apache/cgi-bin/awstats
#把图标等文件目录复制到WEB的HTML文件发布目录下:/home/apache/htdocs/ 下发布
更多的批量更新脚本等在tools 目录下,可以一并放到cgi-bin/awstats/ 目录下
升级国内主要搜索引擎定义:http://www.chedong.com/tech/search_engines.pm
配置
====
将缺省awstats.model.conf 命名成common.conf
修改其中的
LoadPlugin="decodeutfkeys"
创建awstats下创建:data 目录用于统计数据输出
按照一下样例设置配置文件:
Include "common.conf"
LogFile="/home/apache/logs/access_log.%YYYY-24%MM-24%DD-24"
SiteDomain="www.chedong.com"
HostAliases="chedong.com"
DefaultFile="index.html"
DirData="/home/cgi-bin/awstats/data/"

内容摘要:AWStats的使用简介和配置一些改进说明。很高兴看到在AWStats 6.3版本开始:中文用户基本上已经只需要将配置文件中将 LoadPlugin="decodeutfkeys" 启用基本上就没有什么中文搜索引擎的统计问题了,目前增加了# Minor chinese search engines 'baidu\.com','search\.sina\.com','search\.sohu\.com',这3个搜索引擎。
包含了针对国内主要搜索引擎和门户网站定义的补丁(解包后覆盖lib\目录下的原程序目录即可)
日志统计系统在站点的用户行为分析中扮演了重要的角色,尤其是对于来自搜索引擎的关键词访问统计:是很有效的用户行为分析数据来源。随着互联网多年的发展,WEB日志统计工具已经越来越成熟,功能也越来越丰富。其中有很多是开放源代码的, AWStats就是其中非常优秀的一款。
AWStats: Advanced Web Statistics
AWStats
是在
Sourceforge
上发展很快的一个基于Perl的WEB日志分析工具。相对于另外一个非常优秀的开放源代码的日志分析工具
Webalizer
,AWStats的优势在于:

  • 界面友好:可以根据浏览器直接调用相应语言界面(有简体中文版)
    参考输出样例:

    http://www.chedong.com/cgi-bin/awstats/awstats.pl?config=chedong

  • 基于Perl:并且很好的解决了跨平台问题,系统本身可以运行在GNU/Linux上或Windows上(安装了
    ActivePerl
    后);分析的日志直接支持Apache格式 (combined)和IIS格式(需要修改)。Webalizer虽然也有
    Windows平台版
    ,但目前已经缺乏维护;
    AWStats完全可以实现用一套系统完成对自身站点不同WEB服务器:GNU/Linux/Apache和Windows/IIS服务器的统一统计。

  • 效率比较高:AWStats输出统计项目比Webalizer丰富了很多,速度仍可以达到Webalizer的1/3左右,对于一个日访问量百万级的站点,这个速度都是足够的;

  • 配置/定制方便:系统提供了足够灵活但缺省也很合理的配置规则,需要修改的缺省配置不超过3,4项就可以开始运行,而且修改和扩展的插件还是比较多的;
  • AWStats的设计者是面向精确的"Human visits"设计的,因此很多搜索引擎的机器人访问都被过滤掉了,因此有可能比其他日志统计工具统计的数字要低,来自公司内部的访问也可以通过IP过滤设置过滤掉。
  • 提供了很多扩展的参数统计功能:使用ExtraXXXX系列配置生成针对具体应用的参数分析会对产品分析非常有用。

    更多与其他工具:Webalizer, analog的比较请参考:

    http://awstats.sourceforge.net/#COMPARISON

    AWStats安装备忘
    AWStats的运行模式是这样的:

  • 分析日志:运行后将这样的日志统计结果归档到一个AWStats的数据库(纯文本)里;
  • 然后是输出:分两种形式


    以下是2个针对单个站点日志统计例子:
    一个是在GNU/Linux上通过CGI方式的输出,
    一个是在Windows 2000上的基于静态页面的导出

    下载/安装
    http://sourceforge.net/projects/awstats/
    下载安装包后:

    GNU/Linux:tar zxf awstats-version.tgz
    awstats的脚本和静态文件缺省都在wwwroot目录下:将cgi-bin目录下的文件都部署awstats.pl程序到/home/apache/cgi-bin/awstats/ 下
    mv awstats-version/wwwroot/cgi-bin /path/to/apache/cgi-bin/awstats
    #把图标等文件目录复制到WEB的HTML文件发布目录下:/home/apache/htdocs/ 下发布
    更多的批量更新脚本等在tools 目录下,可以一并放到cgi-bin/awstats/ 目录下,

    Windows 2000:按照后台脚本模式运行,直接解包,然后移动到D:\AWStats目录下
    把图标icon目录复制到IIS的发布目录下:inetpub/icon

    数据源日志格式和按天的截断规则

  • 对于Apache:日志格式好设置:设置成combined格式即可,日志截断麻烦一点:需要安装
    cronolog
    工具,将日志设置成按天截断:
    CustomLog "|/usr/local/sbin/cronolog /path/to/apache/logs/access_log.%Y%m%d" combined
    比如:logs/access_log.20030326
    日志是压缩格式,可以使用gzip -d 相比IIS缺省设置:
    减少的有:

    增加的有:


    配置文件的命名规则:awstats.sitename.conf
    AWStats的主程序awstats.pl会自动根据站点名调用相应站点的配置文件:awstats.sitename.conf
    比如:运行./awstats.pl -config=chedong 调用的就是同目录下的 awstats.chedong.conf 配置文件;
    如果没有指定-config,还会找当前目录下的awstats.conf或者/etc/awstats.conf作为缺省配置文件。
    所以最好把缺省的awstats.model.conf 重命名成 awstats.yoursite.conf;比如:awstats.chedong.conf,

    对于多个站点的统计,AWStats的配置文件包含功能还是非常有用的,我们可以把通用的配置放在一个文档中,然后用(5.4版本以后开始支持) Include配置将通用配置包含在各个具体配置文件的头部,然后用其他配置覆盖通用配置中的相应属性,比如:
    Include="common.conf"
    LogFile="/path/to/bbs/access_log"
    SiteName="bbs.chedong.com"

    最少的配置文件修改:LogFile SiteDomain LogFormat
    对于在GNU/Linux上统计Apache日志只需修改:LogFile SiteDomain这2个选项

  • GNU/Linux LogFile="/path/to/apache/logs/access_log.%YYYY-24%MM-24%DD-24"
    Windows 2000 LogFile="d:\iis_logs\W3SV3\ex%YY-24%MM-24%DD-24.log"
    这个配置的意思是用24小时前的年份,月份,日期拼出的日志文件名;

  • SiteDomain="www.chedong.com"
    站点的名称,缺省是空的,如果为空,AWStats将拒绝运行;

  • 对于统计IIS日志需要多修改一个:
    LogFormat=2
    缺省值是1:Apache日志,2是IIS日志

    其他需要注意的事项:
    AWStats缺省不过滤swf文件,会把.swf算成PageView,所以如果站点上swf文件主要是广告的话最好还是要过滤掉:

    日志分析
    ./awstats.pl -update -config=sitename -lang=cn
    比如:./awstats.pl -update -config=chedong
    会自动调用awstats.chedong.conf这个配置文件

    统计输出
    GNU/Linux    http://localhost/cgi-bin/awstats/awstats.pl?config=chedong
    Windows 2000 http://localhost/awstats/awstats.chedong.html

    日志统计自动运行
    GNU/Linux上:crontab -e: 每天8点10分运行
    #update awstats
    10 8 * * * (cd /path/to/apache/cgi-bin/awstats/; ./awstats.pl -update -config=chedong)

    Windows 2000上:设置每天8点10分运行
    D:\Perl\bin\perl.exe d:\AWStats\tools\awstats_buildstaticpages.pl -update -config=chedong -lang=cn -dir=c:\inetpub\awstats\ -awstatsprog=d:\awstats\wwwroot\cgi-bin\awstats.pl

    多站点日志统计
    AWStats自带了一个批处理工具:tools/awstats_updateall.pl,可以批量地遍历一个目录下所有地配置文件并运行统计。因此剩下的工作就主要是日志的同步问题了。

    针对多个站点,很多配置选项是重复的,如果每个配置文件都修改维护起来会很麻烦,AWStats从5.4版本开始提供了配置文件包含的功能,所以我们可以配置一个通用配置,比如:common.conf
    然后其他站点的配置设置为:可以通过后面的选项覆盖和缺省不一致的配置。
    awstats.bbs.chedong.conf
    Include "chedong.common.conf"
    LogFile "/path/to/bbs_log"
    SiteName "bbs.chedong.com"

    awstats.www.chedong.conf
    Include "chedong.common.conf"
    LogFile "/path/to/www_log"
    SiteName "www.chedong.com"
    HostAliases="chedong.com"

    统计指标说明

    Hacking AWStatsIIS按GMT时间的补丁:awstats.pl
    IIS的日志时间是格林威治之间,中国本地时间和GMT有+8个小时差距,如果直接用TIMEZONE插件从格林威治时间转换会有40%的性能下降,这里有一个将时间按本地时间修改时间坐标的补丁:
    7696d7695
    = 24) {
    print "$ix\n"; # width=19 instead of 18 to avoid a MacOS browser bug.
    7708,7712c7703
    = 24) {
    12) { $hr=$hr-12; }
    ---
    > my $hr=($ix+1); if ($hr>12) { $hr=$hr-12; }

    在Awstats 5.5以后中已经加入了针对中文主要搜索引擎的定义:这里是补充后的完整列表(包括了主要门户搜索和搜索门户)
    62c60
    "baidu\.com","sina\.com","3721\.com","163\.com","tom\.com","sohu\.com",

    153c144
    "baidu\.com","word=", "sina\.com", "word=", "3721\.com", "name=","163\.com","q=","tom\.com","word=","sohu\.com","word=",

    250c234
    "baidu\.com","Baidu", "sina\.com","Sina", "3721\.com","3721","163\.com","NetEase","tom\.com","Tom","sohu\.com","Sohu",

    对Google的Unicode查询还是需要一些查询补丁:
    因为Google对于Windows 2000以上的IE浏览器缺省发送的查询都是UTF-8格式的,而其他搜索引擎大部分使用的是系统本地编码:GB2312,因此需要将查询URI解码后,还要根据是否使用UTF-8进行到GB2312的转码,否则同样的单词会在统计中留有UTF-8和GB2312两条记录。

    我增加了以下函数用于Google UTF-8字符的解码和类似于“\xc4\xbe\xd7\xd3\xc3\xc0”这样查询的解码
    sub Utf8_To_Ascii {
         my $string = shift;
         my $encoding = shift;
         # change \xc4\xbe\xd7\xd3\xc3\xc0 into %c4%be%d7%d3%c3%c0
         $string =~ s/\\x(\w{2})/%\1/gi;
         # uri unescape
         $string = uri_unescape($string);
         if ( $string =~ m/^([\x00-\x7f]|[\xc2-\xdf][\x80-\xbf]|\xe0[\xa0-\xbf][\x80-\xbf]|[\xe1-\xef][\x80-\xbf][\
    x80-\xbf]|\xf0[\x90-\xbf][\x80-\xbf][\x80-\xbf]|[\xf1-\xf7][\x80-\xbf][\x80-\xbf][\x80-\xbf])*$/ )
         {
             $string = decode("utf-8", $string);
             $string = encode($encoding, $string);
         }
         # trim space
         $string =~ s/^\s+//;
         $string =~ s/\s+$//;
         # reverse "+", ";" to space
         $string =~ s/;+//g;
         $string =~ s/\s+/\+/g;
         
         #print $string."\n";
         return $string;
    }

    这里有
    更多关于GOOGLE UTF-8查询的补丁


    基于地理信息的插件安装:

    GeoIP 和 Geo::IPfree(awstats 5.5+)
    GeoIP和Geo::IPfree都免费的是国家/IP的影射表,比通过DNS反相解析域名得到的统计准确,而且速度快。GeoIP的API都是免费的,缺省库是免费的,收费的是它的数据更新服务。Geo::IPfree不仅代码是公开的,而且库数据也是公开的,因此可以自己定制,我曾经设想做一个中国城市到IP的映射。

    GeoIP安装:
    先下载C库:

    GeoIP C
    解包后
    %./configure; make
    #make install
    然后下载Perl库:

    GeoIP Perl
    解包后
    %perl MakeFile.PL; make
    #make install

    Geo::IPfree安装:
    下载

    Geo::IPfree
    解包后
    %perl Makefile
    %make
    #make install

    配置:通过在配置文件中启用插件GeoIP或者Geo::IPfree

    参考资料:

    AWStats
    http://awstats.sourceforge.net/

    Webalizer
    http://www.webalizer.org/

    日志分析工具
    http://directory.google.com/Top/Computers/Software/Internet/Site_Management/Log_Analysis/

    商业日志统计/分析工具
    http://directory.google.com/Top/Computers/Software/Internet/Site_Management/Log_Analysis/Commercial/


    多站点的日志合并统计:
    http://www.chedong.com/tech/rotate_merge_log.html

    日志统计对于分析搜索引擎对站点的影响具有非常重要的意义
    http://www.chedong.com/tech/google.html

    AWStats 本身也包含了很多插件,包括将多个站点的统计再次汇总输出,IIS日志时间转换,URL的标题映射等
    http://awstats.sourceforge.net/awstats_contrib.html


    本文来自ChinaUnix博客,如果查看原文请点:http://blog.chinaunix.net/u/13444/showart_131901.html




    欢迎光临 Chinaunix (http://bbs.chinaunix.net/) Powered by Discuz! X3.2