Différences

Ci-dessous, les différences entre deux révisions de la page.

Lien vers cette vue comparative

Les deux révisions précédentes Révision précédente
Prochaine révision
Révision précédente
awstats [Le 29/07/2010, 18:14]
Gemnoc Mise en forme pour respecter le modèle application.
awstats [Le 15/11/2022, 22:48] (Version actuelle)
thpo [Voir les statistiques dans une belle interface web]
Ligne 50: Ligne 50:
 ==== Tester l'​analyse des logs ==== ==== Tester l'​analyse des logs ====
  
-<​code>​sudo /​usr/​lib/​cgi-bin/​awstats.pl -config=ma_machine.mon_domaine.mon_pays ​update</​code>​+<​code>​sudo /​usr/​lib/​cgi-bin/​awstats.pl -config=ma_machine.mon_domaine.mon_pays ​-update</​code>​
  ... quelques instants plus tard, si tout va bien ...  ... quelques instants plus tard, si tout va bien ...
 <​code>​ <​code>​
Ligne 66: Ligne 66:
 </​code>​ </​code>​
  
-=== Ajouter l'​analyse des logs archivés ===+=== Ajouter l'​analyse des logs archivés:  ​===
  
 <​code>​ <​code>​
 +cd /​var/​lib/​awstats
 +rm *
 cd /​var/​log/​apache* cd /​var/​log/​apache*
- +for i in `ls -tr access.log.*.gz`  
-for i in access.log.*.gzdo +do 
-    zcat $i | /​usr/​lib/​cgi-bin/​awstats.pl -config=ma_machine.mon_domaine.mon_pays ​-update;+ echo "​Fichier traité: $i" 
 + zcat $i | /​usr/​lib/​cgi-bin/​awstats.pl -config=ma_machine_mon_domaine.com -update ​-LogFile=-
 done done
