詳解MySQL集群下的復(fù)制(replicate)原理
7. 集群下的復(fù)制
7.1. 簡(jiǎn)述
從MySQL 5.1 開始,就支持集群+復(fù)制了,這對(duì)于想要構(gòu)建一個(gè)高可用方案的用戶來說,無疑是個(gè)驚喜。在這種模式下,既有主從的實(shí)時(shí)備份,又有基于集群的負(fù)載均衡,不足指出在于,從我的測(cè)試結(jié)果來看,這種方案下的性能還不是太高,仍有待改進(jìn)。
集群+復(fù)制的配置其實(shí)很簡(jiǎn)單,就是配置好2個(gè)獨(dú)立的集群后,把其中一個(gè)的SQL節(jié)點(diǎn)作為另一個(gè)集群SQL節(jié)點(diǎn)的slave即可。甚至可以使用下面幾種架構(gòu):
3個(gè)集群,6個(gè)SQL節(jié)點(diǎn),形成一個(gè)3個(gè)點(diǎn)環(huán)形的復(fù)制。
3個(gè)集群,6個(gè)SQL節(jié)點(diǎn),形成一個(gè)6個(gè)點(diǎn)環(huán)形的復(fù)制,把另一個(gè)SQL節(jié)點(diǎn)也利用起來。
7.2. 開始配置
7.2.1. master上的配置
由于集群下的復(fù)制是基于row-based復(fù)制的,因此需要設(shè)置logbin-format的格式為:ROW 或者 MIXED。
相對(duì)于普通的mysqld服務(wù)器配置,只需要增加類似如下2行:
- server-id = 1
- binlog_format = "ROW" #or MIXED
7.2.2. slave上的配置
新版本的MySQL已經(jīng)不再通過 my.cnf 來指定master相關(guān)的信息了,而是通過 CHANGE MASTER 指令來管理。因此,slave上只需簡(jiǎn)單增加類似如下幾行:
- server-id = 2
- relay-log-purge=1
- skip-slave-start
- replicate-ignore-db=mysql
7.3. 啟動(dòng)slave
先按照正常的方式啟動(dòng)master和slave上的mysqld后,執(zhí)行SHOW PROCESSLIST 可以看到2個(gè)mysqld都只有2個(gè)進(jìn)程:
- mysql> SHOW PROCESSLIST;
- +----+-------------+-----------+------+---------+------+-----------------------------------+------------------+
- | Id | User | Host | db | Command | Time | State | Info |
- +----+-------------+-----------+------+---------+------+-----------------------------------+------------------+
- | 1 | system user | | | Daemon | 0 | Waiting for event from ndbcluster | NULL |
- | 2 | root | localhost | NULL | Query | 0 | NULL | show processlist |
- +----+-------------+-----------+------+---------+------+-----------------------------------+------------------+
- 2 rows in set (0.00 sec)
在slave上執(zhí)行 SHOW SLAVE STATUS 再看看:
- mysql> show slave status\G
- Empty set (0.00 sec)
可以看到,現(xiàn)在還沒有任何復(fù)制相關(guān)的配置。因此,我們需要先在master上添加一個(gè)賬戶用于復(fù)制:
- mysql> GRANT REPLICATION SLAVE, GRANT REPLICATION CLIENT ON *.* TO rep@’192.168.1.2’ IDENTIFIED BY ‘rep’;
- Query OK, 0 rows affected (0.00 sec)
然后,我們用 CHANGE MASTER 指令來指定一下 master 相關(guān)的參數(shù):
- mysql> CHANGE MASTER TO MASTER_HOST='192.168.0.2', MASTER_USER='rep', MASTER_PASSWORD='rep';
- Query OK, 0 rows affected (0.01 sec)
- mysql> SHOW SLAVE STATUS\G
- *************************** 1. row ***************************
- Slave_IO_State:
- Master_Host: 192.168.0.2
- Master_User: rep
- Master_Port: 3306
- Connect_Retry: 60
- Master_Log_File:
- Read_Master_Log_Pos: 4
- Relay_Log_File: slave-relay-bin.000001
- Relay_Log_Pos: 4
- Relay_Master_Log_File:
- Slave_IO_Running: No
- Slave_SQL_Running: No
- Replicate_Do_DB:
- Replicate_Ignore_DB: mysql
- 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: 0
- Relay_Log_Space: 106
- 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: NULL
- 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)
執(zhí)行 START SLAVE 來啟動(dòng)它。
- mysql> start slave;
- Query OK, 0 rows affected (0.00 sec)
再來看看:
- mysql> SHOW SLAVE STATUS\G
- *************************** 1. row ***************************
- Slave_IO_State: Waiting for master to send event
- Master_Host: 192.168.0.2
- Master_User: rep
- Master_Port: 3306
- Connect_Retry: 60
- Master_Log_File: binlog.000001
- Read_Master_Log_Pos: 256
- Relay_Log_File: slave-relay-bin.000002
- Relay_Log_Pos: 398
- Relay_Master_Log_File: binlog.000001
- Slave_IO_Running: Yes
- Slave_SQL_Running: Yes
- Replicate_Do_DB:
- Replicate_Ignore_DB: mysql
- 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: 256
- Relay_Log_Space: 557
- 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:
- 1 row in set (0.00 sec)
7.4. 簡(jiǎn)單測(cè)試
這個(gè)留給讀者自己按照常規(guī)的測(cè)試去完成吧。
【編輯推薦】
- MySQL數(shù)據(jù)庫集群進(jìn)行正確配置步驟
- MySQL 集群在Server1與Server2上如何安裝MySQL
- MySQL集群配置
- MySQL集群自動(dòng)安裝腳本
- MySQL觸發(fā)器如何正確使用