Ein DNS-Eintrag, der sich häufig ändert? [geschlossen]

17

Wie erstelle ich einen Domain-Eintrag, der sich häufig ändern kann?

Lassen Sie uns example.orgPunkte sagen 203.0.113.0. Zwei Minuten später muss es zeigen 198.51.100.0.

Es handelt sich um normale Websites hinter der Domain ("normal" nur in dem Sinne, dass der Zugriff über gängige Webbrowser erfolgt), die jedoch eine sehr kurze Lebensdauer haben. Die Domain verweist maximal 3-4 Stunden auf eine Adresse, bevor sie geschaltet oder heruntergefahren wird. Der DNS-Server muss nicht vor häufigen Abfragen geschützt werden.

Mein Ansatz wäre, TTL auf 60 Sekunden zu setzen und einfach den Datensatz zu ändern, wenn ein Wechsel erforderlich ist. Im schlimmsten Fall würde ein Benutzer maximal 60 Sekunden warten, bevor auf einen neuen Server zugegriffen werden kann.

Irgendwie vertraue ich dem nicht ... Einige ISPs oder Browser könnten die TTL ignorieren oder überschreiben, nicht wahr? Wenn es ein berechtigtes Anliegen ist, was wäre eine vernünftige TTL zu erwarten?

Vielen Dank!

Andrew8
quelle
9
Warum genau brauchen Sie diese Fähigkeit? Welche Art von "normaler Website" läuft auf einer Infrastruktur, die nach 3-4 Stunden verschwindet? Es gibt Lösungen, die in den Sinn kommen, aber es ist nicht klar, was Sie mit schnellen DNS-Änderungen tun oder welches Verhalten Sie bei Übergängen erwarten.
Michael - sqlbot
@ Michael-sqlbot, "normal" in dem Sinne, dass es sich um eine Webanwendung handelt, auf die über einen Browser zugegriffen wird, die jedoch weit davon entfernt ist, eine klassische Website zu sein. Eine einzelne Anwendungsinstanz hat in der Tat eine Lebensdauer von wenigen Stunden. Ich möchte nur einen gemeinsamen Pool von Domain-Namen für sie verwenden. Ich habe bereits den Rat erhalten, mich mit der Lastausgleichstechnik zu befassen. Da Anwendungsinstanzen jedoch nicht austauschbar sind, bin ich mir nicht sicher, ob sie überhaupt anwendbar sind.
Andrew8
4
Nach meiner Erfahrung ist DNS aufgrund der Unklarheiten im Internet ein schlechter Kandidat für die Überwachung von Diensten. Es funktioniert zwar auf Ihrem Computer oder sogar in Ihrem Firmennetzwerk oder auf dem flockigen Breitband Ihres Freundes, aber es scheint, dass es auf der ganzen Welt einige wirklich schreckliche Clients gibt, die ein Vielfaches Ihrer TTL benötigen, um Änderungen in Ihrem DNS zu bemerken.
Ralph Bolton
Warum nicht stattdessen ein IP-Failover?
Giammin

Antworten:

38

Dies wird als Fast Flux DNS-Einträge bezeichnet . In der Regel verstecken Malware-Autoren ihre Infrastrukturserver.

Während dies für Ihren Plan funktioniert, ist es nicht der beste Plan. Sie müssen wahrscheinlich einen oder mehrere Ersatzserver online haben und fast die ganze Zeit nichts tun. Nur wenn Sie ein Problem mit dem Hauptserver haben, würden Sie zum nächsten wechseln.

Selbst wenn Sie eine TTL von 1 Minute haben, ist ein Datensatz höchstwahrscheinlich länger gültig:

  1. Browser-Caches

    Browser speichern die DNS-Einträge normalerweise für einen variablen Zeitraum im Cache. Firefox verwendet 60 Sekunden , Chrome verwendet auch 60 Sekunden , IE 3.x und früher für 24 Stunden im Cache , IE 4.x und höher für 30 Minuten im Cache.

  2. Betriebssystem-Cache

    Windows wird die TTL normalerweise nicht einhalten . Eine TTL für DND entspricht nicht der TTL für ein IPv4-Paket. Es ist eher ein Hinweis auf Frische als eine obligatorische Aktualisierung. Unter Linux kann nscd so konfiguriert werden, dass die vom Benutzer gewünschte Zeitdauer festgelegt wird, wobei DNS TTL nicht berücksichtigt wird. Es können beispielsweise Einträge für eine Woche zwischengespeichert werden.

  3. ISP-Cache

    ISPs können (und manche werden) aggressives Caching verwenden, um den Datenverkehr zu verringern. Sie können nicht nur die TTL ändern, sondern die Datensätze zwischenspeichern und an Clients zurückgeben, ohne auch nur vorgeschaltete DNS-Server zu fragen. Dies ist bei mobilen ISPs häufiger der Fall, da sie die TTL ändern, damit sich mobile Clients nicht über die Latenz des Datenverkehrs beschweren.

