Erzielung von Datenredundanz und -erweiterung: Anwendungsfälle der MySQL-Master-Slave-Replikationstechnologie in einer Clusterumgebung
Einführung:
Mit der Entwicklung des Internets, der zunehmenden Datenmenge und der zunehmenden Anzahl von Benutzern werden traditionelle Stand- Datenbanken allein sind nicht mehr in der Lage, die Anforderungen an hohe Parallelität und hohe Verfügbarkeit zu erfüllen. In diesem Zusammenhang sind verteilte Datenbanken zu einer der beliebtesten Lösungen geworden. Als eine der am häufigsten verwendeten relationalen Datenbanken hat die Master-Slave-Replikationstechnologie von MySQL auch in verteilten Datenbanken große Beachtung gefunden. In diesem Artikel werden die Anwendungsfälle der MySQL-Master-Slave-Replikationstechnologie zur Erzielung von Datenredundanz und -erweiterung in einer Clusterumgebung vorgestellt und entsprechende Codebeispiele bereitgestellt.
1. Einführung in die MySQL-Master-Slave-Replikationstechnologie
Die MySQL-Master-Slave-Replikationstechnologie ist eine Datenreplikationsmethode, die auf Binärprotokollen basiert. Es zeichnet die Änderungsvorgänge an der Master-Datenbank in Echtzeit im Binärprotokoll auf und überträgt das Binärprotokoll zur Wiedergabe an die Slave-Datenbank, wodurch die Datenkonsistenz zwischen der Master- und der Slave-Datenbank sichergestellt wird. In einer Clusterumgebung können wir Datenredundanz und -erweiterung erreichen, indem wir mehrere Slave-Bibliotheken auf verschiedenen Servern bereitstellen.
2. Bereitstellung der Clusterumgebung
[mysqld]
server-id=1
log_bin=mysql-bin
binlog_format=row
[mysqld]
server-id=2
relay_log=mysql-relay-bin
read_only=1
3. Aufbau der Clusterumgebung
CREATE USER 'replication'@'%' IDENTIFIED BY '123456';
GRANT REPLICATION SLAVE ON . TO 'replication' @'%';
CHANGE MASTER TO
MASTER_HOST='192.168.1.100',
MASTER_USER='Replikation',
MASTER_PASSWORD='123456',
MASTER_LOG_FILE='mysql-bin.000001',
MASTER_LOG_POS=123456;
START SLAVE;
Dann überprüfen Sie den Replikationsstatus mit dem folgenden Befehl:
SHOW SLAVE STATUSG;
Wenn sowohl „Slave_IO_Running“ als auch „Slave_SQL_Running“ im angezeigten Inhalt sind „Ja“, das bedeutet, dass die Replikation normal läuft.
4. Anwendungsfälle: Datenredundanz und -erweiterung
In einer Clusterumgebung können wir Lese- und Schreibanforderungen an mehrere Slave-Bibliotheken verteilen, um Datenredundanz und -erweiterung zu erreichen. Das Folgende ist ein einfacher Anwendungsfall, um die Auswirkung von Datenredundanz und -erweiterung zu demonstrieren.
CREATE TABLE user
(user
(
id
INT(11) NOT NULL AUTO_INCREMENT,
name
VARCHAR(20) NOT NULL,
age
INT(3) NOT NULL,
PRIMARY KEY (id
)
) ENGINE=INNODB DEFAULT CHARSET=utf8;
INSERT INTO user
(name
, age
id
INT(11) NOT NULL AUTO_INCREMENT,
name
VARCHAR(20) NOT NULL,age
INT(3) NOT NULL,id
)Testdaten einfügen
Einige Tests in die Hauptbibliothek einfügen Daten.
user
(name
, age
) VALUES ('Alice', 25), ('Bob', 30), ( 'Chris', 35);
Daten abfragen
In der Anwendung können wir Leseanfragen an jede Slave-Bibliothek senden. Angenommen, unser Anwendungsserver verfügt über zwei Slave-Bibliotheken, deren IP-Adressen 192.168.1.101 und 192.168.1.102 sind. Wir können Leseanforderungen über das folgende Codebeispiel senden:import java.sql.Connection;
import java.sql. DriverManager;
public static void main(String[] args) { String url = "jdbc:mysql://192.168.1.101:3306/test"; String username = "username"; String password = "password"; try { Connection conn = DriverManager.getConnection(url, username, password); String sql = "SELECT * FROM user"; Statement stmt = conn.createStatement(); ResultSet rs = stmt.executeQuery(sql); while (rs.next()) { int id = rs.getInt("id"); String name = rs.getString("name"); int age = rs.getInt("age"); System.out.println("id=" + id + ", name=" + name + ", age=" + age); } rs.close(); stmt.close(); conn.close(); } catch (Exception e) { e.printStackTrace(); } }
Das obige ist der detaillierte Inhalt vonDatenredundanz und -erweiterung erreichen: Anwendungsfälle der MySQL-Master-Slave-Replikationstechnologie in Clusterumgebungen. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!