suchen
HeimSystem-TutorialLINUXSo lösen Sie die MySQL-Master-Slave-Verzögerung

So lösen Sie die MySQL-Master-Slave-Verzögerung

Mar 19, 2024 am 09:28 AM
linuxlinux教程红帽linux系统linux命令网络问题Linux-ZertifizierungRed Hat LinuxLinux-Video

So lösen Sie die MySQL-Master-Slave-Verzögerung

Die integrierten Replikationsfunktionen von MySQL bilden die Grundlage für die Erstellung großer, leistungsstarker Anwendungen. Verteilen Sie MySQL-Daten auf mehrere Systeme. Dieser verteilte Mechanismus wird erreicht, indem die Daten eines bestimmten MySQL-Hosts auf andere Host-Slaves kopiert und erneut ausgeführt werden.
Bei der Replikation fungiert ein Server als Master und ein oder mehrere andere Server fungieren als Slaves. Der Master schreibt Aktualisierungen in binäre Protokolldateien und verwaltet einen Index der Dateien, um die Protokollrotation zu verfolgen. Diese Protokolle zeichnen Aktualisierungen auf, die an Slave-Server gesendet werden. Wenn ein Slave eine Verbindung zum Master herstellt, benachrichtigt er den Master über den Ort der letzten erfolgreichen Aktualisierung, die der Slave im Protokoll gelesen hat. Der Slave-Server empfängt alle seitdem erfolgten Aktualisierungen, blockiert dann und wartet darauf, dass der Master-Server sie über Aktualisierungen benachrichtigt.
Probleme mit der MySQL-Master-Slave-Replikation:

  • Nachdem die Hauptdatenbank ausgefallen ist, können Daten verloren gehen
  • Die Slave-Bibliothek verfügt nur über einen SQL-Thread, die Hauptbibliothek steht unter großem Schreibdruck und die Replikation wird sich wahrscheinlich verzögern
Im Folgenden finden Sie vier praktische Möglichkeiten, die MySQL-Master-Slave-Verzögerung zu lösen
1. Prinzip der Master-Slave-Synchronisationsverzögerung der MySQL-Datenbank.

Antwort: Wenn wir über das Prinzip der Master-Slave-Synchronisationsverzögerung in der MySQL-Datenbank sprechen, müssen wir mit dem Prinzip der Master-Slave-Replikation der MySQL-Datenbank beginnen. Die Hauptdatenbank generiert Binlog Für alle DDL- und DML-Programme ist die Effizienz sehr hoch DDL- und DML-Operationen der Hauptbibliothek auf dem Slave. Die E/A-Operationen von DML und DDL sind zufällig und nicht sequentiell, daher können auch andere Abfragen auf dem Slave zu Sperrenkonflikten führen. Da Slave_SQL_Running ebenfalls Single-Threaded ist, muss ein DDL-Karten-Master zehnmal ausgeführt werden. Minuten, dann warten alle nachfolgenden DDL, bis die Ausführung dieses DDL abgeschlossen ist, bevor sie fortfahren, was zu Verzögerungen führt. Einige Freunde werden fragen: „Derselbe DDL in der Hauptbibliothek muss auch 10 Minuten lang ausgeführt werden. Warum ist der Slave verzögert?“ Die Antwort ist, dass der Master gleichzeitig ausgeführt werden kann, der Slave_SQL_Running-Thread jedoch nicht.

2. Wie kommt es zur Master-Slave-Synchronisationsverzögerung in der MySQL-Datenbank?

Antwort: Wenn die TPS-Parallelität der Hauptbibliothek hoch ist, übersteigt die Anzahl der generierten DDL den Bereich, den ein SQL-Thread des Slaves aushalten kann, und dann kann es zu einer Verzögerung beim Warten auf die Sperre kommen große Abfrageanweisung.

3.MySQL-Datenbank-Master-Slave-Synchronisationsverzögerungslösung

Antwort: Die einfachste Lösung zur Reduzierung der Slave-Synchronisationsverzögerung besteht darin, die Architektur zu optimieren und zu versuchen, die DDL der Hauptbibliothek schnell auszuführen. Es gibt auch die Tatsache, dass die Hauptbibliothek eine hohe Datensicherheit aufweist, z. B. sync_binlog = 1, innodb_flush_log_at_trx_commit = 1. Der Slave benötigt jedoch keine so hohe Datensicherheit. Sie können sync_binlog auf 0 oder setzen Binlog deaktivieren kann auch auf 0 gesetzt werden, um die SQL-Ausführungseffizienz zu verbessern. Die andere Möglichkeit besteht darin, als Slave ein besseres Hardwaregerät als die Hauptbibliothek zu verwenden.

