MySQL主從複製原理: master(主伺服器),slave(從伺服器) 1. MySQL master 將數據變更寫入二進位日誌( binary log, 其中記錄叫做二進位日誌事binary log events,可以通過 show binlog events 進行查看) 2. MySQL s ...
MySQL主從複製原理:
master(主伺服器),slave(從伺服器)
- MySQL master 將數據變更寫入二進位日誌( binary log, 其中記錄叫做二進位日誌事binary log events,可以通過 show binlog events 進行查看)
- MySQL slave 將 master 的 binary log events 拷貝到它的中繼日誌(relay log)
- MySQL slave 重放 relay log 中事件,將數據變更反映它自己的數據
1.MySQL下載安裝
- MySQL官方下載地址:https://dev.mysql.com/downloads/mysql/,選擇自己需要的版本以及對應的平臺。這裡本人選擇最新版本8.0.17,下載免安裝的zip包。
- 具體安裝步驟參照:https://www.cnblogs.com/laumians-notes/p/9069498.html
2.本地搭建主從複製
- 首先需要在本地安裝至少兩個MySQL伺服器,為了避免埠衝突,可以把mysql的伺服器的埠設置不同,這裡我設置一個為3306,另一個伺服器的埠號為3307,埠號在mysql的配置文件my.ini中配置。
主伺服器配置
[mysqld]
port=3306
basedir="D:/master/MySQL/"
datadir="D:/master/MySQL/data/"
character-set-server=utf8
server_id=1
log-bin=mysql-bin#要生成的二進位日記文件名稱
binlog-do-db=test#同步的資料庫
binlog-ignore-db=mysql#不參與同步的資料庫 ,例如mysql從伺服器配置
[mysqld]
port=3307
basedir=D:\slave\mysql2
datadir=D:\slave\mysql2\data
server-id=2
log-bin=mysql-bin#開啟了二進位文件
binlog_do_db=follow#主從複製的資料庫
binlog_ignore_db=mysql#不參與主從複製的資料庫,例如mysql接下來在主伺服器登錄mysql,創建用於主從複製的用戶並授權
create user 'xiao'@'127.0.0.1' identified by 'password';
grant replication slave on . to xiao@'127.0.0.1';在從伺服器上用創建的用戶登錄主伺服器,看能不能成功,成功繼續下麵的步驟
在主伺服器上執行命令:
show master status;(此命令查看主伺服器的bin-log日誌文件名稱和position點)
mysql> show master status;
+------------------+----------+--------------+------------------+
| File | Position | Binlog_Do_DB | Binlog_Ignore_DB |
+------------------+----------+--------------+------------------+
| mysql-bin.000001 | 107 | test | mysql |
+------------------+----------+--------------+------------------+
1 row in set (0.00 sec)
- 在從伺服器上執行以下命令:
在從庫設置它的master:
mysql> change master to
master_host='127.0.0.1',master_port=3306,master_user='xiao',master_password='password',master_log_file='mysql-bin.000001',master_log_pos=107;
Query OK, 0 rows affected (0.19 sec)
這裡的master_log_file和master_log_pos對應剛纔show master status記下的參數。
- 在從庫開啟從資料庫複製功能。
mysql>start slave;
Query OK, 0 rows affected (0.00 sec)
- 在從庫可以通過show slave status\G來查看一些參數。
當Slave_IO_Running和Slave_SQL_Running線程都為yes是主從複製配置成功!
- 此時在主庫創建表或插入數據,在從庫就會很快也能看到了。
-- 主庫
mysql> create table tianyc_02(b int);
Query OK, 0 rows affected (0.16 sec)
mysql> insert into tianyc_02 values(2013);
Query OK, 1 row affected (0.13 sec)
-- 從庫
mysql> show tables;
+----------------+
| Tables_in_test |
+----------------+
| tianyc_01 |
| tianyc_02 |
+----------------+
2 rows in set (0.00 sec)
mysql> select * from tianyc_02;
+------+
| b |
+------+
| 2013 |
+------+
1 row in set (0.00 sec)
同理,可以搭建第二、第三個從節點。
備註:兩個服務的serve_id必須不同,否則在開啟複製功能時會提示錯誤
mysql> slave start;
ERROR 1200 (HY000): The server is not configured as slave; fix in config file or with CHANGE MASTER TO
我這裡設置的主節點id為1,從節點id為2。也可以按照ip或埠進行設置,好用來區分。