La réplication MySQL permet :
Donc, je vais vous montrer les 2 types de réplication possible sur MySQL master/slave et master/master
Nous allons éditer le fichier configuration my.cnf qui est dans /etc/mysql
bind-address = XXX.XXX.XXX.XXX server-id = 1 log_bin = /var/log/mysql/mysql-bin.log expire_logs_days = 1 #on peut mettre plus de jours max_binlog_size = 100M binlog_do_db = DB_REPLI
Nous allons éditer le fichier configuration my.cnf qui est dans /etc/mysql
bind-address = XXX.XXX.XXX.XXX server-id = 2 log_bin = /var/log/mysql/mysql-bin.log expire_logs_days = 1 # on peut mettre plus de jours max_binlog_size = 100M replicate_do_db = DB_REPLI
Pour simplifier la copie de la base de données, j'ai l'habitude de copier le contenu du répertoire mysql dans /var/lib/.
Dans un premier temps, j’arrête le service MYSQL sur le maître et l'esclave.
/etc/init.d/mysql stop
Nous allons installer rsync pour synchroniser les fichiers, j'aime bien car cela permet de garder les droits sur les fichiers, etc.
aptitude install rsync
Puis supprimer le contenu du répertoire mysql dans /var/lib de notre machine esclave
rm -rf /var/lib/mysql/*
Il ne reste plus qu'à lancer la synchronisation, depuis le maître.
rsyn -avz /var/lib/mysql/ <USER>@<IP_SLAVE>:/var/lib/mysql
debian.cnf dans /etc/mysql/, ce login sert pour la rotation des journaux et arrêter ou relancer le service MYSQL.
Vous pouvez relancer Mysql.
/etc/init.d/mysql start
Nous allons créer un login capable de faire la réplication
mysql -u root -p GRANT REPLICATION SLAVE ON *.* TO 'replication_user'@'<IP_SLAVE>' IDENTIFIED BY 'motdepasse'; FLUSH PRIVILEGES;
Nous pouvons regarder l’état de notre serveur maître.
SHOW MASTER STATUS\G
'*************************** 1. row ***************************'
File: mysql-bin.000030
Position: 107
Binlog_Do_DB: example
Binlog_Ignore_DB:
1 row in set (0.00 sec)
voici, un résultat sur une base example
Nous allons modifier les paramètres que l'esclave utilise pour se connecter et pour communiquer avec le serveur maître.
STOP slave; CHANGE MASTER TO MASTER_HOST='<IP_MASTER>', MASTER_USER='replication_user', MASTER_PASSWORD='motdepasse'; START slave;
Nous pouvons regarder l'état de notre serveur esclave :
SHOW SLAVE STATUS\G
'*************************** 1. row ***************************'
Slave_IO_State: Waiting for master to send event
Master_Host: 192.168.2.7
Master_User: replica
Master_Port: 3306
Connect_Retry: 60
Master_Log_File: mysql-bin.000025
Read_Master_Log_Pos: 107
Relay_Log_File: mysqld-relay-bin.000082
Relay_Log_Pos: 313
Relay_Master_Log_File: mysql-bin.000025
Slave_IO_Running: Yes
Slave_SQL_Running: Yes
Replicate_Do_DB: example
Replicate_Ignore_DB:
Replicate_Do_Table:
Replicate_Ignore_Table:
Replicate_Wild_Do_Table:
Replicate_Wild_Ignore_Table:
Last_Errno: 0
Last_Error:
Skip_Counter: 0
Exec_Master_Log_Pos: 107
Relay_Log_Space: 513
Until_Condition: None
Until_Log_File:
Until_Log_Pos: 0
Master_SSL_Allowed: No
Master_SSL_CA_File:
Master_SSL_CA_Path:
Master_SSL_Cert:
Master_SSL_Cipher:
Master_SSL_Key:
Seconds_Behind_Master: 0
Master_SSL_Verify_Server_Cert: No
Last_IO_Errno: 0
Last_IO_Error:
Last_SQL_Errno: 0
Last_SQL_Error:
Replicate_Ignore_Server_Ids:
Master_Server_Id: 2
1 row in set (0.00 sec)
Voici, le résultat de notre esclave qui arrive bien à joindre notre serveur maître (192.168.2.7) avec le login replica, la base répliquée est example et surtout pas d'erreur.
Pour la réplication master/master, c'est très simple surtout si, vous avez réussi la réplication master/slave, il suffit de recommencer l'opération, mais cette fois dans l'autre sens.
Configurer l'esclave en maître et le maître en esclave.