Ein Load Balancer macht genau das, was Sie wollen. Mit einem Load Balancer können Sie 2, 4 oder 10 Server gleichzeitig online stellen, um die Last zu teilen. Wenn einer von ihnen offline geht, ist der Dienst nicht betroffen. Das Ändern von DNS-Einträgen hat eine Ausfallzeit zwischen dem Abschalten des Servers und dem Ändern des DNS. Es dauert länger als eine Minute, da Sie die Ausfallzeit ermitteln, die Datensätze ändern und auf ihre Weitergabe warten müssen.

Verwenden Sie also einen Load Balancer. Es ist darauf ausgelegt, zu tun, was Sie wollen, und Sie wissen genau, was Sie erwartet. Ein schnelles Flux-DNS-Setup führt zu gemischten und inkonsistenten Ergebnissen.

ThoriumBR
quelle
11
Verwenden Sie trotzdem einen Load Balancer. Sie verfügen über eine hohe Verfügbarkeit, einen flexiblen Pool, Protokolle, zahlreiche Messdaten und Statistiken, können Prioritäten für den einen oder anderen Server festlegen und haben weniger Kopfschmerzen.
ThoriumBR
4
Ja, Sie werden wahrscheinlich feststellen, dass ein schrecklicher ISP irgendwo Stunden oder einen ganzen Tag benötigt, um Ihre DNS-Änderung zu erfassen.
Robyn
2
@Mehrdad Je nachdem, wie Sie es definieren, funktioniert es. Wenn Sie in Deutschland über eine ADSL-Leitung verfügen, müssen Sie sich über PPPoE authentifizieren und erhalten dann eine IP-Adresse aus dem Einwahlbereich. Bis vor kurzem (und in einigen Fällen immer noch) wurde Ihre Verbindung nach 24 Stunden unterbrochen, sodass Sie sich erneut anmelden mussten (oder Ihr CPE hat dies für Sie getan).
glglgl
3
Hinzufügen zu @ glglgls Kommentar: Der entscheidende Punkt ist, dass Ihnen bei jedem erneuten Anmelden eine andere IP-Adresse zugewiesen wurde . Dieses Verhalten war beabsichtigt: Die Anbieter wollten verhindern, dass Benutzer Server in ihren SOHOs auf diese Weise ausführen.
Binarus
1
@Binarus ist nicht nur das, sondern normalerweise hat ein ISP mit 2000 Teilnehmern keine 2000 IPs in seinem Pool. Da nicht jeder Kunde zur gleichen Zeit aktiv ist, kann ein anderer Benutzer dieselbe IP-Adresse beziehen, sobald er die Verbindung trennt.
ThoriumBR
6

DNS und seine Funktionsweise gehen möglicherweise mit mehr Missverständnissen, Legenden, Aberglauben und Mythologie einher als jeder andere Aspekt der IT.

Sogar diejenigen von uns, die wissen, dass wir im Wesentlichen lügen (oder zumindest drastisch vereinfachen), wenn wir über die "Ausbreitung" von Änderungen sprechen, tendieren immer noch dazu, den Begriff zu verwenden, um etwas zu beschreiben, das - gleichzeitig - extrem einfach und unkompliziert ist ... noch schwer zu erklären ... und hat nichts mit Propagierung per se zu tun, sondern alles mit Caching und Negativ-Caching, die beide eine wesentliche Komponente der Funktionsweise des Systems sind (und wohl auch, wie es einen völligen Zusammenbruch verhindert) sein eigenes Gewicht) - im Wesentlichen das Inside-Out, das Gegenteil der tatsächlichen "Ausbreitung", ziehen - nicht schieben.

