[[Vorlage(Getestet, focal)]] {{{#!vorlage Wissen [:Pakete installieren: Installation von Programmen] [:Editor: Einen Editor öffnen] [:sudo: Root-Rechte] [:Terminal: Ein Terminal öffnen] }}} [[Inhaltsverzeichnis()]] [[Bild(./webalizer_head.gif, , align=left)]] Das Programm [http://www.webalizer.org/ Webalizer] {en} dient zur Auswertung der [:Logdateien:], die [:Serverdienste:Webserver] auf Basis von Besucheranfragen erstellen. Die Software erzeugt Berichte im HTML-Format, die anschließend mit einem beliebigen Webbrowser betrachtet werden können. [http://www.webalizer.org/sample/ Demoseiten] {en} zeigen beispielhaft das Ergebnis einer solchen Auswertung, die in mehr als 30 Sprachen erfolgen kann. Die konkret verwendete Sprache hängt von den [:Spracheinstellungen:] des verwendeten Rechners ab. Häufig kritisiert wird bei Webalizer die fehlende Auswertung von [wikipedia:Toter_Link:404]-Fehlern, die besonders für Webmaster und -designer interessant ist. Die beiden Projekte [http://www.patrickfrei.ch/webalizer/ Webalizer Xtended] {en} und [http://www.stonesteps.ca/projects/webalizer/ Stone Steps Webalizer] {en} sind Weiterentwicklungen des ursprünglichen Programms und lösen nicht nur dieses Problem. Eine Alternative zu Webalizer ist [wikipedia:AWStats:], dessen Konfiguration allerdings um einiges komplexer ist. Noch umfangreichere Optionen zur Auswertung (u.a. eine Echtzeitanalyse) bieten die Projekte [https://goaccess.io/ GoAccess] {en} und [wikipedia:Piwik:]. = Installation = [[Bild(Wiki/Icons/synaptic.png, 48, align=right)]] Folgendes Paket muss installiert [1] werden: {{{#!vorlage Paketinstallation webalizer, universe }}} = Konfiguration = Webalizer ist unter Ubuntu bereits passend für den Webserver [:Apache:] vorkonfiguriert, so dass man das Programm sofort einsetzen kann – vorausgesetzt, es sind Webserver-Logdateien vorhanden. Wer selbst Hand anlegen will, nimmt Änderungen über die gut dokumentierte Konfigurationsdatei '''/etc/webalizer/webalizer.conf''' vor. Zum Bearbeiten [2] dieser Datei werden Root-Rechte [3] vorausgesetzt. * Um Duplikate in den Logfiles zu ignorieren, wird folgende Option gesetzt: {{{ Incremental yes }}} * Verwendet man statt Apache den Server [:lighttpd:]: {{{ LogFile /var/log/lighttpd/access.log.1 }}} * Und ein anderes Ausgabeverzeichnis (Standard: '''/var/www/webalizer/''') wird so konfiguriert: {{{ OutputDir /var/www/www.beispiel.de/webalizer }}} = Verwendung = [[Bild(./webalizer_statistics.jpg, 200, align=right)]] Das Programm besitzt keine grafische Oberfläche, sondern wird über einen [:Cron:Cronjob] regelmäßig gestartet. Bereits bei der Installation wird über die Datei '''/etc/cron.daily/webalizer''' festgelegt, dass Webalizer automatisch einmal pro Tag startet. Es werden dabei alle '''.conf'''-Dateien unter '''/etc/webalizer/''' verwendet, d.h. man kann z.B. für jeden vHost eine separate anlegen. Direkt nach der Installation und Anpassung der Konfigurationsdatei ist es sinnvoll, das Programm einmalig von Hand zu starten: {{{#!vorlage Befehl sudo /etc/cron.daily/webalizer }}} Die Auswertung erfolgt normalerweise inkrementell, wodurch nur neue Log-Einträge berücksichtigt werden. Weitere Informationen liefert die [:man:Manpage] zum Programm. Das Ergebnis kann mit einem [:Internetanwendungen:Webbrowser] auf zweierlei Arten betrachtet werden: * Öffnen der Datei '''/var/www/webalizer/index.html''' * über den Webserver mit * `http://SERVER-IP/webalizer/` * `http://localhost/webalizer/` (nur auf dem Server selbst möglich) {{{#!vorlage Hinweis Webalizer verwendet in der Standardkonfiguration nicht die aktuelle Logdatei, sondern quasi die "vorletzte" Version. Diese Thematik wird im Artikel [:Logdateien#Logrotate:] näher erläutert. }}} = Problembehebung == == Auswertung in englisch == Wie in der Einleitung erwähnt, richtet sich die in der Auswertung verwendete Sprache nach den Spracheinstellungen. Dies führt unter Umständen zu dem unschönen Effekt, dass der manuelle Aufruf von Webalizer eine deutsche Auswertung, der automatische Aufruf über '''/etc/cron.daily/webalizer''' aber eine englische Auswertung ergibt. Falls diese Situation auftritt, sollte man die systemweiten [:Spracheinstellungen#Systemweite-nderung:] überprüfen. == HostnameLookups aktivieren == In der Monatsauswertung erscheint für die Länder (`Countries` oder `Locations`), aus denen Seiten abgerufen wurden, statt eines bunten Tortendiagramms nur ein einfarbiges mit der Aufschrift ''"unresolved/unknown (100%)"''. Dieses scheinbare Fehlverhalten liegt nicht am Webalizer, sondern ist in der Konfiguration des Webservers begründet: jede Abfrage des Hostnamens erzeugt unnötigen "Traffic" auf dem Webserver. Daher ist die Namensauflösung normalerweise abgeschaltet. Um sie z.B. für den Webserver [:Apache:] zu aktivieren, bearbeitet man mit Root-Rechten die Datei '''/etc/apache2/apache2.conf''' und ändert den Eintrag {{{ HostnameLookups Off }}} in {{{ HostnameLookups On }}} Anschließend muss der Webserver neu gestartet werden. Diese Umstellung gilt nur für neue Log-Einträge. Wer zusätzliche Abfragen während des Betriebs lieber vermeiden möchte, kann auch das Hilfsprogramm logresolv verwenden, um die Adressen im Nachhinein aufzulösen. Dazu folgendes Paket installieren: {{{#!vorlage Paketinstallation apache2-utils }}} == HostnameLookups offline nutzen == Als Alternative zur oben beschriebenen Methode oder wenn die Apache-Konfiguration nicht geändert werden soll/darf, kann die Offline-Geo-Auflösung verwendet werden. Auf der Projektseite gibt es im Downloadbereich die [http://www.webalizer.org/download.html Latest Webalizer GeoDB database] {en} {dl} zum Herunterladen. Die Hostauflösung geschieht dann ausschließlich mit Hilfe einer lokalen Geo-Datenbank. 1. Datenbank herunterladen: {{{#!vorlage Befehl wget ftp://ftp.mrunix.net/pub/webalizer/webalizer-geodb-latest.tgz }}} 1. Nach '''/usr/share/GeoDB''' entpacken: {{{#!vorlage Befehl sudo tar -xzf webalizer-geodb-latest.tgz -C /usr/share/GeoDB }}} 1. In der '''/etc/webalizer/webalizer.conf''' muss dann die GeoDB noch aktiviert werden: {{{ GeoDB yes }}} 1. Der korrekte Pfad zur GeoDB kann ebenfalls in der Konfigurationsdatei von Webalizer angegeben werden, oder man schaut sich die Ausgabe von {{{#!vorlage Befehl webalizer -vV }}} an, wie die Standard-Verzeichnisse lauten. = Links = * [http://www.webalizer.org/ Projektseite] {en} * [wikipedia:Webalizer:] und [wikipedia_en:Webalizer:] - Wikipedia * [http://mikiwiki.org/wiki/Webalizer#Wie_wird_eine_Webalizer-Statistik_gelesen.3F Wie wird eine Webalizer-Statistik gelesen?] {de} - 08/2011 * [http://www.programmierer-forum.de/webalizer-tuning-wie-man-die-auswertung-optimiert-t85297.htm Webalizer Tuning] {de} - wie man die Auswertung optimiert, 01/2009 * [http://www.ubuntugeek.com/webalizer-apache-web-server-log-file-analysis-tool.html Webalizer – Apache web server log file analysis Tool] {en} - UbuntuGeek 06/2008 * [http://www.beesign.com/webdesign/besucher-zaehlen.html Wie die Besucher zählen] {de} - Webalizer, AWStats und Google Analytics im Vergleich * [http://t3n.de/magazin/17-tools-website-analyse-alternativen-google-analytics-222450/ 17 Tools zur Website-Analyse] {de} - Alternativen zu Google Analytics, 10/2009 * [https://kofler.info/web-stats-mit-goaccess/ Web-Stats mit GoAccess] {de} - Blogbeitrag, 04/2017 #tag: Internet, Server