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
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.
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.
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.
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!

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.

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

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.

Ü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

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

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

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.

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


Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

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

Heißer Artikel

Heiße Werkzeuge

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

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
Chinesische Version, sehr einfach zu bedienen

SublimeText3 Linux neue Version
SublimeText3 Linux neueste Version

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.