4. Faktoren, die die Master-Slave-Synchronisationsverzögerung in der MySQL-Datenbank verursachen.

1. Netzwerkverzögerung
2. Hauptlast
3. Sklavenladung
Der allgemeine Ansatz besteht darin, mehrere Slaves zum Verteilen von Leseanforderungen zu verwenden und dann einen dedizierten Server dieser Slaves nur für die Sicherung zu verwenden, ohne dass weitere Vorgänge erforderlich sind, sodass die Anforderungen an „Echtzeit“ maximal erfüllt werden können

Darüber hinaus führen wir zwei weitere Parameter ein, die die Verzögerung reduzieren können
–slave-net-timeout=Sekunden
Parameterbedeutung: Wenn der Slave keine Protokolldaten aus der Hauptdatenbank liest, wie lange muss gewartet werden, bis die Verbindung wiederhergestellt und die Daten abgerufen werden können
Die Einheit von „slave_net_timeout“ ist Sekunden. Die Standardeinstellung ist 3600 Sekunden
|. Slave_net_timeout |. 3600
–master-connect-retry=Sekunden Parameterbedeutung: Wie lange dauert der erneute Versuch, wenn beim erneuten Herstellen der Master-Slave-Verbindung die Verbindung fehlschlägt?
Die Einheit für den Master-Verbindungswiederholungsversuch ist Sekunden. Die Standardeinstellung ist 60 Sekunden Normalerweise kann die Konfiguration der beiden oben genannten Parameter die durch Netzwerkprobleme verursachte Verzögerung bei der Master-Slave-Datensynchronisierung verringern

Das obige ist der detaillierte Inhalt vonSo lösen Sie die MySQL-Master-Slave-Verzögerung. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme
Dieser Artikel ist reproduziert unter:Linux就该这么学. Bei Verstößen wenden Sie sich bitte an admin@php.cn löschen
Was sind die Unterschiede in der Benutzerkontoverwaltung zwischen Linux und Windows?Was sind die Unterschiede in der Benutzerkontoverwaltung zwischen Linux und Windows?May 02, 2025 am 12:02 AM

Der Hauptunterschied zwischen Linux und Windows in der Benutzerkontoverwaltung ist das Berechtigungsmodell- und Verwaltungswerkzeug. Linux verwendet UNIX-basierte Berechtigungsmodelle und Befehlszeilen-Tools (z. B. UserAdd, Usermod, UserDel), während Windows ein eigenes Sicherheitsmodell und sein Grafical User Interface (GUI) -Management-Tools verwendet.

Wie macht die Befehlszeilenumgebung von Linux es mehr/weniger sicher als Windows?Wie macht die Befehlszeilenumgebung von Linux es mehr/weniger sicher als Windows?May 01, 2025 am 12:03 AM

Linux'scommandlinecanBemoresecurethanWindowsifManagedCorrecty, ButRequiresmoreuser Knowledge.1) Linux-Soopen-SourcenatureAllowsforquickSecurityUpdates.2) Fehlkonfigurationskanleadtovulierungen

So erstellen Sie automatisch eine USB -Laufwerkshalterung unter LinuxSo erstellen Sie automatisch eine USB -Laufwerkshalterung unter LinuxApr 30, 2025 am 10:04 AM

In diesem Leitfaden wird erläutert, wie Sie ein USB -Laufwerk auf dem Boot in Linux automatisch montieren und Ihnen Zeit und Mühe sparen. Schritt 1: Identifizieren Sie Ihr USB -Laufwerk Verwenden Sie den Befehl LSBLK, um alle Blockgeräte aufzulisten. Ihr USB -Laufwerk wird wahrscheinlich mit /dev /sdb1, /dev /sdc1 usw. gekennzeichnet.

Beste plattformübergreifende Apps für Linux, Windows und Mac im Jahr 2025Beste plattformübergreifende Apps für Linux, Windows und Mac im Jahr 2025Apr 30, 2025 am 09:57 AM

