2
0

Zend_Db_Profiler.xml 17 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- EN-Revision: 17178 -->
  3. <!-- Reviewed: no -->
  4. <sect1 id="zend.db.profiler" xmlns:xi="http://www.w3.org/2001/XInclude">
  5. <title>Zend_Db_Profiler</title>
  6. <sect2 id="zend.db.profiler.introduction">
  7. <title>Introduction</title>
  8. <para>
  9. <classname>Zend_Db_Profiler</classname> peut être activé pour permettre le
  10. profilage de requête. Les profils incluent les requêtes exécutées par l'adaptateur,
  11. ainsi que leur temps d'exécution, permettant l'inspection des requêtes qui ont été
  12. exécutées sans avoir besoin de rajouter le code spécifique de débogage aux classes.
  13. L'utilisation avancée permet aussi au développeur de filtrer quelles requêtes il
  14. souhaite profiler.
  15. </para>
  16. <para>
  17. Le profileur s'active soit en passant une directive au constructeur de
  18. l'adaptateur, soit en spécifiant à l'adaptateur de l'activer plus tard.
  19. </para>
  20. <programlisting language="php"><![CDATA[
  21. $params = array(
  22. 'host' => '127.0.0.1',
  23. 'username' => 'webuser',
  24. 'password' => 'xxxxxxxx',
  25. 'dbname' => 'test',
  26. 'profiler' => true // active le profileur ;
  27. // mettre à false pour désactiver
  28. // (désactivé par défaut)
  29. );
  30. $db = Zend_Db::factory('PDO_MYSQL', $params);
  31. // stoppe le profileur :
  32. $db->getProfiler()->setEnabled(false);
  33. // active le profileur :
  34. $db->getProfiler()->setEnabled(true);
  35. ]]></programlisting>
  36. <para>
  37. La valeur de l'option <code>profiler</code> est souple. Elle est interprétée
  38. différemment suivant son type. La plupart du temps, vous devriez simplement utiliser une
  39. variable booléenne, mais d'autres valeurs vous permettent de personnaliser le
  40. comportement du profileur.
  41. </para>
  42. <para>
  43. Un argument booléen active le profileur si c'est une valeur <constant>TRUE</constant>, ou
  44. le désactive si <constant>FALSE</constant>. La classe de profileur est celle par défaut, par
  45. exemple <classname>Zend_Db_Profiler</classname>. <programlisting language="php"><![CDATA[
  46. $params['profiler'] = true;
  47. $db = Zend_Db::factory('PDO_MYSQL', $params);
  48. ]]></programlisting>
  49. </para>
  50. <para>
  51. Une instance d'un objet profileur fait que l'adaptateur utilise cet objet. L'objet
  52. doit être de type <classname>Zend_Db_Profiler</classname> ou une sous-classe.
  53. L'activation du profileur est faite séparément. <programlisting language="php"><![CDATA[
  54. $profiler = Mon_Db_Profiler();
  55. $profiler->setEnabled(true);
  56. $params['profiler'] = $profiler;
  57. $db = Zend_Db::factory('PDO_MYSQL', $params);
  58. ]]></programlisting>
  59. </para>
  60. <para>
  61. L'argument peut être un tableau associatif contenant une ou toutes les clés
  62. suivantes : "<code>enabled</code>", "<code>instance</code>", et "<code>class</code>".
  63. Les clés "<code>enabled</code>" et "<code>instance</code>" correspondent aux types
  64. booléen et instance décrites ci-dessus. La clé "<code>class</code>" est utilisée pour
  65. nommer une classe à prendre en tant que profileur personnalisé. La classe doit être de
  66. type <classname>Zend_Db_Profiler</classname> ou une sous-classe. La classe est
  67. instanciée sans aucun argument de constructeur. L'option "<code>class</code>" est
  68. ignorée quand l'option "<code>instance</code>" est fournie. <programlisting
  69. role="php"><![CDATA[
  70. $params['profiler'] = array(
  71. 'enabled' => true,
  72. 'class' => 'Mon_Db_Profiler'
  73. );
  74. $db = Zend_Db::factory('PDO_MYSQL', $params);
  75. ]]></programlisting>
  76. </para>
  77. <para>
  78. Enfin, l'argument peut être un objet de type <classname>Zend_Config</classname>
  79. contenant des propriétés, qui sont traitées comme les clés de tableaux décrites
  80. ci-dessus. Par exemple, une fichier "config.ini" peut contenir les données
  81. suivantes&#160;:
  82. <programlisting language="ini"><![CDATA[
  83. [main]
  84. db.profiler.class = "Mon_Db_Profiler"
  85. db.profiler.enabled = true
  86. ]]></programlisting>
  87. Cette configuration peut être appliquée par le code PHP suivant&#160;:
  88. <programlisting language="php"><![CDATA[
  89. $config = new Zend_Config_Ini('config.ini', 'main');
  90. $params['profiler'] = $config->db->profiler;
  91. $db = Zend_Db::factory('PDO_MYSQL', $params);
  92. ]]></programlisting>
  93. La propriété "<code>instance</code>" peut être utilisée comme ceci&#160;:
  94. <programlisting language="php"><![CDATA[
  95. $profiler = new Mon_Db_Profiler();
  96. $profiler->setEnabled(true);
  97. $configData = array(
  98. 'instance' => $profiler
  99. );
  100. $config = new Zend_Config($configData);
  101. $params['profiler'] = $config;
  102. $db = Zend_Db::factory('PDO_MYSQL', $params);
  103. ]]></programlisting>
  104. </para>
  105. </sect2>
  106. <sect2 id="zend.db.profiler.using">
  107. <title>Utiliser le profileur</title>
  108. <para>
  109. A n'importe quel moment, vous pouvez récupérer le profileur en utilisant la
  110. méthode <methodname>getProfiler()</methodname> de l'adaptateur&#160;:
  111. </para>
  112. <programlisting language="php"><![CDATA[
  113. $profileur = $db->getProfiler();
  114. ]]></programlisting>
  115. <para>
  116. Ceci retourne une instance de <classname>Zend_Db_Profiler</classname>. Avec cette
  117. instance, le développeur peut examiner les requêtes en utilisant un éventail de
  118. méthodes&#160;:
  119. </para>
  120. <itemizedlist>
  121. <listitem>
  122. <para>
  123. <methodname>getTotalNumQueries()</methodname> retourne le nombre total de requêtes
  124. profilées.
  125. </para>
  126. </listitem>
  127. <listitem>
  128. <para>
  129. <methodname>getTotalElapsedSecs()</methodname> retourne le nombre total de secondes
  130. écoulées pour chaque requête profilée.
  131. </para>
  132. </listitem>
  133. <listitem>
  134. <para>
  135. <methodname>getQueryProfiles()</methodname> retourne un tableau de tous les profils de
  136. requêtes.
  137. </para>
  138. </listitem>
  139. <listitem>
  140. <para>
  141. <methodname>getLastQueryProfile()</methodname> retourne le profil de requête le plus
  142. récent, peut importe si la requête à fini de s'exécuter ou pas (si l'exécution
  143. n'est pas finie, le temps de fin sera <constant>NULL</constant>).
  144. </para>
  145. </listitem>
  146. <listitem>
  147. <para><methodname>clear()</methodname> nettoie tous les anciens profils de la pile.</para>
  148. </listitem>
  149. </itemizedlist>
  150. <para>
  151. La valeur de retour de <methodname>getLastQueryProfile()</methodname> et les éléments
  152. individuels de <methodname>getQueryProfiles()</methodname> sont des objets de type
  153. <classname>Zend_Db_Profiler_Query</classname> qui permettent d'inspecter les
  154. requêtes&#160;:
  155. </para>
  156. <itemizedlist>
  157. <listitem>
  158. <para>
  159. <methodname>getQuery()</methodname> retourne le <acronym>SQL</acronym> de la requête sous forme de texte.
  160. Le texte de <acronym>SQL</acronym> d'une requête préparée avec des paramètres est le texte au
  161. moment où la requête a été préparée, donc il contient les emplacements de
  162. paramètre, mais pas les valeurs utilisées quand la déclaration est
  163. exécutée.
  164. </para>
  165. </listitem>
  166. <listitem>
  167. <para>
  168. <methodname>getQueryParams()</methodname> retourne un tableau des valeurs de
  169. paramètres utilisées lors de l'exécution d'une requête préparée. Ceci inclue à
  170. la fois les paramètres attachés et les arguments de de la méthode
  171. <methodname>execute()</methodname>. Les clés du tableau sont les positions (base 1) ou les
  172. noms des paramètres.
  173. </para>
  174. </listitem>
  175. <listitem>
  176. <para>
  177. <methodname>getElapsedSecs()</methodname> retourne le nombre de secondes d'exécution
  178. de la requête.
  179. </para>
  180. </listitem>
  181. </itemizedlist>
  182. <para>
  183. L'information que <classname>Zend_Db_Profiler</classname> fourni est utile pour
  184. profiler des goulots d'étranglement dans les applications, ainsi que pour déboguer les
  185. requêtes qui viennent d'être exécutées. Par exemple, pour voir la dernière requête qui
  186. vient de s'exécuter&#160;:
  187. </para>
  188. <programlisting language="php"><![CDATA[
  189. $query = $profileur->getLastQueryProfile();
  190. echo $query->getQuery();
  191. ]]></programlisting>
  192. <para>
  193. Si une page se génère lentement, utilisez le profileur pour déterminer le nombre
  194. total de requêtes, et ensuite passer d'une requête à l'autre pour voir laquelle a été la
  195. plus longue&#160;:
  196. </para>
  197. <programlisting language="php"><![CDATA[
  198. $tempsTotal = $profileur->getTotalElapsedSecs();
  199. $nombreRequetes = $profileur->getTotalNumQueries();
  200. $tempsLePlusLong = 0;
  201. $requeteLaPlusLongue = null;
  202. foreach ($profileur->getQueryProfiles() as $query) {
  203. if ($query->getElapsedSecs() > $tempsLePlusLong) {
  204. $tempsLePlusLong = $query->getElapsedSecs();
  205. $requeteLaPlusLongue = $query->getQuery();
  206. }
  207. }
  208. echo 'Exécution de '
  209. . $nombreRequetes
  210. . ' requêtes en '
  211. . $tempsTotal
  212. . ' secondes' . "\n";
  213. echo 'Temps moyen : '
  214. . $tempsTotal / $nombreRequetes
  215. . ' secondes' . "\n";
  216. echo 'Requêtes par seconde: '
  217. . $nombreRequetes / $tempsTotal
  218. . ' seconds' . "\n";
  219. echo 'Requête la plus lente (secondes) : '
  220. . $tempsLePlusLong . "\n";
  221. echo "Requête la plus lente (SQL) : \n"
  222. . $requeteLaPlusLongue . "\n";
  223. ]]></programlisting>
  224. </sect2>
  225. <sect2 id="zend.db.profiler.advanced">
  226. <title>Utilisation avancée du profileur</title>
  227. <para>
  228. En plus de l'inspection de requête, le profileur permet aussi au développeur de
  229. filtrer quelles requêtes il veut profiler. Les méthodes suivantes fonctionnent avec une
  230. instance de <classname>Zend_Db_Profiler</classname>&#160;:
  231. </para>
  232. <sect3 id="zend.db.profiler.advanced.filtertime">
  233. <title>Filtrer par temps d'exécution</title>
  234. <para>
  235. <methodname>setFilterElapsedSecs()</methodname> permet au développeur de définir un temps
  236. minimum d'exécution de la requête avant que celle-ci soit profilée. Pour retirer le
  237. filtre, passez une valeur <constant>NULL</constant> à la méthode.
  238. </para>
  239. <programlisting language="php"><![CDATA[
  240. // Seules les requêtes qui durent au moins 5 secondes sont profilées :
  241. $profileur->setFilterElapsedSecs(5);
  242. // Profil de toutes les requêtes, peu importe leur durée :
  243. $profileur->setFilterElapsedSecs(null);
  244. ]]></programlisting>
  245. </sect3>
  246. <sect3 id="zend.db.profiler.advanced.filtertype">
  247. <title>Filtrer par type de requête</title>
  248. <para>
  249. <methodname>setFilterQueryType()</methodname> permet au développeur de définir quels types
  250. de requêtes doivent être profilées ; pour profiler des types multiples vous pouvez
  251. utiliser le OU logique. Les types de requêtes sont définis sous forme de constantes
  252. de <classname>Zend_Db_Profiler</classname>&#160;:
  253. </para>
  254. <itemizedlist>
  255. <listitem>
  256. <para>
  257. <classname>Zend_Db_Profiler::CONNECT</classname>&#160;: opérations de
  258. connexion ou de sélection de base de données.
  259. </para>
  260. </listitem>
  261. <listitem>
  262. <para>
  263. <classname>Zend_Db_Profiler::QUERY</classname>&#160;: requête générale qui
  264. ne correspond pas aux autres types.
  265. </para>
  266. </listitem>
  267. <listitem>
  268. <para>
  269. <classname>Zend_Db_Profiler::INSERT</classname>&#160;: toute requête qui
  270. ajoute des données dans la base de données, généralement INSERT.
  271. </para>
  272. </listitem>
  273. <listitem>
  274. <para>
  275. <classname>Zend_Db_Profiler::UPDATE</classname>&#160;: toute requête qui
  276. met à jour des données, généralement UPDATE.
  277. </para>
  278. </listitem>
  279. <listitem>
  280. <para>
  281. <classname>Zend_Db_Profiler::DELETE</classname>&#160;: toute requête qui
  282. efface des données, généralement DELETE.
  283. </para>
  284. </listitem>
  285. <listitem>
  286. <para>
  287. <classname>Zend_Db_Profiler::SELECT</classname>&#160;: toute requête qui
  288. récupère des données, généralement SELECT.
  289. </para>
  290. </listitem>
  291. <listitem>
  292. <para>
  293. <classname>Zend_Db_Profiler::TRANSACTION</classname>&#160;: toute requête
  294. qui concerne des opérations de transaction, comme start transaction, commit,
  295. ou rollback.
  296. </para>
  297. </listitem>
  298. </itemizedlist>
  299. <para>
  300. Comme avec <methodname>setFilterElapsedSecs()</methodname>, vous pouvez retirer tous les
  301. filtres en passant <constant>NULL</constant> comme unique argument.
  302. </para>
  303. <programlisting language="php"><![CDATA[
  304. // profile uniquement les requêtes SELECT
  305. $profileur->setFilterQueryType(Zend_Db_Profiler::SELECT);
  306. // profile les requêtes SELECT, INSERT, et UPDATE
  307. $profileur->setFilterQueryType(Zend_Db_Profiler::SELECT
  308. | Zend_Db_Profiler::INSERT
  309. | Zend_Db_Profiler::UPDATE);
  310. // profile les requêtes DELETE
  311. $profileur->setFilterQueryType(Zend_Db_Profiler::DELETE);
  312. // Efface tous les filtres
  313. $profileur->setFilterQueryType(null);
  314. ]]></programlisting>
  315. </sect3>
  316. <sect3 id="zend.db.profiler.advanced.getbytype">
  317. <title>Récupérer les profils par type de requête</title>
  318. <para>
  319. Utiliser <methodname>setFilterQueryType()</methodname> peut réduire les profils générés.
  320. Cependant il est parfois utile de garder tous les profils et voir uniquement ceux
  321. dont on a besoin, à un moment donné. Une autre possibilité de
  322. <methodname>getQueryProfiles()</methodname> est qu'il est possible de filtrer à la volée, en
  323. passant un type de requête (ou une combinaison logique de types de requête) comme
  324. premier argument ; voir <xref linkend="zend.db.profiler.advanced.filtertype" /> pour
  325. la liste des constantes de types de requête.
  326. </para>
  327. <programlisting language="php"><![CDATA[
  328. // Récupère uniquement les profils des requêtes SELECT
  329. $profiles = $profiler->getQueryProfiles(Zend_Db_Profiler::SELECT);
  330. // Récupère uniquement les profils des requêtes :
  331. // SELECT, INSERT, et UPDATE
  332. $profiles = $profiler->getQueryProfiles(Zend_Db_Profiler::SELECT
  333. | Zend_Db_Profiler::INSERT
  334. | Zend_Db_Profiler::UPDATE);
  335. // Récupère uniquement les profils des requêtes DELETE
  336. // (on peut donc comprendre pourquoi les données disparaissent)
  337. $profiles = $profiler->getQueryProfiles(Zend_Db_Profiler::DELETE);
  338. ]]></programlisting>
  339. </sect3>
  340. </sect2>
  341. <sect2 id="zend.db.profiler.profilers">
  342. <title>Profileurs spécialisés</title>
  343. <para>
  344. Un profileur spécialisé est un objet qui hérite de
  345. <classname>Zend_Db_Profiler</classname>. Les profileurs spécialisés traitent les
  346. informations de profilage de manière spécifique.
  347. </para>
  348. <xi:include href="Zend_Db_Profiler-Firebug.xml" />
  349. </sect2>
  350. </sect1>