Zend_Log-Overview.xml 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- Reviewed: no -->
  3. <!-- EN-Revision: 24604 -->
  4. <sect1 id="zend.log.overview">
  5. <title>概要</title>
  6. <para>
  7. <classname>Zend_Log</classname> は、ログ出力用の汎用コンポーネントです。
  8. 複数のバックエンドに対応しており、ログに出力するメッセージをフォーマットしたり
  9. 記録するメッセージをフィルタリングしたりできます。
  10. これらの関数は、以下のオブジェクトに分けられています。
  11. <itemizedlist>
  12. <listitem>
  13. <para>
  14. ログ (<classname>Zend_Log</classname> のインスタンス) は、
  15. アプリケーション内でもっともよく使用するオブジェクトです。
  16. いくつでも望みの数だけのログオブジェクトを保持できます。
  17. それらが互いに影響しあうことはありません。
  18. ログオブジェクトには最低ひとつのライターが含まれる必要があり、
  19. オプションでひとつあるいは複数のフィルタを含むことができます。
  20. </para>
  21. </listitem><listitem>
  22. <para>
  23. ライター (<classname>Zend_Log_Writer_Abstract</classname> を継承したもの)
  24. は、データを保存する役割を受け持ちます。
  25. </para>
  26. </listitem><listitem>
  27. <para>
  28. フィルタ (<classname>Zend_Log_Filter_Interface</classname> を実装したもの)
  29. は、保存するログデータをブロックします。
  30. フィルタは個々のライターに適用することもできますし、
  31. ログに適用することもできます。ログに適用した場合は、
  32. すべてのライターの前に適用されます。どちらの場合についても、
  33. 複数のフィルタを連結することが可能です。
  34. </para>
  35. </listitem><listitem>
  36. <para>
  37. フォーマッタ (<classname>Zend_Log_Formatter_Interface</classname> を実装したもの)
  38. は、ログのデータをライターに書き出す前に書式設定できます。
  39. 個々のライターは、それぞれひとつのフォーマッタを保持しています。
  40. </para>
  41. </listitem>
  42. </itemizedlist>
  43. </para>
  44. <sect2 id="zend.log.overview.creating-a-logger">
  45. <title>ログの作成</title>
  46. <para>
  47. ログの記録を開始するには、ライターのインスタンスを作成し、
  48. それをログのインスタンスに渡します。
  49. </para>
  50. <programlisting language="php"><![CDATA[
  51. $logger = new Zend_Log();
  52. $writer = new Zend_Log_Writer_Stream('php://output');
  53. $logger->addWriter($writer);
  54. ]]></programlisting>
  55. <para>
  56. 注意すべき点は、ログには最低ひとつのライターが必要であるということです。
  57. ライターはお好みの数だけ追加できます。追加するには
  58. ログの <methodname>addWriter()</methodname> メソッドを使用します。
  59. </para>
  60. <para>
  61. 一方、ログのコンストラクタで直接ライターを指定することも可能です。
  62. </para>
  63. <programlisting language="php"><![CDATA[
  64. $writer = new Zend_Log_Writer_Stream('php://output');
  65. $logger = new Zend_Log($writer);
  66. ]]></programlisting>
  67. <para>
  68. これで、ログが使用できるようになりました。
  69. </para>
  70. </sect2>
  71. <sect2 id="zend.log.overview.logging-messages">
  72. <title>メッセージの記録</title>
  73. <para>
  74. メッセージをログに記録するには、ログのインスタンスの <methodname>log()</methodname>
  75. メソッドを実行し、メッセージと優先度を渡します。
  76. </para>
  77. <programlisting language="php"><![CDATA[
  78. $logger->log('Informational message', Zend_Log::INFO);
  79. ]]></programlisting>
  80. <para>
  81. <methodname>log()</methodname> メソッドの最初のパラメータは文字列の <property>message</property> で、
  82. 二番目のパラメータは整数の <property>priority</property> です。
  83. 優先度は、ログのインスタンスが理解できる形式の値のいずれかでなければなりません。
  84. これについては次の節で説明します。
  85. </para>
  86. <para>
  87. こちらも別の方法が使用できます。<methodname>log()</methodname> メソッドをコールするかわりに、
  88. 優先度と同じ名前のメソッドをコールできます。
  89. </para>
  90. <programlisting language="php"><![CDATA[
  91. $logger->log('Informational message', Zend_Log::INFO);
  92. $logger->info('Informational message');
  93. $logger->log('Emergency message', Zend_Log::EMERG);
  94. $logger->emerg('Emergency message');
  95. ]]></programlisting>
  96. </sect2>
  97. <sect2 id="zend.log.overview.destroying-a-logger">
  98. <title>ログの破棄</title>
  99. <para>
  100. ログオブジェクトが不要になったら、ログオブジェクトを指す変数に
  101. <constant>NULL</constant> を代入してそれを破棄しましょう。これは、
  102. アタッチされている各ライターのインスタンスメソッド
  103. <methodname>shutdown()</methodname> をコールしてからログオブジェクトを破棄します。
  104. </para>
  105. <programlisting language="php"><![CDATA[
  106. $logger = null;
  107. ]]></programlisting>
  108. <para>
  109. このように明示的にログを破棄することは必須ではありません。
  110. <acronym>PHP</acronym> の終了時に、この処理が自動的に行われます。
  111. </para>
  112. </sect2>
  113. <sect2 id="zend.log.overview.builtin-priorities">
  114. <title>組み込みの優先度の使用</title>
  115. <para>
  116. <classname>Zend_Log</classname> クラスでは以下の優先度を定義しています。
  117. </para>
  118. <programlisting language="php"><![CDATA[
  119. EMERG = 0; // 緊急事態 (Emergency): システムが使用不可能です
  120. ALERT = 1; // 警報 (Alert): 至急対応が必要です
  121. CRIT = 2; // 危機 (Critical): 危機的な状況です
  122. ERR = 3; // エラー (Error): エラーが発生しました
  123. WARN = 4; // 警告 (Warning): 警告が発生しました
  124. NOTICE = 5; // 注意 (Notice): 通常動作ですが、注意すべき状況です
  125. INFO = 6; // 情報 (Informational): 情報メッセージ
  126. DEBUG = 7; // デバッグ (Debug): デバッグメッセージ
  127. ]]></programlisting>
  128. <para>
  129. これらの優先度は常に使用可能で、それぞれについて
  130. 同じ名前のメソッドが用意されています。
  131. </para>
  132. <para>
  133. これらの優先度は適当に指定しているわけではありません。
  134. もとは BSD の syslog プロトコルに由来するもので、
  135. <ulink url="http://tools.ietf.org/html/rfc3164">RFC-3164</ulink>
  136. で示されています。それぞれの名前と優先度番号は、<acronym>PHP</acronym> におけるもうひとつのログ記録システムである
  137. <ulink url="http://pear.php.net/package/log">PEAR Log</ulink>
  138. とも互換性があります。おそらく、これと <classname>Zend_Log</classname>
  139. は相互運用できるでしょう。
  140. </para>
  141. <para>
  142. 優先度の数値が小さいほど優先度が高くなります。<code>EMERG</code> (0)
  143. が最重要な優先度で、<constant>DEBUG</constant> (7) は
  144. 組み込みの優先度の中ではもっとも優先度が低いものです。
  145. <constant>DEBUG</constant> より低い優先度を定義することもできます。
  146. メッセージをログに記録する際には、この優先度の階層に注意し、適切なものを選択するようにしましょう。
  147. </para>
  148. </sect2>
  149. <sect2 id="zend.log.overview.user-defined-priorities">
  150. <title>ユーザ定義の優先度の追加</title>
  151. <para>
  152. ユーザ定義の優先度を実行時に追加するには、ログの
  153. <methodname>addPriority()</methodname> メソッドを使用します。
  154. </para>
  155. <programlisting language="php"><![CDATA[
  156. $logger->addPriority('FOO', 8);
  157. ]]></programlisting>
  158. <para>
  159. 上の例では、新しい優先度 <constant>FOO</constant> を
  160. '8' という値で定義しています。これで、次のようにして新しい優先度でログ出力できるようになります。
  161. </para>
  162. <programlisting language="php"><![CDATA[
  163. $logger->log('Foo message', 8);
  164. $logger->foo('Foo Message');
  165. ]]></programlisting>
  166. <para>
  167. 新しい優先度は、既存のものを上書きすることはできません。
  168. </para>
  169. </sect2>
  170. <sect2 id="zend.log.overview.understanding-fields">
  171. <title>ログのイベントについて理解する</title>
  172. <para>
  173. <methodname>log()</methodname> メソッドやその仲間をコールした際に、
  174. ログのイベントが作成されます。これは単純な連想配列で、
  175. ライターに渡されるイベントの内容を表します。この配列には、
  176. <property>timestamp</property>、<property>message</property>、<property>priority</property> および
  177. <property>priorityName</property> のキーが常に存在します。
  178. </para>
  179. <para>
  180. <property>event</property> 配列の作成は完全に透過的です。
  181. しかし、<property>event</property> 配列について知っておかないと、
  182. 上で示した既存のセットに含まれない項目を追加できません。
  183. </para>
  184. <para>
  185. 将来のイベントにたいして常に特定の項目を追加するようにするには、
  186. <methodname>setEventItem()</methodname> メソッドをコールしてキーと値を指定します。
  187. </para>
  188. <programlisting language="php"><![CDATA[
  189. $logger->setEventItem('pid', getmypid());
  190. ]]></programlisting>
  191. <para>
  192. 上の例は、<property>pid</property> という名前の新しい項目を作成して現在のプロセスの
  193. PID を格納します。新しい値が設定されると、他のすべてのイベントデータと同様に
  194. すべてのライターから自動的にアクセス可能となります。項目を上書きするには、
  195. もう一度好きなときに <methodname>setEventItem()</methodname> メソッドをコールします。
  196. </para>
  197. <para>
  198. 新しいイベント項目を <methodname>setEventItem()</methodname> で設定すると、
  199. ロガーのすべてのライターに新しい項目を送信します。しかし、
  200. これはそれらのライターが実際にその項目を書き出すことを保証するものではありません。
  201. フォーマッタオブジェクトがその新しい項目のことを教えない限り、
  202. ライターはそれをどう扱っていいのかわからないからです。
  203. さらに詳しく学ぶには、フォーマッタの節を参照ください。
  204. </para>
  205. </sect2>
  206. <sect2 id="zend.log.overview.as-errorHandler">
  207. <title>PHP のエラーを記録</title>
  208. <para>
  209. <classname>Zend_Log</classname> は、<acronym>PHP</acronym> のエラーを記録するためにも使えます。
  210. <methodname>registerErrorHandler()</methodname> を呼び出すと、現行のエラーハンドラの前に
  211. <classname>Zend_Log</classname> を追加して、同様に一緒にエラーを渡します。
  212. </para>
  213. <para>
  214. PHP エラー由来の Zend_Log イベントには、
  215. <ulink url="http://php.net/manual/ja/function.set-error-handler.php">set_error_handler</ulink> 由来の
  216. <methodname>handler ( int $errno , string $errstr [, string $errfile [, int $errline [, array $errcontext ]]] )</methodname>
  217. に一致する追加の項目があります
  218. </para>
  219. <table id="zend.log.overview.as-errorHandler.properties.table-1">
  220. <title>PHP エラー由来の Zend_Log イベント用の追加項目</title>
  221. <tgroup cols="3">
  222. <thead>
  223. <row>
  224. <entry>名前</entry>
  225. <entry>エラーハンドラ・パラメータ</entry>
  226. <entry>説明</entry>
  227. </row>
  228. </thead>
  229. <tbody>
  230. <row>
  231. <entry>message</entry>
  232. <entry>errstr</entry>
  233. <entry>エラーメッセージ(文字列)</entry>
  234. </row>
  235. <row>
  236. <entry>errno</entry>
  237. <entry>errno</entry>
  238. <entry>エラーの発生レベル(整数)</entry>
  239. </row>
  240. <row>
  241. <entry>file</entry>
  242. <entry>errfile</entry>
  243. <entry>エラーが発生したファイル名(文字列)</entry>
  244. </row>
  245. <row>
  246. <entry>line</entry>
  247. <entry>errline</entry>
  248. <entry>エラーが発生した行番号(整数)</entry>
  249. </row>
  250. <row>
  251. <entry>context</entry>
  252. <entry>errcontext</entry>
  253. <entry>
  254. (任意) エラーが発生した場所のアクティブシンボルテーブルを指す配列。
  255. つまり、エラーが発生したスコープ内に存在するすべての変数の配列です。
  256. ユーザエラーハンドラは、決してエラーコンテキストを書き換えてはいけません。
  257. </entry>
  258. </row>
  259. </tbody>
  260. </tgroup>
  261. </table>
  262. </sect2>
  263. </sect1>