Zend_Log-Overview.xml 9.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155
  1. <!-- EN-Revision: 13840 -->
  2. <sect1 id="zend.log.overview">
  3. <title>Présentation</title>
  4. <para><classname>Zend_Log</classname> est un composant destiné à tous les usages du log. Il supporte l'écriture multiple
  5. centralisée, formate les messages envoyés vers les logs, et les filtre. Ces fonctions sont divisées en objets
  6. suivants : <itemizedlist>
  7. <listitem>
  8. <para>Un enregistreur (instance de <classname>Zend_Log</classname>) est l'objet que votre application emploie le
  9. plus. Vous pouvez avoir autant d'objets d'enregistreur que vous voulez ; ils n'agissent pas l'un sur
  10. l'autre. Un objet enregistreur doit contenir au moins un rédacteur (Writer), et peut facultativement
  11. contenir un ou plusieurs filtres.</para>
  12. </listitem>
  13. <listitem>
  14. <para>Un rédacteur [ou Writer] (hérite de <classname>Zend_Log_Writer_Abstract</classname>) est responsable de la
  15. sauvegarde des données dans le stockage.</para>
  16. </listitem>
  17. <listitem>
  18. <para>Un filtre (implémente <classname>Zend_Log_Filter_Interface</classname>) bloque des données de log ne devant
  19. pas être écrites. Un filtre peut être appliqué à un rédacteur en particulier, ou à tous les rédacteurs.
  20. Dans l'un ou l'autre cas, les filtres peuvent être enchaînés.</para>
  21. </listitem>
  22. <listitem>
  23. <para>Un formateur (implémente <classname>Zend_Log_Formatter_Interface</classname>) peut formater les données de
  24. log avant qu'elles soient écrites par un rédacteur. Chaque rédacteur a exactement un formateur.</para>
  25. </listitem>
  26. </itemizedlist></para>
  27. <sect2 id="zend.log.overview.creating-a-logger">
  28. <title>Créer un log</title>
  29. <para>Pour commencer à enregistrer, instanciez un rédacteur et passez le à une instance d'un enregistreur :
  30. <programlisting role="php"><![CDATA[
  31. $logger = new Zend_Log();
  32. $redacteur = new Zend_Log_Writer_Stream('php://output');
  33. $logger->addWriter($redacteur);
  34. ]]></programlisting> Il est important de noter que l'enregistreur doit avoir au moins un
  35. rédacteur. Vous pouvez ajouter tout nombre de rédacteurs en utilisant la méthode
  36. <code>addWriter()</code>.</para>
  37. <para>Alternativement, vous pouvez passer un rédacteur directement au constructeur de l'enregistreur :
  38. <programlisting role="php"><![CDATA[
  39. $logger = new Zend_Log(new Zend_Log_Writer_Stream('php://output'));
  40. ]]></programlisting>
  41. L'enregistreur est maintenant prêt à être utilisé.</para>
  42. </sect2>
  43. <sect2 id="zend.log.overview.logging-messages">
  44. <title>Messages de logs</title>
  45. <para>Pour enregistrer un message, appelez la méthode <code>log()</code> de l'instance de l'enregistreur et
  46. passez lui le message avec son niveau de priorité. <programlisting role="php"><![CDATA[
  47. $logger->log("Message d'information", Zend_Log::INFO);
  48. ]]></programlisting>
  49. Le premier paramètre de la méthode <code>log()</code> est une chaîne <code>message</code> et le deuxième
  50. paramètre est une <code>priority</code> fourni en nombre entier. La priorité doit être l'une des priorités
  51. identifiées par l'instance de l'enregistreur. Ceci est expliqué dans la prochaine section.</para>
  52. <para>Un raccourci est également disponible. Au lieu d'appeler la méthode <code>log()</code>, vous pouvez
  53. appeler une méthode par le même nom que la priorité : <programlisting role="php"><![CDATA[
  54. $logger->log("Message d'information", Zend_Log::INFO);
  55. $logger->info("Message d'information");
  56. $logger->log("Message d'urgence", Zend_Log::EMERG);
  57. $logger->emerg("Message d'urgence");
  58. ]]></programlisting></para>
  59. </sect2>
  60. <sect2 id="zend.log.overview.destroying-a-logger">
  61. <title>Détruire un log</title>
  62. <para>Si l'objet enregistreur n'est plus nécessaire, vous devez affectez la valeur <code>null</code> à la
  63. variable le contenant pour le détruire. Ceci appellera automatiquement la méthode <code>shutdown()</code> de
  64. chaque rédacteur avant que l'objet enregistreur ne soit détruit : <programlisting role="php"><![CDATA[
  65. $logger = null;
  66. ]]></programlisting>
  67. Explicitement détruire le log de cette façon est facultatif et est exécuté automatiquement à la fermeture de
  68. PHP.</para>
  69. </sect2>
  70. <sect2 id="zend.log.overview.builtin-priorities">
  71. <title>Utiliser les priorités intégrées</title>
  72. <para>La classe de <classname>Zend_Log</classname> définit les priorités suivantes : <programlisting role="php"><![CDATA[
  73. EMERG = 0; // Urgence : le système est inutilisable
  74. ALERT = 1; // Alerte: une mesure corrective
  75. // doit être prise immédiatement
  76. CRIT = 2; // Critique : états critiques
  77. ERR = 3; // Erreur: états d'erreur
  78. WARN = 4; // Avertissement: états d'avertissement
  79. NOTICE = 5; // Notice: normal mais état significatif
  80. INFO = 6; // Information: messages d'informations
  81. DEBUG = 7; // Debug: messages de déboguages
  82. ]]></programlisting> Ces priorités sont toujours disponibles, et une méthode de convenance de même nom est
  83. disponible pour chacun.</para>
  84. <para>Les priorités ne sont pas arbitraires. Elles viennent du protocole BSD <code>syslog</code>, qui est décrit
  85. dans la <ulink url="http://tools.ietf.org/html/rfc3164">RFC-3164</ulink>. Les noms et les niveaux de priorité
  86. correspondants sont également compatibles avec un autre système de log de PHP, <ulink
  87. url="http://pear.php.net/package/log">PEAR Log</ulink>, ce qui favorise l'interopérabilité entre lui et
  88. <classname>Zend_Log</classname>.</para>
  89. <para>Les numéros de priorité descendent par ordre d'importance. <code>EMERG</code> (0) est la priorité la plus
  90. importante. <code>DEBUG</code> (7) est la priorité la moins importante des priorités intégrées. Vous pouvez
  91. définir des priorités d'importance inférieure que <code>DEBUG</code>. En choisissant la priorité pour votre
  92. message de log, faîtes attention à cette hiérarchie prioritaire et choisissez convenablement.</para>
  93. </sect2>
  94. <sect2 id="zend.log.overview.user-defined-priorities">
  95. <title>Ajouter ses propres priorités</title>
  96. <para>Des priorités définies par l'utilisateur peuvent être ajoutées en cours d'exécution en utilisant la
  97. méthode de <code>addPriority()</code> de l'enregistreur : <programlisting role="php"><![CDATA[
  98. $logger->addPriority('ESSAI', 8);
  99. ]]></programlisting>
  100. L'extrait ci-dessus crée une nouvelle priorité, <code>ESSAI</code>, dont la valeur est <code>8</code>. La
  101. nouvelle priorité est alors disponible pour l'enregistreur : <programlisting role="php"><![CDATA[
  102. $logger->log("Message d'essai", 8);
  103. $logger->essai("Message d'essai");
  104. ]]></programlisting> Les nouvelles priorités ne peuvent pas surcharger celles
  105. existantes.</para>
  106. </sect2>
  107. <sect2 id="zend.log.overview.understanding-fields">
  108. <title>Comprendre les événements de logs</title>
  109. <para>Quand vous appelez la méthode <code>log()</code> ou l'un de ses raccourcis, un événement de log est créé.
  110. C'est simplement un tableau associatif avec des données décrivant l'événement qui est envoyé aux rédacteurs. Les
  111. clés suivantes sont toujours créées dans ce tableau : <code>timestamp</code>, <code>message</code>,
  112. <code>priority</code>, et <code>priorityName</code>.</para>
  113. <para>La création du tableau <code>event</code> est complètement transparente. Cependant, la connaissance du
  114. tableau d'événement est exigée pour ajouter un élément qui n'existerait pas dans le réglage par défaut
  115. ci-dessus.</para>
  116. <para>Pour ajouter un nouvel élément à chaque futur événement, appeler la méthode <code>setEventItem()</code> en
  117. donnant une clé et une valeur : <programlisting role="php"><![CDATA[
  118. $logger->setEventItem('pid', getmypid());
  119. ]]></programlisting>
  120. L'exemple ci-dessus place un nouvel élément nommé <code>pid</code> et lui donne comme valeur le PID du processus
  121. courant. Une fois qu'un nouvel élément a été placé, il est disponible automatiquement pour tous les rédacteurs
  122. avec toutes les autres données d'événement pendant l'enregistrement. Un élément peut être surchargé à tout
  123. moment en appelant une nouvelle fois la méthode <code>setEventItem()</code>.</para>
  124. <para>Le réglage d'un nouvel élément d'événement avec <code>setEventItem()</code> entraîne que le nouvel élément
  125. sera envoyé à tous les rédacteurs de l'enregistreur. Cependant, ceci ne garantit pas que les rédacteurs
  126. utilisent réellement l'élément. C'est parce que les rédacteurs ne sauront pas quoi faire avec lui à moins qu'un
  127. objet formateur soit informé du nouvel élément. Veuillez vous reporter à la section sur des formateurs pour en
  128. apprendre davantage.</para>
  129. </sect2>
  130. </sect1>