Mediante la replicación master-slave de MySQL podemos repartir las lecturas de la base de datos entre varios hosts.
En este artículo veremos cómo montar un slave de MySQL.
1.- Primero tenemos que tener habilitado los binary logs y definir un server-id único dentro del entorno de replicación.
vi my.cnf
log-bin=mysql-bin
server-id=1
2.- En el slave debemos añadir también un server-id único:
vi my.cnf
server-id=2
3.- Reiniciamos los MySQL para aplicar los cambios.
/etc/init.d/mysql restart
4.- Creamos un usuario para la replicación en el master:
mysql> GRANT REPLICATION SLAVE ON *.* TO 'slave'@'%' IDENTIFIED BY 'password';
Query OK, 0 rows affected (0.04 sec)
mysql> FLUSH PRIVILEGES;
Query OK, 0 rows affected (0.00 sec)
5.- Bloquearemos la base de datos del master para poder posteriormente hacer la copia:
mysql> FLUSH TABLES;
Query OK, 0 rows affected (0.00 sec)
mysql> FLUSH TABLES WITH READ LOCK;
Query OK, 0 rows affected (0.00 sec)
mysql> SHOW MASTER STATUS;
+------------------+----------+--------------+------------------+
| File | Position | Binlog_Do_DB | Binlog_Ignore_DB |
+------------------+----------+--------------+------------------+
| mysql-bin.000002 | 1284 | | |
+------------------+----------+--------------+------------------+
1 row in set (0.00 sec)
6.- Realizamos la copia inicial de la base de datos. En el master ejecutamos:
mysqldump --all-databases bbdd_dump_20100101.sql
Luego lo importamos en el slave:
mysql < bbdd_dump_20100101.sql
7.- Una vez tenemos los datos podemos liberar el LOCK en el master:
mysql> UNLOCK TABLES;
8.- En el slave indicamos los datos del master para empezar la replicación:
mysql> SLAVE STOP;
Query OK, 0 rows affected, 1 warning (0.00 sec)
Los datos que hemos sacado del SHOW MASTER STATUS deberemos pasárselos al slave:
CHANGE MASTER TO MASTER_HOST='192.168.4.1', MASTER_USER='slave', MASTER_PASSWORD='password', MASTER_LOG_FILE='mysql-bin.000002', MASTER_LOG_POS=1284, MASTER_PORT=3306;
9.- A continuación iniciamos la replicación ejecutando el siguiente comando (en el slave):
mysql> START SLAVE;
Mediante SHOW SLAVE STATUS podemos ver el estado del slave:
mysql> SHOW SLAVE STATUS\G
*************************** 1. row ***************************
Slave_IO_State: Waiting for master to send event
Master_Host: 192.168.4.1
Master_User: slave
Master_Port: 3306
Connect_Retry: 60
Master_Log_File: mysql-bin.000002
Read_Master_Log_Pos: 951
Relay_Log_File: mysqld-relay-bin.000002
Relay_Log_Pos: 251
Relay_Master_Log_File: mysql-bin.000002
Slave_IO_Running: Yes
Slave_SQL_Running: Yes
Replicate_Do_DB:
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: 951
Relay_Log_Space: 407
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: 382
Master_SSL_Verify_Server_Cert: No
Last_IO_Errno: 0
Last_IO_Error:
Last_SQL_Errno: 0
Last_SQL_Error:
1 row in set (0.00 sec)
Veremos como poco a poco se va reduciendo el “Seconds_Behind_Master” hasta estar sincronizados con las escrituras que se hayan hecho mientras copiabamos los datafiles.
Seconds_Behind_Master: 0
10.- A continuación, podemos hacer una prueba con los siguientes comandos en el master:
mysql> CREATE DATABASE test;
Query OK, 1 row affected (0.00 sec)
mysql> USE test;
Database changed
mysql> create table aaa(id int);
Query OK, 0 rows affected (0.00 sec)
mysql> INSERT INTO test VALUES(2);
Query OK, 1 row affected (0.00 sec)
A continuación en el slave podremos comprobar como se han replicado:
mysql> USE test;
Database changed
mysql> select * from aaa;
+------+
| id |
+------+
| 2 |
+------+
1 row in set (0.00 sec)
Comentarios recientes
8 weeks 1 day ago
22 weeks 2 days ago
27 weeks 5 days ago
36 weeks 3 days ago
44 weeks 2 days ago
51 weeks 5 days ago
1 year 3 days ago
1 year 12 weeks ago
1 year 12 weeks ago
1 year 15 weeks ago