performance-localization.xml 6.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- EN-Revision: 24249 -->
  3. <!-- Reviewed: no -->
  4. <sect1 id="performance.localization">
  5. <title>Internationalisierung (I18n) und Lokalisierung (L10n)</title>
  6. <para>
  7. Internationalisierte und Lokalisierte Sites sind ein fantastischer Weg um seine
  8. Zuschaueranzahl zu expandieren und sicherzustellen das alle Besucher die Information
  9. bekommen die Sie benötigen. Trotzdem kommt es oft zu einem Geschwindigkeitsverlust. Anbei
  10. sind einige Strategien die man verwenden kann um den Overhead von I18n und L10n zu
  11. verkleinern.
  12. </para>
  13. <sect2 id="performance.localization.translationadapter">
  14. <title>Welchen Übersetzungsadapter sollte ich verwenden?</title>
  15. <para>
  16. Nicht alle Übersetzungadapter sind gleich gemacht. Einige haben mehr Feature als
  17. andere, und einige sind performanter als andere. Zusätzlich kann es sein das man
  18. geschäftliche Notwendigkeiten hat die einen zwingen einen bestimmten Adapter zu
  19. verwenden. Trotzdem, welcher Adapter ist der schnellste, wenn man die Wahl hat?
  20. </para>
  21. <sect3 id="performance.localization.translationadapter.fastest">
  22. <title>Verwende nicht-XML Übersetzungsadapter für die größte Geschwindigkeit</title>
  23. <para>
  24. Zend Framework wird mit einer Vielzahl von Übersetzungsadaptern ausgeliefert. Die
  25. Hälfte von Ihnen verwenden ein <acronym>XML</acronym> Format, welches viel Speicher
  26. benötigt und eine Geschwindkeitseinbuße bedeutet. Glücklicherweise gibt es
  27. verschiedene Adapter die andere Formate verwenden, die viel schneller geparst
  28. werden können. In der Reihenfolge Ihrer Geschwindigkeit, vom Schnellsten zum
  29. Langsamsten, sind das:
  30. </para>
  31. <itemizedlist>
  32. <listitem>
  33. <para>
  34. <emphasis>Array</emphasis>: Das ist der Schnellste, weil er, von seiner
  35. Definition her, sofort in ein natives <acronym>PHP</acronym> Format geparst
  36. und sofort eingefügt wird.
  37. </para>
  38. </listitem>
  39. <listitem>
  40. <para>
  41. <emphasis><acronym>CSV</acronym></emphasis>: Verwendet
  42. <methodname>fgetcsv()</methodname> um eine <acronym>CSV</acronym> Datei zu
  43. parsen und transformiert es in ein natives <acronym>PHP</acronym> Format.
  44. </para>
  45. </listitem>
  46. <listitem>
  47. <para>
  48. <emphasis><acronym>INI</acronym></emphasis>: Verwendet
  49. <methodname>parse_ini_file()</methodname> um eine <acronym>INI</acronym>
  50. Datei zu lesen und Sie in ein natives <acronym>PHP</acronym> Format zu
  51. transformieren. Dieser und der <acronym>CSV</acronym> Adapter sind in Ihrer
  52. Geschwindigkeit ziemlich identisch.
  53. </para>
  54. </listitem>
  55. <listitem>
  56. <para>
  57. <emphasis>Gettext</emphasis>: Der Gettext Adapter von Zend Framework
  58. verwendet <emphasis>nicht</emphasis> die Gettext Erweiterung da diese nicht
  59. Threadsicher ist und es nicht erlaubt mehr als ein Gebietsschema pro Server
  60. zu definieren. Als Ergebnis, ist ist er langsamer als die Gettext
  61. Erweiterung direkt, aber, weil das Gettext Format binär ist, ist es
  62. schneller geparst als <acronym>XML</acronym>.
  63. </para>
  64. </listitem>
  65. </itemizedlist>
  66. <para>
  67. Wenn hohe Geschwindigkeit eine der eigenen Bedenken sind, empfehlen wir die
  68. Verwendung einer der obigen Adapter.
  69. </para>
  70. </sect3>
  71. </sect2>
  72. <sect2 id="performance.localization.cache">
  73. <title>Wie kann ich Übersetzungen und Lokalisierungen sogar noch schneller machen?</title>
  74. <para>
  75. Aus Geschäftsgründen kann es möglich sein, das man auf einen
  76. <acronym>XML</acronym>-basierenden Übersetzungsadapter limitiert ist. Oder vielleicht
  77. will man die Dinge sogar noch schneller machen. Oder vielleicht will man L10n
  78. Operationen schneller machen. Wie kann man das tun?
  79. </para>
  80. <sect3 id="performance.localization.cache.usage">
  81. <title>Verwenden von Übersetzungs und Lokalisierungs Caches</title>
  82. <para>
  83. Beide, <classname>Zend_Translate</classname> und <classname>Zend_Locale</classname>
  84. implementieren eine Caching Funktionalität welche die Geschwindigkeit großartig
  85. verbessern kann. In jedem der Fälle ist dass das Nadelöhr typischerweise das Lesen
  86. der Dateien, nicht das effektive Nachschauen; die Verwendung eines Caches eliminiert
  87. die Notwendigkeit die Übersetzungsdateien und/oder Lokalisierungsdateien zu lesen.
  88. </para>
  89. <para>
  90. Man kann an den folgenden Orten mehr über das Cachen von Übersetzungs und
  91. Lokalisierungsstrings nachlesen:
  92. </para>
  93. <itemizedlist>
  94. <listitem>
  95. <para>
  96. <link
  97. linkend="zend.translate.adapter.caching"><classname>Zend_Translate</classname>
  98. Adapter Caching</link>
  99. </para>
  100. </listitem>
  101. <listitem>
  102. <para>
  103. <link linkend="zend.locale.cache"><classname>Zend_Locale</classname>
  104. Caching</link>
  105. </para>
  106. </listitem>
  107. </itemizedlist>
  108. </sect3>
  109. </sect2>
  110. </sect1>