Zend_TimeSync.xml 8.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- EN-Revision: 19568 -->
  3. <!-- Reviewed: no -->
  4. <sect1 id="zend.timesync.introduction">
  5. <title>Einführung</title>
  6. <para>
  7. <classname>Zend_TimeSync</classname> ist fähig, die Internet- oder Netzwerkzeit von einem
  8. Zeitserver zu empfangen, indem es das <emphasis>NTP</emphasis> oder
  9. <emphasis>SNTP</emphasis> Protokoll verwendet. Mit <classname>Zend_TimeSync</classname>
  10. wird Zend Framework ermöglicht, unabhängig von den Zeiteinstellungen des Servers, auf dem es
  11. läuft, zu agieren.
  12. </para>
  13. <para>
  14. Um unabhängig von der aktuellen Zeit des Servers zu sein, arbeitet
  15. <classname>Zend_TimeSync</classname> intern nur mit dem Unterschied der wirklichen Zeit der
  16. über NTP oder SNTP empfangenen und der internen Zeit des Servers.
  17. </para>
  18. <note>
  19. <title>Hintergrund</title>
  20. <para>
  21. <classname>Zend_TimeSync</classname> ist nicht fähig die Zeit des Servers zu ändern,
  22. jedoch gibt es eine Instanz von <link linkend="zend.date.introduction">Zend_Date</link>
  23. zurück, mit der der Unterschied zur Serverzeit verarbeitet werden kann.
  24. </para>
  25. </note>
  26. <sect2 id="zend.timesync.introduction.why">
  27. <title>Warum Zend_TimeSync ?</title>
  28. <para>
  29. Warum würde jemand <classname>Zend_TimeSync</classname> verwenden ?
  30. </para>
  31. <para>
  32. Normalerweise hat jeder Server in einer Multiserver Farm einen Service laufen, der die
  33. eigene Zeit mit einem Zeitserver syncronisiert. In einer Standardumgebung sollte es
  34. also nicht notwendig sein, <classname>Zend_TimeSync</classname> zu verwenden. Aber
  35. manchmal ist es sehr nützlich, wenn es keinen Service gibt und wenn man nicht das Recht
  36. hat, einen solchen Service zu installieren.
  37. </para>
  38. <para>
  39. Hier sind ein paar Beispiele, wo <classname>Zend_TimeSync</classname> perfekt passt:
  40. </para>
  41. <itemizedlist mark='opencircle'>
  42. <listitem>
  43. <para>
  44. <emphasis>Server ohne Zeitservice</emphasis>
  45. </para>
  46. <para>
  47. Wenn eine Anwendung auf einem Server läuft und auf diesem Server kein
  48. Zeitservice läuft, kann es Sinn machen <classname>Zend_TimeSync</classname> in
  49. der eigenen Anwendung zu verwenden.
  50. </para>
  51. </listitem>
  52. <listitem>
  53. <para>
  54. <emphasis>Separater Datenbank Server</emphasis>
  55. </para>
  56. <para>
  57. Wenn eine Datenbank auf einem anderen Server läuft und dieser Server
  58. nicht mit <emphasis>NTP</emphasis> oder <emphasis>SNTP</emphasis> an dem
  59. Anwendungsserver angebunden ist, kann man Probleme haben, Zeitstempel zu
  60. speichern und zu verwenden.
  61. </para>
  62. </listitem>
  63. <listitem>
  64. <para>
  65. <emphasis>Mehrere Server</emphasis>
  66. </para>
  67. <para>
  68. Wenn die Anwendung auf mehr als einem Server läuft, und die Zeitbasis dieser
  69. Server nicht miteinander gekoppelt ist, kann das zu Problemen in der Anwendung
  70. führen, wenn Teile der Anwendung von einem Server und andere von einem anderen
  71. Server kommen.
  72. </para>
  73. </listitem>
  74. <listitem>
  75. <para>
  76. <emphasis>Batch Ausführung</emphasis>
  77. </para>
  78. <para>
  79. Wenn man mit einem Zeitserver arbeiten oder in einer Batchdatei oder in einer
  80. Kommandozeilen Anwendung verwenden möchte, kann
  81. <classname>Zend_TimeSync</classname> nützlich sein.
  82. </para>
  83. </listitem>
  84. </itemizedlist>
  85. <para>
  86. <classname>Zend_TimeSync</classname> kann in allen diesen Fällen eine gute Lösung bieten
  87. und kann verwendet werden, wenn man nicht in der Lage ist, Services auf dem Server zu
  88. starten.
  89. </para>
  90. </sect2>
  91. <sect2 id="zend.timesync.introduction.ntp">
  92. <title>Was ist NTP ?</title>
  93. <para>
  94. Das Network Time Protocol (<emphasis>NTP</emphasis>) ist
  95. ein Protokoll für die Synchronisierung von mehreren Systemuhren über
  96. Paket-geführte, variabel laufende Datennetzwerke. NTP verwendet den UDP Port 123 als
  97. Transportschicht. Siehe <ulink
  98. url="http://en.wikipedia.org/wiki/Network_Time_Protocol">diesen Wikipedia
  99. Artikel</ulink> für Details über das Protokoll.
  100. </para>
  101. </sect2>
  102. <sect2 id="zend.timesync.introduction.sntp">
  103. <title>Was ist SNTP?</title>
  104. <para>
  105. Das Simple Network Time Protocol (<emphasis>SNTP</emphasis>)
  106. ist ein Protokoll für die Synchronisierung von mehreren Systemuhren über
  107. Paket-geführte, variabel laufende Datennetzwerke. SNTP verwendet den UDP Port 37 als
  108. Transportschicht. Es ist fast identisch mit dem Network Time Protokoll, aber
  109. einfacher.
  110. </para>
  111. </sect2>
  112. <sect2 id="zend.timesync.introduction.problematic">
  113. <title>Problematische Verwendung</title>
  114. <para>
  115. Vorsicht das man sich, wenn <classname>Zend_TimeSync</classname> verwendet wird, einige
  116. Gedanken über Details, betreffend der Struktur von Zeitsynchronisierung und dem Internet
  117. selbst machen muß. Die richtige Verwendung und die beste Praxis werden hier beschrieben.
  118. Bevor man <classname>Zend_TimeSync</classname> verwendet, sollte das hier sorgfältig
  119. durchgelesen werden.
  120. </para>
  121. </sect2>
  122. <sect2 id="zend.timesync.introduction.decision">
  123. <title>Auswählen welcher Server verwendet werden soll</title>
  124. <para>
  125. Der Zeitserver, der verwendet werden soll, muß anhand der folgenden Kriterien, sehr
  126. sorgfältig ausgewählt werden:
  127. </para>
  128. <itemizedlist mark='opencircle'>
  129. <listitem>
  130. <para>
  131. Distanz
  132. </para>
  133. <para>
  134. Die Distanz vom Server auf dem die Anwendung läuft und dem angefragten
  135. Zeitserver. Wenn der Server in Europa lokalisiert ist, macht es wenig Sinn,
  136. einen Zeitserver aus Tahiti zu verwenden. Es sollte immer ein Server
  137. ausgewählt werden, der nicht weit entfernt ist. Das reduziert die Zeit für die
  138. Anfrage und es reduziert die Last im Netzwerk.
  139. </para>
  140. </listitem>
  141. <listitem>
  142. <para>
  143. Geschwindigkeit
  144. </para>
  145. <para>
  146. Wie lange es dauert, eine Anfrage zu empfangen ist auch relevant. Es sollten
  147. andere Server probiert werden, um das beste Ergebnis zu erhalten. Wenn ein
  148. Server angefragt wird, auf den nie zugegriffen werden kann, wird man immer
  149. unnötige Verzögerungen haben.
  150. </para>
  151. </listitem>
  152. <listitem>
  153. <para>
  154. Aufteilung
  155. </para>
  156. <para>
  157. Es sollte nicht immer der gleiche Server verwendet werden. Alle Zeitserver
  158. sperren Anfragen von Servern, welche sie überfluten. Wenn eine Anwendung
  159. exzessiv Zeitserver verwendet, sollte man, wie anbei beschrieben einen Pool
  160. verwenden.
  161. </para>
  162. </listitem>
  163. </itemizedlist>
  164. <para>
  165. Wo kann man also einen Zeitserver finden? Generell kann jeder bekannte Zeitserver
  166. verwendet werden. Das kann ein Zeitserver im eigenen LAN oder ein öffentlicher
  167. Zeitserver sein, auf den man Zugriff hat. Wenn man sich für einen öffentlichen
  168. Zeitserver entscheidet, sollte man einen Pool-Server verwenden. Serverpools sind
  169. öffentliche Adressen, von denen man einen zufälligen Zeitserver auf dem Pool erhält,
  170. wenn man die Zeit anfrägt. Auf diesem Weg muss man seine Anfragen nicht aufteilen. Es
  171. gibt öffentliche Serverpools für verschiedene Regionen, so dass man die vorher erwähnten
  172. Probleme nicht hat.
  173. </para>
  174. <para>
  175. Siehe <ulink url="http://www.pool.ntp.org">pool.ntp.org</ulink>, um den
  176. am nächsten liegenden Serverpool zu finden. Wenn zum Beispiel der eigene Server also
  177. in Deutschland liegt, kann man sich auf <emphasis>0.europe.pool.ntp.org</emphasis>
  178. verbinden.
  179. </para>
  180. </sect2>
  181. </sect1>