| トップ | Solaris | FreeBSD | Gentoo | CentOS | Fedora | Windows | Tips | 自宅サーバの動作確認 | サイト内検索(Namazu) | サイト内検索(HE) |
「AWStats」を用いて「Squid」のログ解析を行います。
なお、「Apache」の設定、
「Squid」の設定、
Webアクセスログ解析(AWStats)は完了済みとします。
新規に設定ファイルを作成します。
[root@CentOS ~]# vi /etc/awstats/awstats.squid.conf <= 設定ファイルの作成 LogFile="/var/log/squid/access.log" <= ログファイルのパスを指定 LogType=W LogFormat=4 SiteDomain="crimson-snow.net" <= ドメインを指定 HostAliases="localhost 127.0.0.1 REGEX[myserver\.com$]" DNSLookup=1 DirData="/var/www/awstats/squid" <= AWStatsが保持する分析結果等のファイルを格納するディレクトリを指定 (絶対パスもしくはawstats.plからの相対パス) DirCgi="/awstats" <= awstats.plが格納されているディレクトリを指定 (絶対URLもしくはWWWサーバのルートディレクトリからの相対URL) DirIcons="/awstats/icon" <= アイコンファイルが格納されているディレクトリを指定 (絶対URLもしくはWWWサーバのルートディレクトリからの相対URL) EnableLockForUpdate=0 AllowAccessFromWebToFollowingIPAddresses="" AllowToUpdateStatsFromBrowser=1 Lang="jp" LevelForBrowsersDetection=0 LevelForOSDetection=0 LevelForRefererAnalyze=0 LevelForRobotsDetection=0 LevelForSearchEnginesDetection=0 LevelForKeywordsDetection=0 LevelForWormsDetection=0 ShowDomainsStats=0 ShowRobotsStats=0 ShowFileSizesStats=0 ShowOSStats=0 ShowBrowsersStats=0 ShowOriginStats=0 ShowKeyphrasesStats=0 ShowKeywordsStats=0 |
ディレクトリの作成
AWStatsが保持する分析結果等のファイルを格納するディレクトリを作成します。
[root@CentOS ~]# mkdir /var/www/awstats/squid |
オーナの変更
「AWStats」の設定で AllowToUpdateStatsFromBrowser を 1 にしましたが、
これは、出力結果に更新ボタンを設置し、ブラウザから最新のログの情報に更新します。
ただ、Apacheのユーザ権限で更新しますので、パーミッションエラーが起きます。
そこで、必要なディレクトリのオーナを変更します。
この作業は AllowToUpdateStatsFromBrowser を 0 に設定していれば必要ありません。
[root@CentOS ~]# chown apache /var/www/awstats/squid <= 分析結果等の格納先のオーナをapacheに変更 [root@CentOS ~]# chmod 755 /var/log/squid <= ログファイルをapacheから見れるようにする |
「Squid」のログ形式を「AWStats」用に変更します。
なお、「CentOS5.0(Squid-2.6系)」の場合、emulate_httpd_log を変更するだけでは設定が反映されないので、
access_log の設定も変更します。
[root@CentOS ~]# vi /etc/squid/squid.conf <= 設定ファイルの編集 access_log /var/log/squid/access.log squid ↓ access_log /var/log/squid/access.log auto <= 変更(「CentOS5.0」の場合のみ) # emulate_httpd_log off ↓ emulate_httpd_log on <= 変更 |
古いログファイルを削除します。
[root@CentOS ~]# rm /var/log/squid/access.log |
「Squid」を再起動し、設定を反映させます。
[root@CentOS ~]# /etc/rc.d/init.d/squid reload |
[root@CentOS ~]# /var/www/awstats/awstats.pl -config=squid -update |
http://サーバのIPアドレス/awstats/awstats.pl?config=squid
でアクセスできれば問題ありません。
上記のままの設定で問題ありませんが、アクセスするたびにCGIスクリプトが実行されますので、
表示が遅く、サーバにも負荷がかかります。
そこで、出力結果をHTML化します。
[root@CentOS ~]# /var/www/awstats/awstats.pl -config=squid -output -staticlinks \ > /var/www/awstats/squid.html |
http://サーバのIPアドレス/awstats/squid.html
でアクセスできれば問題ありません。
HTML化の自動実行
「Squid」のログローテーションに合わせて実行するようにします。
[root@CentOS ~]# vi /etc/logrotate.d/squid <= 設定ファイルの編集
/var/log/squid/access.log {
weekly
rotate 5
copytruncate
compress
notifempty
missingok
prerotate <= 追加
/var/www/awstats/awstats.pl -config=squid -update > /dev/null <= 追加
/var/www/awstats/awstats.pl -config=squid -output -staticlinks > /var/www/awstats/squid.html <= 追加
endscript <= 追加
}
|