-</​code>​ +</​code> ​FIXME Le script doit être lancé avec sudo.
-<note important>​Ça ne fonctionne pas !!! sans passer l'​argument -LogFile=xxx ça ne fait qu'​analyser n fois le fichier non compressé!!! ​ Utiliser ceci à la place : +
-<​code>​ +
-cd /​var/​log/​apache +
-for f in $(ls -rt access.log.*.gz) ; do +
-  echo "​$f"​ +
-  sudo gzip -d "​$f"​ +
-  sudo /​usr/​lib/​cgi-bin/​awstats.pl -config=ma_machine.mon_domaine.mon_pays -update -LogFile=${f/​.gz/​} +
-  ​sudo gzip "${f/.gz/​}"​ +
-done +
-</​code>​ +
-</​note>​+
  
  
Ligne 94: Ligne 86:
 Il y a un fichier par mois et par site. Il y a un fichier par mois et par site.
  
 +<note tip> 
 +S'il y a des "​trous"​ dans les stats, c'est que le cron est passé par là en cours traitement, solution : 
 +  * commenter les 2 lignes de /​etc/​cron.d/​awstats (ajouter le caractère # devant) 
 +  * lancer le traitement 
 +  * decommenter les lignes (supprimer le #) 
 +</​note>​
 ==== Voir les statistiques dans une belle interface web ==== ==== Voir les statistiques dans une belle interface web ====
  
 D'​abord créez un alias pour apache. D'​abord créez un alias pour apache.
  
-[[[[:​tutoriel:​comment_modifier_un_fichier|Créez le fichier]] **/​etc/​apache2/​sites-available/​awstats** et ajoutez-lui ceci :+[[[[:​tutoriel:​comment_modifier_un_fichier|Créez le fichier]] **/​etc/​apache2/​conf-available/​awstats.conf** et ajoutez-lui ceci :
  
 <​file>​Alias /​awstatsclasses "/​usr/​share/​awstats/​classes/"​ <​file>​Alias /​awstatsclasses "/​usr/​share/​awstats/​classes/"​
Ligne 105: Ligne 102:
 Alias /​awstats-icon "/​usr/​share/​awstats/​icon/"​ Alias /​awstats-icon "/​usr/​share/​awstats/​icon/"​
  
-ScriptAlias /stats /​usr/​lib/​cgi-bin/​awstats.pl+  <​IfVersion < 2.3> 
 +     ScriptAlias /stats /​usr/​lib/​cgi-bin/​awstats.pl 
 +  </​IfVersion> ​   
 +  <​IfVersion >= 2.3> 
 +      ScriptAlias /stats /​usr/​lib/​cgi-bin/​ 
 +   </​IfVersion>​ 
  
 # mêmes paramètres que dans awstats.*.conf # mêmes paramètres que dans awstats.*.conf
Ligne 117: Ligne 120:
   Options +ExecCGI   Options +ExecCGI
   AllowOverride None   AllowOverride None
-  Order allow,​deny +  ​<​IfVersion < 2.3> 
-  Allow from all+      ​Order allow,​deny 
 +      Allow from all 
 +  </​IfVersion>​  
 + <​IfVersion >= 2.3> 
 +      Require all granted 
 +   </​IfVersion>​
 </​Directory>​ </​Directory>​
 </​file>​ </​file>​
-Puis créez un lien symbolique dans **/​etc/​apache2/​sites-enabled** vers ce fichier, ou directement en ligne de commande : 
-<​code>​a2ensite awstats</​code>​ 
  
-Ajustez la gestion des droits d'​accès selon votre besoin de confidentialité ;-) +Ajustez la gestion des droits d'​accès selon votre besoin de confidentialité;​-) 
-<note important>​Attention : dans cet exemple, votre page de statistiques sera accessible pour n'​importe quel utilisateur. Si vous ne souhaitez la rendre accessible que pour vous seul, pensez à modifier la ligne suivante : +<note important>​Attention : dans cet exemple, votre page de statistiques sera accessible pour n'​importe quel utilisateur. Si vous ne souhaitez la rendre accessible que pour vous seul, pensez à modifier la ligne suivante :
 <​code>​Allow from all</​code>​ en <​code>​Allow from 127.0.0.1</​code> ​ <​code>​Allow from all</​code>​ en <​code>​Allow from 127.0.0.1</​code> ​
 </​note>​ </​note>​
  
-Enjoy :+<note important>​Attention ​Si vous souhaitez protéger l’accès à votre page de statistiques AWStats en utilisant l'​authentification apache. Il faudra éditer **/​etc/​apache2/​conf-available/​serve-cgi-bin.conf** et remplacer : 
 +<​code>​AllowOverride None</​code>​ en <​code>​AllowOverride AuthConfig</​code>​  
 +</​note>​ 
 + 
 +Activer la configuration créée \\ 
 +<​code>​a2enconf awstats</​code>​ 
 + 
 +Relancer apache \\ 
 +<​code>​systemctl reload apache2</​code>​
  
 +Enjoy : \\
 http://​ma_machine.mon_domaine.mon_pays/​cgi-bin/​awstats.pl http://​ma_machine.mon_domaine.mon_pays/​cgi-bin/​awstats.pl
 et même si tout va bien : et même si tout va bien :
 http://​ma_machine.mon_domaine.mon_pays/​stats/​ http://​ma_machine.mon_domaine.mon_pays/​stats/​
  
 +Il se peut que le code ne soit pas interprété par le navigateur. Il faut alors permettre l'​exécution des scripts cgi par apache. On active le module cgi \\
 +<​code>​a2enmod cgi</​code>​
 +Relancer apache \\
 +<​code>​systemctl reload apache2</​code>​
 ===== Ajouter des plugins à Awstats ===== ===== Ajouter des plugins à Awstats =====
  
Ligne 150: Ligne 169:
   * Récuperer la base GeoIp [[http://​www.maxmind.com/​download/​geoip/​database/​GeoLiteCountry/​|à l'​adresse suivante]]. Vous pourrez téléchargez cette base tous les mois (car MaxMind la met à jour mensuellement).   * Récuperer la base GeoIp [[http://​www.maxmind.com/​download/​geoip/​database/​GeoLiteCountry/​|à l'​adresse suivante]]. Vous pourrez téléchargez cette base tous les mois (car MaxMind la met à jour mensuellement).
  
-  * Placez le fichier dans le fichier ​**/​usr/​share/​awstats/​lib/​**,​ puis dézippez le avec la commande //gunzip GeoIP.dat.gz//​+  * Placez le fichier dans le répertoire ​**/​usr/​share/​awstats/​lib/​**,​ puis dézippez le avec la commande //gunzip GeoIP.dat.gz//​
  
 <note tip>Vous pouvez automatiser ces deux étapes en rajoutant par exemple dans [[cron]] (dans un terminal, tapez **sudo crontab -e**) la commande : <note tip>Vous pouvez automatiser ces deux étapes en rajoutant par exemple dans [[cron]] (dans un terminal, tapez **sudo crontab -e**) la commande :
Ligne 156: Ligne 175:
 </​note>​ </​note>​
  
-  * Ensuite, il vous faut récupérer le fichier **PurePerl.pm** que vous trouverez à l'​adresse [[http://www.maxmind.com/​download/​geoip/​api/​pureperl/​|http://www.maxmind.com/​download/​geoip/​api/​pureperl/​]]. Vous devrez désarchiver le fichier (version actuelle: **Geo-IP-PurePerl-1.25.tar.gz**) avec la commande //tar xzf Geo-IP-PurePerl-1.25.tar.gz//​+  * Ensuite, il vous faut récupérer le fichier **PurePerl.pm** que vous trouverez à l'​adresse [[http://geolite.maxmind.com/​download/​geoip/​api/​pureperl/​Geo-IP-PurePerl-1.25.tar.gz]] . Vous devrez désarchiver le fichier (version actuelle: **Geo-IP-PurePerl-1.25.tar.gz**) avec la commande //tar xzf Geo-IP-PurePerl-1.25.tar.gz//​
  
   * Copiez le fichier PurePerl.pm qui se trouve le répertoire lib/Geo/Ip dans le répertoire /​usr/​share/​awstats/​lib/​   * Copiez le fichier PurePerl.pm qui se trouve le répertoire lib/Geo/Ip dans le répertoire /​usr/​share/​awstats/​lib/​
Ligne 162: Ligne 181:
   * Modifiez le fichier PurePerl.pm aux alentours de la ligne 213 (Fonction: //sub new//) en indiquant le chemin absolu d'​accès à la base GeoIP.dat (/​usr/​share/​awstats/​lib/​)   * Modifiez le fichier PurePerl.pm aux alentours de la ligne 213 (Fonction: //sub new//) en indiquant le chemin absolu d'​accès à la base GeoIP.dat (/​usr/​share/​awstats/​lib/​)
  
-  * Modifiez le fichier **geoip.pm** dans le répertoire /​usr/​share/​awstats/​plugins,​ à la ligne **if (!eval ('​require "​Geo/​IP/​PurePerl.pm"​)) {** (aux alentours de la ligne 20, entête de la fonction: # ENTER HERE THE USE COMMAND FOR ALL REQUIRED PERL MODULES) en remplaçant **Geo/​IP/​PurePerl.pm** par le chemin absolu du fichier **/​usr/​share/​awstats/​lib/​PurePerl.pm** ​+  * Modifiez le fichier **geoip.pm** dans le répertoire /​usr/​share/​awstats/​plugins,​ à la ligne **if (!eval ('​require "​Geo/​IP/​PurePerl.pm"​)) {** (aux alentours de la ligne 21, entête de la fonction: # ENTER HERE THE USE COMMAND FOR ALL REQUIRED PERL MODULES) en remplaçant **Geo/​IP/​PurePerl.pm** par le chemin absolu du fichier **/​usr/​share/​awstats/​lib/​PurePerl.pm**
  
   * Ensuite, il ne vous reste plus qu'à ajouter le code suivant à la fin de votre fichier de configuration de votre site :<​file>#​ Plugin: GeoIP   * Ensuite, il ne vous reste plus qu'à ajouter le code suivant à la fin de votre fichier de configuration de votre site :<​file>#​ Plugin: GeoIP
Ligne 168: Ligne 187:
 # Country chart is built from an Internet IP-Country database. # Country chart is built from an Internet IP-Country database.
 # This plugin is useless for intranet only log files. # This plugin is useless for intranet only log files.
-# Note: You must choose between using this plugin (need Perl Geo::IP module ​+# Note: You must choose between using this plugin (need Perl Geo::IP module
 # from Maxmind, database more up to date) or the GeoIPfree plugin (need # from Maxmind, database more up to date) or the GeoIPfree plugin (need
 # Perl Geo::IPfree module, database less up to date). # Perl Geo::IPfree module, database less up to date).
Ligne 177: Ligne 196:
 <note help>Si après ceci vous obtenez : <note help>Si après ceci vous obtenez :
 <​code>​Error:​ Plugin init for plugin '​geoip'​ failed with return code: Undefined subroutine &​Geo::​IP::​GEOIP_STANDARD called at /​usr/​share/​awstats/​plugins/​geoip.pm line 69. (A module required by plugin might be missing).</​code> ​ <​code>​Error:​ Plugin init for plugin '​geoip'​ failed with return code: Undefined subroutine &​Geo::​IP::​GEOIP_STANDARD called at /​usr/​share/​awstats/​plugins/​geoip.pm line 69. (A module required by plugin might be missing).</​code> ​
-Il faut aussi modifier le fichier **/​usr/​share/​awstats/​plugins/​geoip.pm** à la ligne 197 <​code>​$type='​geoip';</​code>​ par <​code>​$type='​geoippureperl';</​code>​+Il faut aussi modifier le fichier **/​usr/​share/​awstats/​plugins/​geoip.pm** à la ligne 17 <​code>​$type='​geoip';</​code>​ par <​code>​$type='​geoippureperl';</​code>​
 </​note>​ </​note>​
  
Ligne 281: Ligne 300:
  
 <​code>​ <​code>​
-0,10,​20,​30,​40,​50 ​* * * * www-data [ -x /​usr/​lib/​cgi-bin/​awstats.pl -a -f /​etc/​awstats/​awstats.conf -a -r /​var/​log/​apache/​access.log ] && /​usr/​lib/​cgi-bin/​aws+*/10 * * * * www-data [ -x /​usr/​lib/​cgi-bin/​awstats.pl -a -f /​etc/​awstats/​awstats.conf -a -r /​var/​log/​apache/​access.log ] && /​usr/​lib/​cgi-bin/​aws
 tats.pl -config=awstats -update >/​dev/​null tats.pl -config=awstats -update >/​dev/​null
 </​code>​ </​code>​
Ligne 288: Ligne 307:
  
 <​code>​ <​code>​
-0,10,​20,​30,​40,​50 ​* * * *+*/10 * * * *
 </​code>​ </​code>​
  
Ligne 372: Ligne 391:
 Vous avez ainsi la liste de toutes les tâches qui s'​effectueront automatiquement. Vous avez ainsi la liste de toutes les tâches qui s'​effectueront automatiquement.
  
 +=== Solution 4 ===
 +
 +//(Ne connaissant ni emacs, ni nano, je propose **vi** qui est fourni de base :D )//
 +
 +Si vous avez respecte le format de noms de fichier de config : /​etc/​awstats///​awstats.DOMAINE.TLD.conf//​
 +
 +Alors il existe une solution pour mettre a jour l'​ensemble de vos stats
 +
 +<​code>​
 +vi /​etc/​cron.d/​awstats
 +</​code>​
 +
 +Par exemple pour une generation des stats toutes les dix minutes,
 +sur l'​ensemble de vos fichiers (verifiez le chemin des fichiers) :
 +
 +<​code>​
 +*/10 * * * * root /​usr/​share/​doc/​awstats/​examples/​awstats_updateall.pl -awstatsprog=/​usr/​lib/​cgi-bin/​awstats.pl now > /dev/null
 +</​code>​
  
 ==== logrotate (rotation des logs) ==== ==== logrotate (rotation des logs) ====
Ligne 412: Ligne 449:
 </​code>​ </​code>​
  
 +==== Dans le cas d'un serveur apache2 avec la directive ChrootDir ====
  
 +Comme le serveur **apache2** fonctionne en environnemnt chrooté, awstats ne peux pas être installé en tant que script CGI, (Perl n'est pas présent dans le chroot). Il sera donc installé en dehors, avec une génération de pages statiques accessibles par le serveur **Apache**.
  
 +=== Création du fichier d'un configuration awstats spécifique ===
  
 +<code bash>
 +sudo sh -c "zcat /​usr/​share/​doc/​awstats/​examples/​awstats.model.conf.gz > /​etc/​awstats/​awstats.www.ubuntu-fr.org.conf"​
 +sudo chmod 644 /​etc/​awstats/​awstats.www.ubuntu-fr.org.conf
 +</​code>​
  
 +Editez ensuite ce fichier et modifiez les lignes suivantes pour mettre les paramètres adapté à votre configuration :
 +
 +<code file>
 +LogFile="/​var/​log/​apache2/​access_log"​
 +SiteDomain="​www.ubuntu-fr.org"​
 +DNSLookup=1
 +</​code>​
 +
 +<​note>​Vous pouvez aussi modifier le paramètre //​HostAliases//​ si vous utilisez plusieurs VirtualHost.</​note>​
 +
 +Premier lancement : <code bash>​sudo /​usr/​lib/​cgi-bin/​awstats.pl -config=www.ubuntu-fr.org -update</​code>​ et vérifiez ainsi qu'il n'y a pas d'​erreur dans la configuration.
 +
 +=== Génération des pages statiques et création du cron ===
 +
 +Génération des pages statiques :
 +<code bash>
 +sudo mkdir /​web-chroot/​www/​awstats
 +sudo cp -R /​usr/​share/​awstats/​icon/​ /​web-chroot/​www/​awstats/​icones
 +</​code>​
 +
 +<​note>​
 +C'est un choix personnel de copier les icônes directement dans le dossier où seront placées les pages statiques générées.
 +</​note>​
 +
 +Créez ensuite le fichier **/​etc/​cron.daily/​awstats** contenant les lignes suivantes :
 +
 +<code bash>
 +#!/bin/bash
 +
 +/​usr/​share/​doc/​awstats/​examples/​awstats_buildstaticpages.pl -config=www.ubuntu-fr.org -update -lang=fr -dir=/​web-chroot/​www/​awstats/​ -awstatsprog=/​usr/​lib/​cgi-bin/​awstats.pl -diricons=/​icones
 +</​code>​
 +
 +Changez lui ses droits : <code bash>​sudo chmod 755 /​etc/​cron.daily/​awstats</​code>​ Puis exécutez le une première fois.
 +
 +=== Création d'un site pour accéder à ces pages générées ===
 +
 +Créez le fichier // /​etc/​apache2/​sites-available/​awstats // et ajoutez-lui ceci :
 +
 +<code file>
 +<​VirtualHost *:80>
 + ServerAdmin email@site.com
 + ServerName awstats.ubuntu-fr.org
 + DocumentRoot /​web-chroot/​www/​awstats/​
 + ErrorLog /​var/​www/​ubuntu-fr.org/​logs/​error.log
 + CustomLog /​var/​www/​ubuntu-fr.org/​logs/​.access.log combined
 +</​VirtualHost>​
 +</​code>​
 +
 +Puis lancer la ligne de commande : <code bash>​sudo a2ensite awstats</​code>​
 +
 +Ajustez la gestion des droits d'​accès selon votre besoin de confidentialité
 +
 +=== Test final ===
 +
 +Dans votre navigateur préféré: taper l'URL: [[http://​awstats.ubuntu-fr.org/​]]
 +
 +=== Source ===
 +
 +  * [[http://​nicolas.agius.pagesperso-orange.fr/​linux/​docs/​awstats.htm]]
 ===== Statistiques des mails (Postfix) ===== ===== Statistiques des mails (Postfix) =====
 +
 +==== Configuration classique =====
  
 **Procéder ainsi :** **Procéder ainsi :**
Ligne 466: Ligne 571:
    ​ShowSMTPErrorsStats=1    ​ShowSMTPErrorsStats=1
  
-Lancer la mise à jour des statistiques : +Lancer la mise à jour des statistiques :
  
    sudo /​usr/​lib/​cgi-bin/​awstats.pl -config=mails -update    sudo /​usr/​lib/​cgi-bin/​awstats.pl -config=mails -update
Ligne 478: Ligne 583:
    "​-config=mails -update"​    "​-config=mails -update"​
  
 +==== Configuration multi-instance postfix =====
 +
 +Exemple de 2 files postfix: une pour le système et l'​autre pour un service quelconque, nommées respectivement postfix et postfix-service. Les 2 instances génères des logs dans le fichier // /​var/​log/​mail.log //.
  
 +  * Rendez-vous dans le répertoire de configuration de awstats : <code bash>cd /​etc/​awstats</​code>​
 +  * Créez le fichier **awstats.mails-service.conf**:​ <code bash>​sudo cp awstats-mails.conf awstats.mails-service.conf</​code>​
 +  * Modifiez le champ suivant :<code file>​LogFile="​grep postfix-service /​var/​log/​mail.log | sed -e "​s:​postfix-service:​postfix:"​ | perl /​usr/​share/​doc/​awstats/​examples/​maillogconvert.pl standard |"</​code>​
 +  * Lancer la mise à jour des statistiques :<code bash>​sudo /​usr/​lib/​cgi-bin/​awstats.pl -config=mails-service -update</​code>​
 +  * Pour la mise à jour automatique des statistiques,​ cf solution 3 en remplaçant :<code file>​-config=votredomaine.tld -update</​code>​par<​code file>​-config=mails -update</​code>​
 ===== Voir aussi ===== ===== Voir aussi =====
  
   * **(en)** [[http://​awstats.sourceforge.net|Site officiel de AWStats]]   * **(en)** [[http://​awstats.sourceforge.net|Site officiel de AWStats]]
-  * [[http://​www.system-linux.eu/​index.php?​post/​2008/​12/​04/​Statistique-pour-vos-sites-internet|Piwik]] - une alternative à Awstats qui n'​utilise pas les logs apache, et qui produit des statistiques utilisant des graphiques en flash+  * [[https://​www.system-linux.eu/​index.php?​post/​2008/​12/​04/​Statistique-pour-vos-sites-internet|Piwik]] - une alternative à Awstats qui n'​utilise pas les logs apache, et qui produit des statistiques utilisant des graphiques en flash
   * [[http://​www.mrunix.net/​webalizer/​|Webalizer]] - une alternative à Awstats.   * [[http://​www.mrunix.net/​webalizer/​|Webalizer]] - une alternative à Awstats.
   * [[http://​pwet.fr/​blog/​statistiques_web_avec_awstats_sous_ubuntu_en_mode_cgi|Statistiques web avec AWStats sous Ubuntu en mode CGI]]   * [[http://​pwet.fr/​blog/​statistiques_web_avec_awstats_sous_ubuntu_en_mode_cgi|Statistiques web avec AWStats sous Ubuntu en mode CGI]]
-  * [[http://​www.baudelet.net/​awstats-plugins.htm|Extras et plugins sur Baudelet]]+  * [[https://​www.baudelet.net/​awstats-plugins.htm|Extras et plugins sur Baudelet]]
   * [[http://​dedibox.echosblogs.org/​post/​608/​1754|Configurer sa Dédibox sous Ubuntu 6.06 LTS]]   * [[http://​dedibox.echosblogs.org/​post/​608/​1754|Configurer sa Dédibox sous Ubuntu 6.06 LTS]]
  
 ---- ----
 //​Contributeurs : ...// //​Contributeurs : ...//
  • awstats.1280420091.txt.gz
  • Dernière modification: Le 18/04/2011, 14:44
  • (modification externe)