GNU/Linux >> Tutoriels Linux >  >> Ubuntu

Comment configurer la réplication MySQL maître-esclave sur Ubuntu 18.04

La réplication MySQL est un processus qui permet aux données d'un serveur de base de données d'être automatiquement copiées sur un ou plusieurs serveurs.

MySQL prend en charge un certain nombre de topologies de réplication, la topologie maître/esclave étant l'une des topologies les plus connues dans lesquelles un serveur de base de données agit en tant que maître, tandis qu'un ou plusieurs serveurs agissent en tant qu'esclaves. Par défaut, la réplication est asynchrone où le maître envoie des événements décrivant les modifications de la base de données à son journal binaire et les esclaves demandent les événements lorsqu'ils sont prêts.

Ce tutoriel couvre un exemple de base de réplication MySQL maître/esclave avec un serveur maître et un serveur esclave sur Ubuntu 18.04. Les mêmes étapes s'appliquent à MariaDB.

Ce type de topologie de réplication est le mieux adapté au déploiement d'instances dupliquées en lecture pour la mise à l'échelle en lecture, la sauvegarde des bases de données en direct pour la reprise après sinistre et pour les tâches d'analyse.

Prérequis #

Cet exemple suppose que vous disposez de deux serveurs exécutant Ubuntu 18.04, qui peuvent communiquer entre eux via un réseau privé. Si votre fournisseur d'hébergement n'offre pas d'adresses IP privées, vous pouvez utiliser les adresses IP publiques et configurer votre pare-feu pour autoriser le trafic sur le port 3306 uniquement à partir de sources fiables.

Les serveurs de cet exemple ont les adresses IP suivantes :

Master IP: 192.168.121.190
Slave IP:  192.168.121.236

Installer MySQL #

La valeur par défaut Les référentiels Ubuntu 18.04 incluent MySQL version 5.7. Pour éviter tout problème, il est préférable d'installer la même version de MySQL sur les deux serveurs.

Installez MySQL sur le serveur maître :

sudo apt-get updatesudo apt-get install mysql-server

Installez MySQL sur le serveur esclave en utilisant les mêmes commandes :

sudo apt-get updatesudo apt-get install mysql-server

Configurer le serveur maître #

La première étape consiste à configurer le serveur MySQL maître. Nous allons apporter les modifications suivantes :

  • Configurez le serveur MySQL pour qu'il écoute sur l'adresse IP privée.
  • Définissez un ID de serveur unique.
  • Activer la journalisation binaire

Pour ce faire, ouvrez le fichier de configuration MySQL et décommentez ou définissez ce qui suit :

sudo nano /etc/mysql/mysql.conf.d/mysqld.cnf
maître :/etc/mysql/mysql.conf.d/mysqld.cnf
bind-address           = 192.168.121.190
server-id              = 1
log_bin                = /var/log/mysql/mysql-bin.log

Une fois cela fait, redémarrez le service MySQL pour que les modifications prennent effet :

sudo systemctl restart mysql

L'étape suivante consiste à créer un nouvel utilisateur de réplication. Connectez-vous au serveur MySQL en tant qu'utilisateur root en tapant :

sudo mysql

Depuis l'invite MySQL, exécutez les requêtes SQL suivantes qui créeront le replica utilisateur et accordez l'REPLICATION SLAVE privilège à l'utilisateur :

CREATE USER 'replica'@'192.168.121.236' IDENTIFIED BY 'replica_password';
GRANT REPLICATION SLAVE ON *.* TO 'replica'@'192.168.121.236';
Assurez-vous de changer l'adresse IP avec votre adresse IP esclave. Vous pouvez nommer l'utilisateur comme vous le souhaitez.

Toujours dans l'invite MySQL, exécutez la commande suivante qui imprimera le nom et la position du fichier binaire.

SHOW MASTER STATUS\G
*************************** 1. row ***************************
             File: mysql-bin.000001
         Position: 629
     Binlog_Do_DB: 
 Binlog_Ignore_DB: 
Executed_Gtid_Set: 
1 row in set (0.00 sec)

Prenez note du nom du fichier, ‘mysql-bin.000001’ et Position ‘629’ . Vous aurez besoin de ces valeurs lors de la configuration du serveur esclave. Ces valeurs seront probablement différentes sur votre serveur.

Configurer le serveur esclave #

Comme pour le serveur maître ci-dessus, nous apporterons les modifications suivantes au serveur esclave :

  • Configurer le serveur MySQL pour qu'il écoute sur l'adresse IP privée
  • Définissez un ID de serveur unique
  • Activer la journalisation binaire

Ouvrez le fichier de configuration MySQL et modifiez les lignes suivantes :

sudo nano /etc/mysql/mysql.conf.d/mysqld.cnf
esclave :/etc/mysql/mysql.conf.d/mysqld.cnf
bind-address           = 192.168.121.236
server-id              = 2
log_bin                = /var/log/mysql/mysql-bin.log

Redémarrez le service MySQL :

sudo systemctl restart mysql

L'étape suivante consiste à configurer les paramètres que le serveur esclave utilisera pour se connecter au serveur maître. Connectez-vous au shell MySQL :

sudo mysql

Tout d'abord, arrêtez les threads esclaves :

STOP SLAVE;

Exécutez la requête suivante qui configurera l'esclave pour répliquer le maître :

CHANGE MASTER TOMASTER_HOST='192.168.121.190',MASTER_USER='replica',MASTER_PASSWORD='replica_password',MASTER_LOG_FILE='mysql-bin.000001',MASTER_LOG_POS=629;

Assurez-vous que vous utilisez l'adresse IP, le nom d'utilisateur et le mot de passe corrects. Le nom et la position du fichier journal doivent être identiques aux valeurs que vous avez obtenues du serveur maître.

Une fois cela fait, démarrez les threads esclaves.

START SLAVE;

Tester la configuration #

À ce stade, vous devriez avoir une configuration de réplication maître/esclave fonctionnelle.

Pour vérifier que tout fonctionne comme prévu, nous allons créer une nouvelle base de données sur le serveur maître :

sudo mysql
CREATE DATABASE replicatest;

Connectez-vous au shell MySQL esclave :

sudo mysql

Exécutez la commande suivante pour répertorier toutes les bases de données :

SHOW DATABASES;

Vous remarquerez que la base de données que vous avez créée sur le serveur maître est répliquée sur l'esclave :

+--------------------+
| Database           |
+--------------------+
| information_schema |
| mysql              |
| performance_schema |
| replicatest        |
| sys                |
+--------------------+
5 rows in set (0.00 sec)

Ubuntu
  1. Comment installer et configurer un serveur NFS sur Ubuntu 20.04

  2. Comment installer et configurer VNC sur Ubuntu 20.04

  3. Comment installer le serveur MySQL sur Ubuntu 16.04

  4. Comment installer le serveur MySQL sur Ubuntu 17.04

  5. Comment installer MySQL sur Ubuntu 16.04

Comment installer MySQL 8.0 sur Ubuntu 18.04

Réplication maître-esclave MySQL 8 sur Ubuntu 20.04

Comment installer le serveur MySQL dans Ubuntu

Comment installer et configurer MySQL sur Ubuntu 18.04

Comment configurer la réplication maître-esclave MySQL sur RHEL 7 ?

Comment installer le serveur MySQL sur Ubuntu 20.04