Über plattformübergreifende Anwendungen haben die Softwareentwicklung revolutioniert und ermöglicht nahtlose Funktionen über Betriebssysteme wie Linux, Windows und MacOS. Dadurch wird die Notwendigkeit beseitigt, Apps basierend auf Ihrem Gerät zu wechseln, und bietet konsistente Erfahrungen

Beste Linux -Tools für KI und maschinelles Lernen im Jahr 2025Beste Linux -Tools für KI und maschinelles Lernen im Jahr 2025Apr 30, 2025 am 09:44 AM

Künstliche Intelligenz (KI) verändert schnell zahlreiche Sektoren, von Gesundheitswesen und Finanzen bis hin zu kreativen Bereichen wie Kunst und Musik. Linux hat sich mit seinen Open-Source-Natur-, Anpassungs- und Leistungsfähigkeiten als führender Platfo entwickelt

5 Beste leichte Linux -Distributionen ohne GUI5 Beste leichte Linux -Distributionen ohne GUIApr 30, 2025 am 09:38 AM

Suchen Sie nach einer schnellen, minimalen und effizienten Linux -Verteilung ohne grafische Benutzeroberfläche (GUI)? Leichte, gitorlose Linux-Distributionen eignen sich perfekt für ältere Hardware oder spezielle Aufgaben wie Server und eingebettete Systeme. Sie konsumieren weniger res

So installieren Sie Wein 10.0 in Redhat -VerteilungenSo installieren Sie Wein 10.0 in Redhat -VerteilungenApr 30, 2025 am 09:32 AM

Wine 10.0 Stable Version Release: Ausführen von Windows -Anwendungen auf Linux auf einer höheren Ebene Wine, diese Open Source und kostenlose Anwendung ermöglicht es Linux -Benutzern, Windows -Software und Spiele auf UNIX/Linux -Betriebssystemen auszuführen und die Veröffentlichung der 10.0 -stabilen Version zu leiten! Diese Version wurde mit Quellcode und Binärpaket -Downloads versehen und unterstützt verschiedene Verteilungen wie Linux, Windows und Mac. Diese Ausgabe verkörpert ein Jahr harter Arbeit und über 8.600 Verbesserungen, wodurch viele aufregende Verbesserungen erzielt werden. Zu den wichtigsten Highlights gehören: Verbesserte Unterstützung für Bluetooth -Geräte. Verbesserung der Unterstützung für HID -Eingabereiche. Optimierte Leistung von 32-Bit- und 64-Bit-Anwendungen.

So installieren und konfigurieren Sie SQL Server auf RHELSo installieren und konfigurieren Sie SQL Server auf RHELApr 30, 2025 am 09:27 AM

Dieses Tutorial führt Sie durch die Installation von SQL Server 2022 unter RHEL 8.x oder 9.x, eine Verbindung über das SQLCMD-Befehlszeilen-Tool, die Datenbankerstellung und die grundlegende Abfrage. Voraussetzungen Stellen Sie vor Beginn sicher: Eine unterstützte RHEL -Version (RHEL 8 oder 9). Sudo

See all articles

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

Video Face Swap

Video Face Swap

Tauschen Sie Gesichter in jedem Video mühelos mit unserem völlig kostenlosen KI-Gesichtstausch-Tool aus!

Heiße Werkzeuge

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

MantisBT

MantisBT

Mantis ist ein einfach zu implementierendes webbasiertes Tool zur Fehlerverfolgung, das die Fehlerverfolgung von Produkten unterstützen soll. Es erfordert PHP, MySQL und einen Webserver. Schauen Sie sich unsere Demo- und Hosting-Services an.

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

SublimeText3 Linux neue Version

SublimeText3 Linux neue Version

SublimeText3 Linux neueste Version

SecLists

SecLists

SecLists ist der ultimative Begleiter für Sicherheitstester. Dabei handelt es sich um eine Sammlung verschiedener Arten von Listen, die häufig bei Sicherheitsbewertungen verwendet werden, an einem Ort. SecLists trägt dazu bei, Sicherheitstests effizienter und produktiver zu gestalten, indem es bequem alle Listen bereitstellt, die ein Sicherheitstester benötigen könnte. Zu den Listentypen gehören Benutzernamen, Passwörter, URLs, Fuzzing-Payloads, Muster für vertrauliche Daten, Web-Shells und mehr. Der Tester kann dieses Repository einfach auf einen neuen Testcomputer übertragen und hat dann Zugriff auf alle Arten von Listen, die er benötigt.