EinführungZend_TimeSync ist fähig, die Internet- oder Netzwerkzeit von einem
Zeitserver zu empfangen, indem es das NTP oder
SNTP Protokoll verwendet. Mit Zend_TimeSync
wird Zend Framework ermöglicht, unabhängig von den Zeiteinstellungen des Servers, auf dem es
läuft, zu agieren.
Um unabhängig von der aktuellen Zeit des Servers zu sein, arbeitet
Zend_TimeSync intern nur mit dem Unterschied der wirklichen Zeit der
über NTP oder SNTP empfangenen und der internen Zeit des Servers.
HintergrundZend_TimeSync ist nicht fähig die Zeit des Servers zu ändern,
jedoch gibt es eine Instanz von Zend_Date
zurück, mit der der Unterschied zur Serverzeit verarbeitet werden kann.
Warum Zend_TimeSync ?
Warum würde jemand Zend_TimeSync verwenden ?
Normalerweise hat jeder Server in einer Multiserver Farm einen Service laufen, der die
eigene Zeit mit einem Zeitserver syncronisiert. In einer Standardumgebung sollte es
also nicht notwendig sein, Zend_TimeSync zu verwenden. Aber
manchmal ist es sehr nützlich, wenn es keinen Service gibt und wenn man nicht das Recht
hat, einen solchen Service zu installieren.
Hier sind ein paar Beispiele, wo Zend_TimeSync perfekt passt:
Server ohne Zeitservice
Wenn eine Anwendung auf einem Server läuft und auf diesem Server kein
Zeitservice läuft, kann es Sinn machen Zend_TimeSync in
der eigenen Anwendung zu verwenden.
Separater Datenbank Server
Wenn eine Datenbank auf einem anderen Server läuft und dieser Server
nicht mit NTP oder SNTP an dem
Anwendungsserver angebunden ist, kann man Probleme haben, Zeitstempel zu
speichern und zu verwenden.
Mehrere Server
Wenn die Anwendung auf mehr als einem Server läuft, und die Zeitbasis dieser
Server nicht miteinander gekoppelt ist, kann das zu Problemen in der Anwendung
führen, wenn Teile der Anwendung von einem Server und andere von einem anderen
Server kommen.
Batch Ausführung
Wenn man mit einem Zeitserver arbeiten oder in einer Batchdatei oder in einer
Kommandozeilen Anwendung verwenden möchte, kann
Zend_TimeSync nützlich sein.
Zend_TimeSync kann in allen diesen Fällen eine gute Lösung bieten
und kann verwendet werden, wenn man nicht in der Lage ist, Services auf dem Server zu
starten.
Was ist NTP ?
Das Network Time Protocol (NTP) ist
ein Protokoll für die Synchronisierung von mehreren Systemuhren über
Paket-geführte, variabel laufende Datennetzwerke. NTP verwendet den UDP Port 123 als
Transportschicht. Siehe diesen Wikipedia
Artikel für Details über das Protokoll.
Was ist SNTP?
Das Simple Network Time Protocol (SNTP)
ist ein Protokoll für die Synchronisierung von mehreren Systemuhren über
Paket-geführte, variabel laufende Datennetzwerke. SNTP verwendet den UDP Port 37 als
Transportschicht. Es ist fast identisch mit dem Network Time Protokoll, aber
einfacher.
Problematische Verwendung
Vorsicht das man sich, wenn Zend_TimeSync verwendet wird, einige
Gedanken über Details, betreffend der Struktur von Zeitsynchronisierung und dem Internet
selbst machen muß. Die richtige Verwendung und die beste Praxis werden hier beschrieben.
Bevor man Zend_TimeSync verwendet, sollte das hier sorgfältig
durchgelesen werden.
Auswählen welcher Server verwendet werden soll
Der Zeitserver, der verwendet werden soll, muß anhand der folgenden Kriterien, sehr
sorgfältig ausgewählt werden:
Distanz
Die Distanz vom Server auf dem die Anwendung läuft und dem angefragten
Zeitserver. Wenn der Server in Europa lokalisiert ist, macht es wenig Sinn,
einen Zeitserver aus Tahiti zu verwenden. Es sollte immer ein Server
ausgewählt werden, der nicht weit entfernt ist. Das reduziert die Zeit für die
Anfrage und es reduziert die Last im Netzwerk.
Geschwindigkeit
Wie lange es dauert, eine Anfrage zu empfangen ist auch relevant. Es sollten
andere Server probiert werden, um das beste Ergebnis zu erhalten. Wenn ein
Server angefragt wird, auf den nie zugegriffen werden kann, wird man immer
unnötige Verzögerungen haben.
Aufteilung
Es sollte nicht immer der gleiche Server verwendet werden. Alle Zeitserver
sperren Anfragen von Servern, welche sie überfluten. Wenn eine Anwendung
exzessiv Zeitserver verwendet, sollte man, wie anbei beschrieben einen Pool
verwenden.
Wo kann man also einen Zeitserver finden? Generell kann jeder bekannte Zeitserver
verwendet werden. Das kann ein Zeitserver im eigenen LAN oder ein öffentlicher
Zeitserver sein, auf den man Zugriff hat. Wenn man sich für einen öffentlichen
Zeitserver entscheidet, sollte man einen Pool-Server verwenden. Serverpools sind
öffentliche Adressen, von denen man einen zufälligen Zeitserver auf dem Pool erhält,
wenn man die Zeit anfrägt. Auf diesem Weg muss man seine Anfragen nicht aufteilen. Es
gibt öffentliche Serverpools für verschiedene Regionen, so dass man die vorher erwähnten
Probleme nicht hat.
Siehe pool.ntp.org, um den
am nächsten liegenden Serverpool zu finden. Wenn zum Beispiel der eigene Server also
in Deutschland liegt, kann man sich auf 0.europe.pool.ntp.org
verbinden.