Serveur Apache HTTP Version 2.5
Description: | Fournit des informations sur les performances et l'activité du serveur |
---|---|
Statut: | Base |
Identificateur de Module: | status_module |
Fichier Source: | mod_status.c |
Le module Status permet à un administrateur de déterminer le niveau de performances de son serveur. Les statistiques instantanées du serveur sont présentées dans une page HTML sous une forme aisément lisible. Si nécessaire, cette page peut être configurée pour être automatiquement actualisée (sous réserve de compatibilité du navigateur). Une autre page fournit l'état instantané du serveur sous la forme d'une simple liste lisible par une machine.
Les détails fournis sont :
Les lignes se terminant par "(*)" ne sont disponibles que si la
directive ExtendedStatus
est définie à On
. Depuis la version
2.3.6, le chargement de mod_status définit automatiquement
ExtendedStatus
à On.
mod_status
est chargé, son
gestionnaire sera disponible dans tous les fichiers de
configuration, y compris ceux concernant un répertoire (comme les fichiers
.htaccess
). Ce comportement doit donc être pris en compte pour la
gestion de la sécurité de votre site.
Ce module ne fournit aucune directive.
Pour n'activer les rapports d'état que pour les navigateurs
appartenant au domaine example.com, ajoutez ces lignes à votre
fichier de configuration httpd.conf
:
<Location "/etat-serveur"> SetHandler server-status Require host example.com </Location>
Il est alors possible d'obtenir les statistiques du serveur en
utilisant un navigateur web et en accédant à la page
http://votre.serveur/etat-serveur
.
Vous pouvez faire en sorte que cette page d'état s'actualise
elle-même automatiquement si votre navigateur supporte "refresh".
Pour ce faire, accédez à la page
http://votre.serveur/etat-serveur?refresh=N
, pour que
cette dernière soit actualisée toutes les N secondes.
La page http://votre.serveur/etat-serveur?auto
permet d'obtenir une version du fichier d'état lisible par une
machine. Ceci s'avère intéressant dans le cadre d'une exécution
automatique : voir le programme en Perl
log_server_status
situé dans le répertoire
/support
de votre distribution du serveur HTTP Apache.
La page server-status
peut servir de point de départ
à la recherche de défauts de fonctionnement lorsque votre serveur
mobilise toutes les ressources disponibles (CPU ou mémoire), pour
identifier quels clients ou requêtes sont la cause du problème.
Tout d'abord, assurez-vous que la directive ExtendedStatus
est bien définie à on, de
façon à ce que vous puissiez avoir accès à toutes les informations à
propos de la requête et du client pour chaque processus enfant ou
thread.
Consultez ensuite la liste des processus en cours (à l'aide de
top
, ou d'un utilitaire de listage des processus
similaire), afin d'identifier les processus coupables. Triez
l'affichage de top
par utilisation CPU ou mémoire, en
fonction du problème rencontré.
Rechargez la page server-status
et recherchez
les identifiants des processus trouvés précédemment ; vous pourrez
alors déterminer quelle requête est traitée par ces processus, pour
quel client. Les requêtes peuvent apparaître de manière fugitive, et
il se peut que vous deviez effectuer plusieurs essais avant de
parvenir à les prendre en flagrant délit, pour ainsi dire.
Cette procédure devrait vous permettre de cerner quel client, ou type de requête, sont à l'origine de vos problèmes de charge. Il est probable que vous identifiiez une application web au comportement anormal, ou un client en train d'attaquer votre site.