Server Fault Asked on January 5, 2022
I am pretty new to awstats and have configured Awstats on my apache webserver to analyze nginx access logs(nginx webserver is for my django app), I am able to take the stats from
LogFile=/var/log/nginx/access.log but how do I analyze multiple Logs that are gzip format. Such as access.log.1.gz…access.log.40.gz. I have a lot of logs to analyze.
Alternatively, you can use a real-time log analyzer, such as GoAccess. It's really fast and you don't need to unzip any log.
apache & nginx
zcat -f access.log* | goaccess -a -s -b
zcat access.log.*.gz | goaccess -a -s -b
Answered by Sanders12 on January 5, 2022
What you probably want to do here is to analyze all these logfiles once, then keep analyzing only the current logfiles from then on.
The simplest thing to do is unzip all those files into a single file, then have awstats run over it once, then point awstats at your access.log file from then on.
awstats normally has a script called logresolvemerge.pl, which can read the compressed files, and will merge them appropriately for awstats to do analsyis.
To merge all your existing ones, run
perl /usr/share/awstats/tools/logresolvemerge.pl /var/log/nginx/access.log* > /tmp/nginx.tmplog
This will probably take a while.
You can then have awstats run once over this file (set LogFile appropriately).
From then on, you should have awstats run over the most recent logfile - which is what your current configuration is doing.
Depending on how often you are running awstats vs rotating nginx logfiles, you may want to have it read both the current logfile and the previous one. (eg, if you rotate nginx logfiles every day at 12, but have awstats run every day at 1, then whenever awstats runs the logfile will only contain what's been written since the last rotation). You can use logresolvemerge.pl inside your LogFile command like this:
LogFile="/usr/share/awstats/tools/logresolvemerge.pl /var/log/nginx/access.log /var/log/nginx/access.log.1.gz |"
This tells awstats to run the logresolvemerge.pl command with the two logfiles as parameters, and awstats will read in the output of that script (that's what the pipe | does)
Answered by Daniel Lawson on January 5, 2022
0 Asked on February 9, 2021 by brettski
1 Asked on February 9, 2021 by andredurao
1 Asked on February 8, 2021 by drew-chapin
1 Asked on February 8, 2021 by t-brian-jones
9 Asked on February 7, 2021 by corey
2 Asked on February 6, 2021 by mealstrom
0 Asked on February 6, 2021 by tyralcori
0 Asked on February 6, 2021 by richard-lian
3 Asked on February 5, 2021 by spirit
1 Asked on February 5, 2021
1 Asked on February 5, 2021 by mangaldeep-dey
1 Asked on February 4, 2021 by ben-voigt
8 Asked on February 4, 2021 by aseba
1 Asked on February 4, 2021 by rabejens
Get help from others!