2038

2038
Exemplarische Darstellung des Jahr-2038-Problems

Das Jahr-2038-Problem könnte zu Softwareausfällen im Jahr 2038 führen. Dieses Problem ist auf EDV-Systeme beschränkt, die den POSIX-Zeitstandard benutzen und time_t als 32-Bit-Binärzahl definieren.

POSIX zählt die seit dem 1. Januar 1970 abgelaufene Zeit in Sekunden. Am 19. Januar 2038 um 03:14:08 Uhr UTC wird die Anzahl der vergangenen Sekunden die Kapazität einer 31-Bit-Zahl (maximal 2147483647) überschreiten. Das signifikanteste Bit wird laut Konvention dazu verwendet, positive und negative Zahlen zu unterscheiden (Vorzeichen im Zweierkomplement), so dass die Zählung bei einer Überschreitung des Wertes 2147483647 (binär 1111111111111111111111111111111) in den negativen Bereich springt (z.B. 2147483648 binär 10000000000000000000000000000000). Dies führt bei einer ungenügendend implementierten Konvertierung von Unixtime zu Datum und Uhrzeit ungewollt zu einem Wert vor Epoche (1. Januar 1970). Dieses Problem wird in der Softwareentwicklung als Zählerüberlauf (Counterwrap) bezeichnet.

Im Vergleich zum Jahr-2000-Problem, welches im Wesentlichen beim Datumsstempel von Dateien auftrat, führt das Jahr-2038-Problem zu Fehlern bei elektronischen Transaktionen, die die Unixzeit als Zeitstempel verwenden. Ohne Gegenmaßnahmen könnten die wirtschaftlichen Auswirkungen verheerend sein, zumal im Banken- und Versicherungsumfeld Unix-Systeme neben Mainframes zur Standardausstattung gehören.

Ein Beispiel für typische Jahr-2038-Fehler sind Transaktionen, deren Gültigkeit vom Zeitstempel des Ergebnisfeldes abgeleitet wird. Ist das Ergebnis nicht jünger als die Ausgangsdaten, so wird weiterhin auf ein gültiges Ergebnis gewartet oder die Transaktion irgendwann automatisch neu angestoßen. Am Stichtag des Jahr-2038-Problems werden allerdings sämtliche Ergebnisse den vermeintlichen Zeitstempel Dezember 1901 tragen, sind also immer älter als die Eingabedaten. Wartende Programme geraten so leicht in Endlosschleifen, was sich für den Endbenutzer in „abgestürzten“ Anwendungen äußert – z. B. ein Geldautomat, der ewig auf die elektronische Bestätigung der Kontenabbuchung wartet, bevor er Geld ausgibt.

Abhilfe

Schon deutlich vor dem Jahr 2038 wird der Unixzeit-Zähler in den Systemen voraussichtlich als 64-Bit-Zähler implementiert. Dies hängt damit zusammen, dass die unixtypische C-Definition auf den Basistyp „long“ verweist. Es hat sich bereits heute im Unixumfeld durchgesetzt, dass beim Übergang von 32-Bit- zu 64-Bit-Architekturen eben dieser Basistyp auf 64-Bit wechselt (technisch: Umstellung von ILP32 auf LP64-Modell), so dass Zeitstempel zumindest systemseitig als 64-Bit time_t geliefert werden.

Dennoch reicht eine Umstellung auf neue 64-Bit-Prozessorarchitekturen (AMD64/EM64T, Itanium/IA-64, IBM Power 5, UltraSPARC, PA-RISC, MIPS) hier alleine nicht aus: Sie vereinfacht zwar die systemseitige Anpassung, macht jedoch die Durchforstung und Neu-Übersetzung aller Programme mit starrer 32-Bit-Formatierung nicht überflüssig. Nicht alle Programme sind bereits 64-Bit-tauglich und es ist leicht möglich, dass vom System gelieferte 64-Bit-Zeitstempel fälschlicherweise als 32-Bit weiterverarbeitet werden und somit nur die unteren 32 Bit abgefragt werden, welche dann losgelöst wiederum am 19. Januar 2038 den Wert −231 = 13. Dezember 1901 annehmen.

Durch die 64-Bit-Umstellung kann der POSIX-Zeitstempel weitere 292 Milliarden Jahre zuverlässig arbeiten, ohne dass es zu einem Überlauf kommt.


Wikimedia Foundation.

Игры ⚽ Нужно решить контрольную?

Schlagen Sie auch in anderen Wörterbüchern nach:

  • 2038 — (MMXXXVIII) will be a common year starting on Friday of the Gregorian calendar. Predicted events* January 5 Annular solar eclipse in the Caribbean Sea, Atlantic Ocean, and western Africa. * January 19 A common computing representation of date and …   Wikipedia

  • 2038 — Cette page concerne l année 2038 du calendrier grégorien. Pour l année 2038, voir 2038. Années : 2035 2036 2037  2038  2039 2040 2041 Décennies : 2000 …   Wikipédia en Français

  • 2038 — Este artículo o sección se refiere o está relacionado con una fecha o período de tiempo futuro. La información de este artículo puede cambiar frecuentemente. Por favor, no agregues datos especulativos y recuerda colocar referencias a fuentes… …   Wikipedia Español

  • -2038 — Années : 2041 2040 2039   2038  2037 2036 2035 Décennies : 2060 2050 2040   2030  2020 2010 2000 Siècles : XXIIe siècle av. J.‑C.  XXIe siècle av. J.‑C.  XX …   Wikipédia en Français

  • (2038) Bistro — est un astéroïde évoluant dans la ceinture principale, découvert le 24 novembre 1973 par l astronome suisse Paul Wild depuis l observatoire Zimmerwald. Son nom se réfère au bistro, le débit de boisson ou petit restaurant[1]. Notes et… …   Wikipédia en Français

  • 2038-Problem — Exemplarische Darstellung des Jahr 2038 Problems Das Jahr 2038 Problem könnte zu Softwareausfällen im Jahr 2038 führen. Dieses Problem ist auf EDV Systeme beschränkt, die den POSIX Zeitstandard benutzen und time t als 32 Bit Binärzahl definieren …   Deutsch Wikipedia

  • 2038 год — Эта статья или часть статьи содержит информацию об ожидаемых событиях. Здесь описываются события, которые ещё не произошли …   Википедия

  • 2038 Bistro — Infobox Planet minorplanet = yes width = 25em bgcolour = #FFFFC0 apsis = name = Bistro symbol = caption = discovery = yes discovery ref = discoverer = P. Wild discovery site = Zimmerwald discovered = November 24, 1973 designations = yes mp name …   Wikipedia

  • (2038) Bistro — Asteroid (2038) Bistro Eigenschaften des Orbits (Animation) Orbittyp Hauptgürtelasteroid Große Halbachse 2,436 AE …   Deutsch Wikipedia

  • 2038 — …   Википедия

Share the article and excerpts

Direct link
Do a right-click on the link above
and select “Copy Link”