1. 程式人生 > >MySQL高可用配置(主從復制)

MySQL高可用配置(主從復制)

整數 mas pos 當前 sla ids 測試 cer cte

主從復制包含兩個步驟:

在 master 主服務器(組)上的設置,以及在 slave 從屬服務器(組)上的設置。

環境:

MASTER: 192.168.155.101
SLAVE: 192.168.155.102

註意點:

1. 配置主服務器 master需要啟用二進制日誌。
2. 給 master 設置唯一的 server_id ,所有的 slave 從屬服務器也要設置 server_id。server_id值可以是整數型的數字(1 ~ 2^31-1), 在同一個復制組(replicating group)中的每臺服務器的server_id都必須是唯一的。
3. slave 從屬服務器需要有連接並從master復制的權限, 通常是為每一臺slave 創建一個單獨的用戶(user),並且只授予復制的權限(REPLICATION SLAVE 權限).也可使用共用的用戶權限。

MASTER配置:
First Node (MASTER: 192.168.155.101)
---------------
vi /etc/my.cnf.d/server.cnf

[mysqld]
server-id=1
log-bin=master-bin
binlog-do-db=my-db #需要啟用事務日誌的數據庫名
binlog-ignore-db=mysql #不啟用事務日誌的系統數據庫名

以上兩行不指定的話,將對全部數據庫啟用事務日誌。

GRANT REPLICATION SLAVE ON *.* TO ‘rep_user‘@‘%‘ IDENTIFIED BY ‘rep_pass‘;
FLUSH PRIVILEGES;

# service mysql restart

查看Master當前二進制日誌的position時,需要阻止任何數據的提交,並鎖定所有的表。
MariaDB [(none)]> FLUSH TABLES WITH READ LOCK;
MariaDB [(none)]> SHOW MASTER STATUS;
+-------------------+----------+--------------+------------------+
| File | Position | Binlog_Do_DB | Binlog_Ignore_DB |
+-------------------+----------+--------------+------------------+
| master-bin.000001 | 245 | | |
+-------------------+----------+--------------+------------------+
1 row in set (0.00 sec)

記下File列的日誌文件名和Position列的位置數,在SLAVE上同步時需要。
備份MASTER上的數據庫並在SLAVE上手動導入。

釋放表鎖定
MariaDB [(none)]> UNLOCK TABLES;

SLAVE配置:

Other Node (SLAVE: 192.168.155.102)
---------------
vi /etc/my.cnf.d/server.cnf

[mysqld]
server-id=2
read-only=on
relay-log=relay-bin
innodb_recovery_update_relay_log=1
relay_log_recovery=1
replicate-do-db=my-db #需要同步事務日誌的數據庫名
replicate-ignore-db=mysql #不需要同步事務日誌的系統數據庫名

以上兩行不指定的話,將對全部數據庫同步事務日誌。

# service mysql restart

MariaDB [(none)]> show variables like ‘%relay%‘;
+----------------------------------+----------------+
| Variable_name | Value |
+----------------------------------+----------------+
| innodb_recovery_update_relay_log | ON |
| max_relay_log_size | 0 |
| relay_log | relay-bin |
| relay_log_index | |
| relay_log_info_file | relay-log.info |
| relay_log_purge | ON |
| relay_log_recovery | ON |
| relay_log_space_limit | 0 |
| sync_relay_log | 0 |
| sync_relay_log_info | 0 |
+----------------------------------+----------------+
10 rows in set (0.00 sec)

開始同步
MariaDB [(none)]> CHANGE MASTER TO
-> MASTER_HOST=‘192.168.155.101‘,
-> MASTER_USER=‘rep_user‘,
-> MASTER_PASSWORD=‘rep_pass‘,
-> MASTER_PORT=3306,
-> MASTER_LOG_FILE=‘master-bin.000001‘,
-> MASTER_LOG_POS=245,
-> MASTER_CONNECT_RETRY=10;
Query OK, 0 rows affected (0.08 sec)

MariaDB [(none)]> START SLAVE;

查看SLAVE狀態:
MariaDB [(none)]> show slave status\G;
*************************** 1. row ***************************
Slave_IO_State: Waiting for master to send event
Master_Host: 192.168.155.101
Master_User: rep_user
Master_Port: 3306
Connect_Retry: 10
Master_Log_File: master-bin.000002
Read_Master_Log_Pos: 411
Relay_Log_File: relay-bin.000006
Relay_Log_Pos: 696
Relay_Master_Log_File: master-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: 411
Relay_Log_Space: 1269
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: 1
1 row in set (0.00 sec)

查看Slave_IO_Running和Slave_SQL_Running,如果都是Yes說明搭建成功,就可以建表插入數據測試了。

如果需要暫停SLAVE復制
MariaDB [(none)]> STOP SLAVE;

如果出現SLAVE不同步的現象,可以先暫停SLAVE復制,再執行一次同步操作即可。

MySQL高可用配置(主從復制)