Bei all den Sorgen und Problemen mit kurzen TTLs funktionieren sie meistens so oft, dass es in Ihrem Interesse liegt, sie einfach auszuprobieren. Wenn unsere Websites bei $ {day_job} von einer "alten" Plattform auf eine "neue" Plattform migrieren, bedeutet dies häufig, dass sie so migriert werden, dass nichts in der Infrastruktur gemeinsam genutzt wird. Mein erster Schritt bei einer solchen Migration besteht darin, die TTL weit genug vor der Kürzung auf 60 Sekunden zu senken, damit die alte TTL über mehrere Vielfache von sich selbst verfügt, was mir eine angemessene Sicherheit gibt, dass sich diese Übergangs-RRs mit kurzen TTLs "ausbreiten" werden . " Wenn ich für den Schnitt bereit bin, konfiguriere ich den alten Balancer¹ neu, um den Datenverkehr auf das neue System zu übertragen - über das Internet - so, dass der Balancer nicht mehr mehrere interne Systeme balanciert, sondern "

Dann schneide ich den DNS um und beobachte den neuen Balancer und den alten.

Ich bin immer wieder positiv überrascht, wie schnell der Übergang erfolgt. Die Überbleibsel scheinen fast immer Suchspinnen und "Health Checking" -Standorte von Drittanbietern zu sein, die sich unerklärlicherweise an die alten Aufzeichnungen halten.

Es gibt jedoch ein Szenario, das vorhersehbar zusammenbricht: Wenn die Browserfenster eines Benutzers geöffnet bleiben, bleiben sie in der Regel an der bereits erkannten Adresse hängen und bleiben häufig bestehen, bis alle Browserfenster geschlossen werden.

In der obigen Beschreibung finden Sie jedoch die Lösung für das Problem: Ein "Load Balancer" - genauer gesagt ein Reverse Proxy - kann das System sein, auf das Ihr exponierter DNS-Eintrag verweist.

Der Reverse-Proxy leitet die Anforderung dann an die richtige Ziel-IP-Adresse weiter, die er mithilfe eines zweiten "Dummy" -Hostnamens mit einer kurzen TTL auflöst, die auf den realen Back-End-Server verweist Dummy-DNS-Eintrag, Sie können sich auf eine schnelle und vollständige Umstellung verlassen.

Der Nachteil ist, dass Sie den Datenverkehr möglicherweise über eine unnötige zusätzliche Infrastruktur leiten oder redundant mehr für den Transport über mehrere Netzwerkgrenzen zahlen.

Es gibt Dienste, die diese Art von Funktionen auf globaler Ebene bereitstellen, und derjenige, mit dem ich am vertrautesten bin, ist CloudFront. (Höchstwahrscheinlich würde Cloudflare genau den gleichen Zweck erfüllen, da die wenigen Tests, die ich durchgeführt habe, darauf hindeuten, dass es sich auch richtig verhält, und ich bin sicher, dass es noch andere gibt.)

Obwohl CloudFront in erster Linie als CDN vermarktet wird, handelt es sich in seinem Kern um ein globales Netzwerk von Reverse-Proxies mit der Möglichkeit, die Antworten optional zwischenzuspeichern. Wenn www.example.comPunkte auf CloudFront und CloudFront so konfiguriert sind, dass diese Anforderungen an weitergeleitet werden backend.example.com, und der DNS-Eintrag für backend.example.comeine kurze TTL verwendet, wird CloudFront das Richtige tun, da diese kurze TTL berücksichtigt wird. Wenn sich der Back-End-Datensatz ändert, wird der gesamte Datenverkehr bis zum Ablauf der TTL migriert.

Die TTL auf dem Front-Side-Datensatz, die auf CloudFront verweist, und ob Browser und Caching-Resolver dies berücksichtigen, ist unwichtig, da Änderungen am Back-End-Ziel keine Änderungen im www.example.comDatensatz erfordern. Hinsichtlich des richtigen Ziels www.example.comist dies konsistent, unabhängig davon, wo sich das Back-End-System gerade befindet.

Dies löst für mich das Problem vollständig, indem der Browser von der Notwendigkeit befreit wird, Änderungen an der IP des Ursprungsservers zu "verfolgen".

tl; dr: Leiten Sie die Anforderungen an ein System weiter, das als Proxy für den realen Webserver dient, sodass nur die Proxy-Konfiguration die Änderung der IP-Adresse des Ursprungsservers berücksichtigen muss, nicht das browserbasierte DNS.

