Heim >Datenbank >MySQL-Tutorial >Analysieren Sie, wie Datenbankdaten über das MySQL-Binärprotokoll wiederhergestellt werden (detaillierte Grafik- und Texterklärung).

Analysieren Sie, wie Datenbankdaten über das MySQL-Binärprotokoll wiederhergestellt werden (detaillierte Grafik- und Texterklärung).

怪我咯
怪我咯Original
2017-04-30 10:25:231549Durchsuche

In diesem Artikel wird hauptsächlich ausführlich beschrieben, wie Datenbankdaten über das Binärprotokoll von MySQL wiederhergestellt werden. Interessierte können mehr darüber erfahren.

Oft löschen Website-Administratoren aus verschiedenen Gründen und bei verschiedenen Vorgängen versehentlich Website-Daten und führen keine Website-Sicherung durch. Dadurch sind sie ratlos und führen sogar zu Problemen beim Website-Betrieb und Rentabilität. In diesem Artikel zeigen wir Ihnen, wie Sie Daten mithilfe des zweiten Mechanismusprotokolls (Binlog) von MySQL wiederherstellen.

Systemumgebung:

Betriebssystem: CentOS 6.5 X64 (virtuelle Maschine);

WEB-Dienst: PHP+Mysql+Apache;

Website: Erstellen Sie der Einfachheit halber direkt lokal eine DEMO-Site

Bedienungsschritte:

1 ;

2. Daten zur Site hinzufügen

5 Analyse;

6. Stellen Sie die angegebenen Daten wieder her.

Aktivieren Sie die Binlog-Funktion und die Grundfunktionen Öffnen Sie zuerst die MySQL-Aktivierung dieser Funktion in der Konfigurationsdatei und die Bedienung ist sehr einfach. Suchen Sie die MySQL-Konfigurationsdatei und fügen Sie der Datei die Zeile „log_bin = mysql-bin“ hinzu. Tatsächlich ist diese Funktion in den verschiedenen von mir installierten MySQL-Umgebungen normalerweise standardmäßig aktiviert.

Nach dem Aktivieren der Binlog-Funktion befinden sich Dateien wie mysql-bin.000001, mysql-bin.000002 und andere im MySQL-Datenbankverzeichnis. Dies ist die binäre Protokolldatei von MySQL. Bei jedem Start von MySQL oder bei jeder manuellen Aktualisierung des Protokolls wird eine neue binäre Protokolldatei erstellt.

Verwenden Sie zunächst in unserer MySQL-Befehlszeile den Befehl „show master logs“, um die vorhandene Binlog-Datei anzuzeigen.

2. Daten zur Website hinzufügen

Im Hintergrundartikelmodul der Website habe ich mehrere Testdaten hinzugefügt .

3. Aktualisieren Sie das Binlog-Protokoll

Zuvor war die Binlog-Datei von MySQL mysql-bin.000001, und das war es auch im Hintergrund der Website an die Datenbank gesendet. Drei Artikel wurden hinzugefügt. Jetzt aktualisieren wir das Binlog-Protokoll und eine neue mysql-bin.000002-Datei wird wie folgt generiert:

4. Daten löschen
flush logs;

show master logs;

Hier lösche ich alle drei Artikel, die ich gerade hinzugefügt habe.

5. Binlog-Protokollinhaltsanalyse

Die binäre Protokolldatei von MySQL zeichnet MySQL-Vorgänge auf, z. B. den Löschvorgang gerade Protokolldatei.

Verwenden Sie den mysqlbinlog-Befehl von MySQL:

Hinweis: Da mein lokales MySQLbinlog den Standardzeichensatz im nicht erkennen kann binlog-Konfiguration =utf8, also habe ich hier „-no-defaults“ zum Befehl hinzugefügt, damit es funktioniert.

 mysqlbinlog /data/mysql/mysql-bin.000002
Das Folgende ist ein Teil-Screenshot des Protokollinhalts:

6. Stellen Sie die angegebenen Daten wieder her ;

Beim Wiederherstellen von Daten über das Binlog-Protokoll von MySQL können wir die Wiederherstellung auf einen bestimmten Zeitpunkt festlegen, was ein bisschen wie die Server-Snapshot-Verwaltung ist. Jetzt möchten wir den gerade gelöschten Artikel wiederherstellen. Wir können einen Zeitpunkt vor dem Löschen finden und ihn auf diesen Zeitpunkt wiederherstellen.

Was die Verwendung des mysqlbinlog-Befehls betrifft, können wir ihn über den mysqlbinlog-Hilfebefehl wie folgt anzeigen:

Wie im Hilfedokument gezeigt, können Daten durch Angabe einer Zeit oder eines bestimmten Ortes wiederhergestellt werden. Hier werde ich die angegebene Zeit als Beispiel verwenden, um es Ihnen zu demonstrieren.

mysqlbinlog –no-defaults –help
Überprüfen wir die Protokolldatei mysql-bin.000001 wie folgt:

Aus den vorherigen Schritten wissen wir, dass wir vor dem Löschen der Daten die Protokolldatei mysql-bin.000002 generiert haben, sodass wir nur zu diesem Zeitpunkt wiederherstellen müssen, den ich im Bild oben gefunden habe.

mysqlbinlog -no--defaults /data/mysql/mysql-bin.000001
Der Befehl lautet wie folgt:

Kopieren Sie den Code

Der Code lautet wie folgt:

mysqlbinlog –no-defaults – stop-datetime='2017-04-11 09:48:48'/data/mysql/mysql-bin.000001 |mysql –uroot –p123456

Hier Als wir uns den Hintergrund ansahen, stellten wir fest, dass gerade alle drei gelöschten Artikel wiederhergestellt wurden, wodurch der gewünschte Zweck erreicht wurde.

Zusammenfassung:

In diesem Artikel erfahren Sie, wie Sie Daten über die MySQL-Binärprotokolldatei wiederherstellen. Ich möchte jedoch alle daran erinnern, dass Sie Ihre Website-Daten in Friedenszeiten sichern müssen. Einige der aktuellen gängigen CMS-Website-Erstellungssysteme verfügen über integrierte Datenbanksicherungsfunktionen, wie zum Beispiel das Chanzhi-System, dessen Lebenselixier Führen Sie eine gute Datensicherung durch, um spätere Probleme oder Verluste zu vermeiden.

Das obige ist der detaillierte Inhalt vonAnalysieren Sie, wie Datenbankdaten über das MySQL-Binärprotokoll wiederhergestellt werden (detaillierte Grafik- und Texterklärung).. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn