Heim Datenbank MySQL-Tutorial Tutorial zur MySQL 5.7-Docker-Master-Slave-Replikationsarchitektur_MySQL

Tutorial zur MySQL 5.7-Docker-Master-Slave-Replikationsarchitektur_MySQL

Sep 09, 2016 am 08:13 AM
docker 架构

Teilen Sie das Tutorial zur MySQL 5.7-Docker-Master-Slave-Replikationsarchitektur als Referenz. Der spezifische Inhalt ist wie folgt

Umgebungsversion:
MySQL: 5.7.13
Docker: 1.11.2
CentOS: 7.1

1. Installieren Sie zunächst zwei MySQLs auf zwei physischen Maschinen Die Befehle lauten wie folgt

Der Code lautet wie folgt:

docker pull mysql:5.7.13
docker run --name anuo-mysql -p 3306:3306 -e MYSQL_ROOT_PASSWORD=qaz.00JK -d mysql:5.7.13


2. Erstellen Sie ein Kopierkonto in der Hauptdatenbank

Der Code lautet wie folgt:

GRANT REPLICATION SLAVE ON *.* TO 'rep1'@'192.168.2.103' IDENTIFIED BY 'qaz.00JK';


Das kopierte Konto lautet: rep1
Die IP der angegebenen Slave-Bibliothek muss sein: 192.168.2.103
Das Kopierpasswort lautet: qaz.00JK

3. Ändern Sie die Konfigurationsdatei der Hauptbibliothek (Ärgerlich, es sollte eine bequemere Möglichkeit geben, sie zu ändern)

3.1 Kopieren Sie zunächst die Konfigurationsdatei vom Docker in das Host-/Stammverzeichnis:

docker cp anuo-mysql:/etc/mysql/my.cnf /root

3.2 Öffnen Sie my.cnf auf dem Host und fügen Sie

am Ende des [mysqld]-Knotens hinzu

log-bin=mysql-bin
Server-ID=1

3.3 Laden Sie diese Datei dann auf Docker MySQL hoch und überschreiben Sie sie

docker cp /root/my.cnf anuo-mysql:/etc/mysql/my.cnf

3.4 Starten Sie den Docker von MySQL neu, damit die Konfiguration wirksam wird
Docker-Neustart anuo-mysql

4. Ändern Sie die Konfigurationsdatei der Slave-Bibliothek

Wie Schritt 3, der einzige Unterschied ist
Server-ID=2

5. Starten Sie die Sicherung. Führen Sie den folgenden Befehl in der Hauptdatenbank aus, um alle Tabellen in der Hauptdatenbank in einen schreibgeschützten und nicht beschreibbaren Zustand zu versetzen, um eine Datenkonsistenz zwischen den Tabellen zu erreichen Master- und Slave-Datenbanken

Tabellen mit Lesesperre leeren

6. Sichern Sie die Datenbank der Hauptdatenbank und stellen Sie sie aus der Slave-Datenbank wieder her

Es ist sehr praktisch, Navicat für MySQL zu verwenden

7. Geben Sie nach der Wiederherstellung der Slave-Bibliothek die Lesesperre der Hauptbibliothek frei, damit die Hauptbibliothek die Schreibberechtigung wiederherstellen kann

Tabellen entsperren;

8. Konfigurieren Sie die Slave-Bibliothek für die Verbindung mit der Hauptbibliothek und führen Sie sie auf der Slave-Bibliothek aus

CHANGE MASTER TO 
MASTER_HOST='192.168.2.108', 
MASTER_PORT=3306, 
MASTER_USER='rep1', 
MASTER_PASSWORD='qaz.00JK', 
MASTER_LOG_FILE='mysql-bin.000002', 
MASTER_LOG_POS=898;

Nach dem Login kopieren

Die letzten beiden Punkte
MASTER_LOG_FILE und MASTER_LOG_POS
Führen Sie in der Hauptbibliothek den Befehl SHOW MASTER STATUS aus, um
zu erhalten Die entsprechenden Felder sind Datei und Position

9. Starten Sie den Slave-Thread in der Slave-Bibliothek, um die Synchronisierung zu starten
START SLAVE;

10. Überprüfen Sie den Synchronisierungsstatus in der Slave-Bibliothek
Slave-Status anzeigen
Wenn Sie das Feld Slave_Io_State sehen:

Warten darauf, dass der Master ein Ereignis sendet ...
Dann war es erfolgreich!!! !

Das Obige ist der gesamte Inhalt dieses Artikels. Ich hoffe, dass er für das Studium aller hilfreich sein wird, und ich hoffe, dass Sie mich sehr unterstützen werden.

Erklärung dieser Website
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

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

AI Hentai Generator

AI Hentai Generator

Erstellen Sie kostenlos Ai Hentai.

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

So erstellen Sie einen Spiegel in Docker So erstellen Sie einen Spiegel in Docker Apr 15, 2025 am 11:27 AM

Schritte zum Erstellen eines Docker -Images: Schreiben Sie eine Dockerfile, die die Build -Anweisungen enthält. Erstellen Sie das Bild im Terminal mit dem Befehl Docker Build. Markieren Sie das Bild und weisen Sie Namen und Tags mit dem Befehl Docker Tag zu.

So verwenden Sie Docker Desktop So verwenden Sie Docker Desktop Apr 15, 2025 am 11:45 AM

Wie benutze ich Docker Desktop? Docker Desktop ist ein Werkzeug zum Ausführen von Docker -Containern auf lokalen Maschinen. Zu den zu verwendenden Schritten gehören: 1.. Docker Desktop installieren; 2. Start Docker Desktop; 3.. Erstellen Sie das Docker -Bild (mit Dockerfile); 4. Build Docker Image (mit Docker Build); 5. Docker -Container ausführen (mit Docker Run).

So lesen Sie die Docker -Version So lesen Sie die Docker -Version Apr 15, 2025 am 11:51 AM

Um die Docker -Version zu erhalten, können Sie die folgenden Schritte ausführen: Führen Sie den Befehl Docker "Docker --version" aus, um die Client- und Serverversionen anzuzeigen. Für Mac oder Windows können Sie auch Versionsinformationen über die Registerkarte Version der Docker -Desktop -GUI oder das Menü Docker Desktop anzeigen.

So überprüfen Sie den Namen des Docker -Containers So überprüfen Sie den Namen des Docker -Containers Apr 15, 2025 pm 12:21 PM

Sie können den Namen des Docker -Containers abfragen, indem Sie den Schritten folgen: Alle Container auflisten (Docker PS). Filtern Sie die Containerliste (unter Verwendung des GREP -Befehls). Ruft den Containernamen ab (befindet sich in der Spalte "Namen").

So aktualisieren Sie das Bild von Docker So aktualisieren Sie das Bild von Docker Apr 15, 2025 pm 12:03 PM

Die Schritte zur Aktualisierung eines Docker -Images sind wie folgt: Ziehen Sie das neueste Bild -Tag. Neues Bild Löschen Sie das alte Bild für ein bestimmtes Tag (optional) den Container neu (falls erforderlich) neu starten Sie neu (falls erforderlich).

So kopieren Sie Dateien in Docker nach außen So kopieren Sie Dateien in Docker nach außen Apr 15, 2025 pm 12:12 PM

Methoden zum Kopieren von Dateien in externen Hosts in Docker: Verwenden Sie den Befehl Docker CP: Docker CP [Optionen] & lt; Containerpfad & gt; & lt; Host -Pfad & gt;. Verwenden von Datenvolumina: Erstellen Sie ein Verzeichnis auf dem Host und verwenden Sie den Parameter -V, um das Verzeichnis in den Container zu montieren, um den Container zu erstellen, um eine bidirektionale Dateisynchronisation zu erreichen.

So ändern Sie die Docker -Bildquelle in China So ändern Sie die Docker -Bildquelle in China Apr 15, 2025 am 11:30 AM

Sie können zur Quelle der Inlandsspiegel wechseln. Die Schritte sind wie folgt: 1. Bearbeiten Sie die Konfigurationsdatei /etc/docker/daemon.json und fügen Sie die Spiegelquellenadresse hinzu; 2. Starten Sie den Docker Service Sudo SystemCtl Docker neu, um die Download -Geschwindigkeit und -stabilität des Bilddownloads zu verbessern.

So speichern Sie das Docker -Bild So speichern Sie das Docker -Bild Apr 15, 2025 am 11:54 AM

Um das Bild in Docker zu speichern, können Sie den Befehl docker comit verwenden, um ein neues Bild zu erstellen, das den aktuellen Status des angegebenen Containers Syntax: Docker Commit [Optionen] Container -ID -Bildname enthält. Um das Bild im Repository zu speichern, können Sie den Befehl Docker Push, Syntax: Docker -Push -Bildname [: Tag] verwenden. Um gespeicherte Bilder zu importieren, können Sie den Befehl Docker Pull, Syntax: Docker Pull Bildname [: Tag] verwenden.

See all articles