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 update
sudo apt-get install mysql-server
Installez MySQL sur le serveur esclave en utilisant les mêmes commandes :
sudo apt-get update
sudo 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.cnfbind-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.cnfbind-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 TO
MASTER_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)