1、Awstats安装、配置、使用
下载并安装 Awstats
# wget [url]http://nchc.dl.sourceforge.net/sourceforge/awstats/awstats-6.5-1.noarch.rpm[/url]
If first install, follow instructions in documentation
(/usr/local/awstats/docs/index.html) to setup AWStats in 3 steps:
Step 1 : Install and Setup with awstats_configure.pl (or manually)
Step 2 : Build/Update Statistics with awstats.pl
Step 3 : Read Statistics
配置 Awstats
接下来对Awstats进行初始配置。
[root@sample ~]# /usr/local/awstats/tools/awstats_configure.pl
AWStats awstats_configure 1.0 (build 1.6) (c) Laurent Destailleur -----
This tool will help you to configure AWStats to analyze statistics for
one web server. You can try to use it to let it do all that is possible
in AWStats setup, however following the step by step manual setup
documentation (docs/index.html) is often a better idea. Above all if:
- You are not an administrator user,
- You want to analyze downloaded log files without web server,
- You want to analyze mail or ftp log files instead of web log files,
- You need to analyze load balanced servers log files,
- You want to 'understand' all possible ways to use AWStats...
Read the AWStats documentation (docs/index.html).
-----> Running OS detected: Linux, BSD or Unix
Warning: AWStats standard directory on Linux OS is '/usr/local/awstats'.
If you want to use standard directory, you should first move all content
of AWStats distribution from current directory:
/root
to standard directory:
/usr/local/awstats
And then, run configure.pl from this location.
Do you want to continue setup from this NON standard directory [yN] ? y ← 选择y,同意安装到默认目录下
-----> Check for web server install
Enter full config file path of your Web server.
Example: /etc/httpd/httpd.conf
Example: /usr/local/apache2/conf/httpd.conf
Example: c:\Program files\apache group\apache\conf\httpd.conf
Config file path ('none' to skip web server setup):
> /etc/httpd/conf/httpd.conf ← 指定Apache配置文件所在位置
-----> Check and complete web server config file '/etc/httpd/conf/httpd.conf'
Add 'Alias /awstatsclasses "/root/wwwroot/classes/"'
Add 'Alias /awstatscss "/root/wwwroot/css/"'
Add 'Alias /awstatsicons "/root/wwwroot/icon/"'
Add 'ScriptAlias /awstats/ "/root/wwwroot/cgi-bin/"'
Add '' directive
AWStats directives added to Apache config file.
-----> Update model config file '/etc/awstats/awstats.model.conf'
File awstats.model.conf updated.
-----> Need to create a new config file ?
Do you want me to build a new AWStats config/profile
file (required if first install) [y/N] ? y ← 选择y,同意创建一个新的对象配置文件
-----> Define config file name to create
What is the name of your web site or profile analysis ?
Example: [url]www.mysite.com[/url]
Example: demo
Your web site, virtual server or profile name:
> [url]www.91061.com[/url] ← 为统计对象创建代号(推荐以网站URL作为代号)
-----> Define config file path
In which directory do you plan to store your config file(s) ?
Default: /etc/awstats
Directory path to store config file(s) (Enter for default):
> ← 直接按回车,接受将Awstats的配置文件置于/etc/awstats下
-----> Create config file '/etc/awstats/awstats.[url]www.centospub.com.conf[/url]'
Config file /etc/awstats/awstats.[url]www.centospub.com.conf[/url] created.
-----> Restart Web server with '/sbin/service httpd restart' ← HTTP服务重新启动
Stopping httpd: [ OK ]
Starting httpd: [ OK ]
-----> Add update process inside a scheduler
Sorry, configure.pl does not support automatic add to cron yet.
You can do it manually by adding the following command to your cron:
/root/wwwroot/cgi-bin/awstats.pl -update -config=www.centospub.com
Or if you have several config files and prefer having only one command:
/root/tools/awstats_updateall.pl now
Press ENTER to continue... ← 按回车继续进行配置
A SIMPLE config file has been created: /etc/awstats/awstats.[url]www.centospub.com.conf[/url]
You should have a look inside to check and change manually main parameters.
You can then manually update your statistics for 'www.centospub.com' with command:
> perl awstats.pl -update -config=www.centospub.com
You can also read your statistics for 'www.centospub.com' with URL:
> [url]http://localhost/awstats/awstats.pl?config=www.centospub.com[/url]
Press ENTER to finish... ← 按回车结束初始配置
然后对刚刚创建的对象配置文件进行配置。
[root@sample ~]# vi /etc/awstats/awstats.[url]www.centospub.com.conf[/url] ← 修改对象配置文件(文件名与上一步初始配置中设置的域名对应)
LogFile="/var/log/httpd/mylog.log" ← 找到这一行,修改日至文件所在位置(指定Apache的日志文件)
↓
LogFile="/var/log/httpd/access_log" ← 变为此状态
DirData="/var/lib/awstats" ← 找到这一行,更改Awstats数据的保存位置
↓
DirData="." ← 变为此状态,让数据与awstats.pl脚本在同目录下
Lang="auto" ← 找到这一行,将auto改为cn
↓
Lang="cn" ← 变为此状态,让语言默认为中文
SkipHosts="" ← 找到这一行,在""之间添加无效访问规则
↓
SkipHosts="127.0.0.1 REGEX[^192\.168\.]" ← 变为此状态,本地及内部的访问不做分析统计
LevelForWormsDetection=0 ← 找到这一行,将0改为2
↓
LevelForWormsDetection=2 ← 变为此状态,将来自Worm的访问也不做分析统计
接下来,再对httpd.conf中面向Awstats的部分进行必要设置。
[root@sample ~]# vi /etc/httpd/conf/httpd.conf ← 编辑Apache的配置文件
#
# Directives to allow use of AWStats as a CGI
#
----------------------------------------------------
Alias /awstatsclasses "/root/wwwroot/classes/"
Alias /awstatscss "/root/wwwroot/css/"
Alias /awstatsicons "/root/wwwroot/icon/"
ScriptAlias /awstats/ "/root/wwwroot/cgi-bin/"
----------------------------------------------------
找到以上水平线间的语句群,对相应路径进行正确修改。变为下面水平线间状态:
----------------------------------------------------
Alias /awstatsclasses "/usr/local/awstats/wwwroot/classes/"
Alias /awstatscss "/usr/local/awstats/wwwroot/css/"
Alias /awstatsicons "/usr/local/awstats/wwwroot/icon/"
ScriptAlias /awstats/ "/usr/local/awstats/wwwroot/cgi-bin/"
----------------------------------------------------
#
# This is to permit URL access to scripts/files in AWStats directory.
#
↓
然后,重新启动HTTP服务,使新的设置生效。
[root@sample ~]# /etc/rc.d/init.d/httpd restart ← 重新启动HTTP服务,使设置生效
Stopping httpd: [ OK ]
Starting httpd: [ OK ]
对日志进行分析统计
配置完毕后,我们可以通过各种适用于自己的方式,定义统计的方式以及输出的结果。在这里,介绍最简单,也是最广泛的统计方法,如下:
[root@sample ~]# vi /root/awstats.sh ← 建立统计用脚本如下:
#!/bin/bash
/usr/local/awstats/wwwroot/cgi-bin/awstats.pl -update -config=www.centospub.com
(以上紫色字体部分的域名请根据实际情况设置)
[root@sample ~]# chmod 700 /root/awstats.sh ← 赋予脚本可被执行的属性
[root@sample ~]# /root/awstats.sh ← 运行脚本,开始进行统计(如日志量比较大的话,要花一段时间)
Update for config "/etc/awstats/awstats.[url]www.centospub.com.conf[/url]"
With data in log file "/var/log/httpd/access_log"...
Phase 1 : First bypass old records, searching new record...
Searching new records from beginning of log file...
Phase 2 : Now process new records (Flush history on disk after 20000 hosts)...
Jumped lines in file: 0
Parsed lines in file: 55
Found 52 dropped records,
Found 0 corrupted records,
Found 0 old records,
Found 3 new qualified records.
然后在客户端的浏览器上访问 http://服务器IP地址(或你的域名)/awstats/awstats.pl?config=www.91061.com 即可看到详细的分析统计资料
定制统计分析规则及相应外观设置
[1] 完成以上配置,我们已经可以通过客户端的浏览器,掌握Web服务器的访问量、来路等等详细的信息,但由于Awstats的统计是基于Apache日志的, 我们必须通过awstats.pl对当前最新的日志文件进行统计才能得到最新的统计结果。也就是说,在我们运行自行创建的awstats.sh脚本之前, 当前在客户端能够看到的统计分析结果,只是上一次运行awstats.sh脚本时统计的结果。想得到最新的统计结果,必须再次运行awstats.sh。 在这里,我们将其设置为每天定时自动运行,以便于每天都能查看到最新的信息。如下:
[root@sample ~]# crontab -e ← 对定期任务执行时间表进行编辑,添加如下一行:
00 00 * * * /root/awstats.sh ← 添加此行到其中,让统计分析在每天0点更新
[2] 在一些情况,可能并不希望外界看到日志统计分析的结果。对此,我们可以为Apache添加面向于Awstats的访问限制,如下:
[root@sample ~]# vi /etc/httpd/conf.d/awstats.conf ← 创建面向于Awstats的配置文件
AllowOverride None
Order deny,allow
Deny from all
Allow from 192.168.0 ← 只允许局域网内访问
[root@sample ~]# /etc/rc.d/init.d/httpd restart ← 重新启动HTTP服务,使设置生效
Stopping httpd: [ OK ]
Starting httpd: [ OK ]
[3] 用Firefox浏览分析结果时,字体会显得很难看(因为Firefox和IE识别11px字体不一样),所以用Firefox浏览器的情况,可以通过修改awstats.pl输出css的相关字体尺寸进行修改,而达到用Firefox浏览时也和IE一样能够正确显示出适当尺寸的字体。方法就是直接编辑"/usr/local/awstats/wwwroot/cgi-bin/awstats.pl",将文件中所有“11px”的地方都替换为“12px。
在vi awstats.pl
:1,$s/11px/12px/g或/gc,c的含义提示符让用户确认。
配置项目注释及常见问题
在
crontab里手工加进去
/usr/local/awstats/wwwroot/cgi-bin/awstats.pl -update -config=www.youdomains.com,因为这个程序是通过分析日志来进行流量统计的,如果你的日志文件很大的话是很耗系统资源的。还 好,我的流量不大,我设定的是每个小时运行一次,你如果服务器比较繁忙的话也可以每天夜里运行一次。当然你也可以手工运行上面的命令来进行更新统计信息。
第二,conf文件的配置:
LogFile
指定你要分析的日志文件,默认是/var/log/httpd/mylog.log,可以根据你的需要调整,如果你要分析httpd 的全部日志的就是/var/log/httpd/access_log,我们一般就选这个了。
LogType
log类型,默认是web log,不用修改,如果你不是的话就自己照说明改了。
LogFormat
log格式,一般情况下如果是apache的话就是1,iis 就是2,默认不用修改,你也可以照说明自定义,呵呵,我还不太清楚怎么定义。
LogSeparator
log中的分隔符,默认不用修改,如果上面的格式是你自定义的话这里也要修改了
DNSLookup
默认不用修改
DirData
生成的日志分析结果的保存路径,默认是 /var/lib/awstats,你如果要使用默认的路径的话,这个目录是需要手工创建的,注意这个路径必须是可读写的。
下面四项都是在配置时,不用修改。
DirCgi cgi 的路径,这里都是相对于网站根目录的绝对路径
DirIcons icon的路径
SiteDomain 域名:[url]www.youdomains.com[/url]
HostAliases 主机别名
AllowToUpdateStatsFromBrowser
下面这项是是否允许从浏览器里更新统计文件,默认是 0不允许,如果我们改为1的话,就需要apache的属主用户对/var/lib/awstats 目录有读写权限,并对/var/log/httpd目录有读取权限
AllowFullYearView
这个不用修改默认值。awstats默认是以月为单位进行日志分析,如果我们要分析整年的日志的可以在这里设置,因为分析整年的日志的话可能要消耗很多系统资源。如果你需要对年日志进行分析的话,建议手工启动。
这样最基本的配置就完成了,我们可以通过[url]http://www.youdomains.com[/url] awstats/awstats.pl?config=www.youdomains.com来查看统计信息。
/usr/local/awstats/wwwroot/cgi-bin/awstats.pl -update -config=www.youdomains.com,因为这个程序是通过分析日志来进行流量统计的,如果你的日志文件很大的话是很耗系统资源的。还 好,我的流量不大,我设定的是每个小时运行一次,你如果服务器比较繁忙的话也可以每天夜里运行一次。当然你也可以手工运行上面的命令来进行更新统计信息。
第二,conf文件的配置:
LogFile
指定你要分析的日志文件,默认是/var/log/httpd/mylog.log,可以根据你的需要调整,如果你要分析httpd 的全部日志的就是/var/log/httpd/access_log,我们一般就选这个了。
LogType
log类型,默认是web log,不用修改,如果你不是的话就自己照说明改了。
LogFormat
log格式,一般情况下如果是apache的话就是1,iis 就是2,默认不用修改,你也可以照说明自定义,呵呵,我还不太清楚怎么定义。
LogSeparator
log中的分隔符,默认不用修改,如果上面的格式是你自定义的话这里也要修改了
DNSLookup
默认不用修改
DirData
生成的日志分析结果的保存路径,默认是 /var/lib/awstats,你如果要使用默认的路径的话,这个目录是需要手工创建的,注意这个路径必须是可读写的。
下面四项都是在配置时,不用修改。
DirCgi cgi 的路径,这里都是相对于网站根目录的绝对路径
DirIcons icon的路径
SiteDomain 域名:[url]www.youdomains.com[/url]
HostAliases 主机别名
AllowToUpdateStatsFromBrowser
下面这项是是否允许从浏览器里更新统计文件,默认是 0不允许,如果我们改为1的话,就需要apache的属主用户对/var/lib/awstats 目录有读写权限,并对/var/log/httpd目录有读取权限
AllowFullYearView
这个不用修改默认值。awstats默认是以月为单位进行日志分析,如果我们要分析整年的日志的可以在这里设置,因为分析整年的日志的话可能要消耗很多系统资源。如果你需要对年日志进行分析的话,建议手工启动。
这样最基本的配置就完成了,我们可以通过[url]http://www.youdomains.com[/url] awstats/awstats.pl?config=www.youdomains.com来查看统计信息。
常见问题:
[root@demo conf.d]# /usr/local/awstats/wwwroot/cgi-bin/awstats.pl -update -config=www.bestunix.net
Error: AWStats database directory defined in config file by 'DirData' parameter (/var/lib/awstats) does not exist or is not writable.
Setup ('/etc/awstats/awstats.[url]www.youdomains.com.conf[/url]' file, web server or permissions) may be wrong.
Check config file, permissions and AWStats documentation (in 'docs' directory).
这个是因为在/etc/awstats/awstats.[url]www.youdomains.com.conf[/url]中DirData 中定义的目录启动apache的用户没有写得权限,更改目录或更改权限都可以解决。
问题二,出来的页面里所有的流量统计都是空的。
同样是/etc/awstats/awstats.[url]www.youdomains.com.conf[/url]的问题,在这个文件里有一行
LogFile=”/var/log/httpd/mylog.log”
我们一般情况下把这个路径改为”/var/log/apache/access.log”就可以了,如果你设了很多虚拟主机,每个主机都配置了不同的log 的话,在这里指定你要统计的那个主机的log文件就可以了。
问题三,浏览页面时提示没有权限,出现403错误,给上wwwroot目录权限755 就OK了
注:默认的awstats目录结构里并没有wwwroot。可以自己加上去。
[root@demo conf.d]# /usr/local/awstats/wwwroot/cgi-bin/awstats.pl -update -config=www.bestunix.net
Error: AWStats database directory defined in config file by 'DirData' parameter (/var/lib/awstats) does not exist or is not writable.
Setup ('/etc/awstats/awstats.[url]www.youdomains.com.conf[/url]' file, web server or permissions) may be wrong.
Check config file, permissions and AWStats documentation (in 'docs' directory).
这个是因为在/etc/awstats/awstats.[url]www.youdomains.com.conf[/url]中DirData 中定义的目录启动apache的用户没有写得权限,更改目录或更改权限都可以解决。
问题二,出来的页面里所有的流量统计都是空的。
同样是/etc/awstats/awstats.[url]www.youdomains.com.conf[/url]的问题,在这个文件里有一行
LogFile=”/var/log/httpd/mylog.log”
我们一般情况下把这个路径改为”/var/log/apache/access.log”就可以了,如果你设了很多虚拟主机,每个主机都配置了不同的log 的话,在这里指定你要统计的那个主机的log文件就可以了。
问题三,浏览页面时提示没有权限,出现403错误,给上wwwroot目录权限755 就OK了
注:默认的awstats目录结构里并没有wwwroot。可以自己加上去。
Phase 1 : First bypass old records, searching new record...
Searching new records from beginning of log file...
AWStats did not find any valid log lines that match your LogFormat parameter, in the 50th first non commented lines read of your log.
Your log file /usr/local/httpd/logs/dummy-host.fish.tac.idv.tw.com-access_log must have a bad format or LogFormat parameter setup does not match this format.
Your AWStats LogFormat parameter is:
1
This means each line in your web server log file need to have "combined log format" like this:
111.22.33.44 - - [10/Jan/2001:02:14:14 +0200] "GET / HTTP/1.1" 200 1234 "http://www.fromserver.com/from.htm" "Mozilla/4.0 (compatible; MSIE 5.01; Windows NT 5.0)"
And this is an example of records AWStats found in your log file (the record number 50 in your log):
210.67.35.102 - - [29/Jul/2004:15:55:03 +0800] "GET /p_w_picpath/p_w_picpath4.jpg HTTP/1.1" 304 -
Setup ('/usr/local/awstats/wwwroot/cgi-bin/awstats.x.x.x.conf' file, web server or permissions) may be wrong.
Check config file, permissions and AWStats documentation (in 'docs' directory).
如果出现上面错误,说明你的apache 生成的日志格式不是AWstats能识别的格式。
应该把CustomLog 指令的日志类型从common 改为combined类型
ServerAdmin *
ServerName *.*.com.cn
DocumentRoot /var/www/html/*.*.com.cn/
ServerAlias *.*.*
# ServerAlias *.*.com
ErrorLog logs/*.*.*-*-error_log
CustomLog logs/*.com.cn-access_log combined