Mysql Replication

Aqui voy a explicar como poder montar un sistema de maestro-esclavo(s) en mysql. La idea es que hay un servidor principal, que es en el que se modifican los datos y los esclavos solo estan ahi para tenerlo todo duplicado, esto es perfecto para hacer copias de seguridad. Si la idea es tener transferencia de datos bidireccional, hay que montar un “MySQL Cluster

La replicacion funciona por medio de los binary log de mysql, asi que lo primero sera configurar correctamente el servidor maestro. Asi que aƱadimos estas opciones en el fichero my.cnf si aun no estan.

[mysql]
#Activamos el log binario
log-bin=mysql-bin
#Establecemos un id para el servidor, el maestro SIEMPRE sera 1
server_id=1
#Esto ayuda por si el master tiene un cuelgue y no haya problemas en la replicacion al volver a arrancarlo
sync_binlog=1
#Si trabajamos con INNODB, hay que activar esto
innodb_flush_log_at_trx_commit=1

IMPORTANTE: Hay que comprobar que la linea skip-networking no este puesta en el master, ya que sino no abrira el puerto

Ahora dejaremos lista la configuracion en el esclavo

[mysql]
#Activamos el log binario
log-bin=mysql-bin
#Id del esclavo, este tiene que ser unico
server_id=2

Ahora en el maestro le damos permisos al esclavo

GRANT REPLICATION SLAVE ON *.* TO [email protected]_ESCLAVO IDENTIFIED BY 'slavepass';

Ahora vamos a hacer un snapshot de la posicion actual del maestro para dejar el esclavo en la misma posicion para empezar a replicar. Nos conectamos al servidor maestro y ejecutamos lo siguiente:

FLUSH TABLES WITH READ LOCK;
SHOW MASTER STATUS;

Esto nos va a devolver la posicion actual del log, asi que apuntamos “File” y “Position“, que lo necesitaremos para ponerselo al esclavo, en caso de que salga en blanco “File” es y “Position” es 4

Ahora sin cerrar la conexion mysql (sino se pondria en marcha otra vez), ejecutamos esto desde otro terminal:

$ mysqladmin -u root -p shutdown

Realizamos ahora la copia de la base de datos, hay dos metodos:

  • mysqldump
    $ mysqldump --all-databases --master-data -u root -p > /tmp/dump.sql
  • tar
    $ cd /var/lib ; tar cf /tmp/mysql.tar mysql

Pasamos la copia al esclavo y lo importamos:

  • mysqldump
    $ mysql -u root -p < /tmp/dump.sql
  • tar
    $ cd /var/lib ; tar xcf /tmp/mysql.tar

Lo siguiente es ponerle los datos del maestro al esclavo:

CHANGE MASTER TO master_host='IP_MAESTRO', master_user='slave', master_password='slavepass', master_log_file='', master_log_pos=4;
START slave;

Leave a Reply