Beachten Sie, dass Cloudfront minimiert auch die Latenzzeit von einiger DNS Magie es auf der Vorderseite erlegt, die Ergebnisse in der www.example.comLösung auf die optimalste Cloudfront Randlage an der Stelle des Browser - basierte , das heißt die Abfrage www.example.com, so gibt es minimale Chance des Verkehrs ein unnötig Umwege nehmen Vom Browser über die Kante bis zum Ursprung ... aber dieser Teil ist transparent und automatisch und liegt außerhalb des Rahmens der Frage.

Natürlich kann das Zwischenspeichern von Inhalten auch von Nutzen sein, indem die Auslastung des Ursprungsservers oder des Transports verringert wird. Ich habe Websites auf CloudFront konfiguriert, auf denen sich der Ursprungsserver in einem ADSL-Netzwerk befand, und ADSL ist inhärent auf die Bandbreite im Upstream beschränkt. Der Ursprungsserver, zu dem CloudFront eine Verbindung herstellt, um den Inhalt abzurufen, muss kein Server im AWS-Ökosystem sein.


¹ Ich spreche von Balancer als einer einzigen Entität, wenn er tatsächlich mehrere Knoten hat. Wenn es sich bei dem Balancer um einen ELB handelt, fungiert ein Computer hinter dem Balancer als Dummy-App-Server und übernimmt die eigentliche Haarnadelung für den Balancer der neuen Plattform, da ELB dies nicht alleine durchführen kann.

² Das einzige Wissen des neuen Balancers über den alten Balancer besteht darin, dass er dem X-Forwarded-For des alten Balancers vertrauen muss und keine IP-basierte Ratenbeschränkung für die Quelladressen des alten Balancers vornehmen sollte.

³ Wenn es sich bei dem Proxy um einen oder mehrere Server handelt, die Sie steuern, haben Sie die Möglichkeit, die Verwendung von DNS auf der Rückseite und die Verwendung von IP-Adressen in der Proxy-Konfiguration zu überspringen. Für das nachfolgend beschriebene gehostete / verteilte Szenario ist jedoch diese zweite DNS-Schicht erforderlich .

Michael - sqlbot
quelle
2
Vielen Dank wie immer für eine weitere tolle Antwort. "Bei $ {day_job}, wenn unsere Websites von einer" alten "Plattform auf eine" neue "Plattform migrieren, [...]": +1!
gf_
4

Wenn ich DNS-Einträge ändere, wird die alte IP-Adresse oft monatelang verwendet. Allerdings verwendet Amazon eine TTL von nur wenigen Sekunden, um beispielsweise einen Fallback-Service zu erstellen.

Anstatt DNS zu ändern, können Sie einen Proxyserver / Load Balancer davor platzieren.

Halfgaar
quelle
1
In meinen Tests TTLscheinen 60 Sekunden die meiste Zeit zu funktionieren, aber ich hatte einige Kunden, die eine Verspätung von 10-20 Minuten hatten.
Andrew8
1

Sie könnten die Verwendung von Dynamic DNS untersuchen. Dies ist genau für das Szenario gedacht, das @glglgl oben in einem Kommentar erwähnt hat. Ich glaube, sie verwenden eine niedrige TTL, die, wie bereits erwähnt, möglicherweise nicht zu 100% effektiv ist, da die Kunden diese ignorieren können. Aber es funktioniert "ziemlich gut".

Auch wenn Sie Ihre IP-Adresse nicht häufig ändern, ist es wichtig, dass Ihre TTL angemessen ist. Vor vielen Jahren arbeitete das Unternehmen, für das ich arbeitete, für geänderte ISPs, die dazu führten, dass sich unsere IPs änderten. Leider hatten wir unsere TTL auf etwas Lächerliches wie einen Monat eingestellt, sodass die alten DNS-Einträge für eine lange Zeit aufbewahrt wurden.

dwilliss
quelle
Es gibt viele DNS-Server auf ISP-Ebene, die TTL nicht einhalten. Ich arbeite an einem Produkt, das ungefähr zweimal im Jahr DNS-Informationen wechselt. Wir haben viele Leute, deren DNS-Server unsere alten Informationen bis zu mehreren Wochen nach dem Ändern zwischenspeichern. Wenn Sie nicht die Client-Seite kontrollieren, können Sie nicht damit rechnen, dass dies gut funktioniert.
Michael Gantz