1、首先要在本地建立兩個mysql服務(參考這裡),指定不同的埠。這裡一個主(3306),一個從(3307)。
2、然後修改主配置檔案:
[mysqld]
server-id = 1
binlog-do-db=test #要同步的資料庫
#binlog-ignore-db=mysql #不同步的資料庫,如果指定了binlog-do-db這裡應該可以不用指定的
log-bin=mysql-bin #要生成的二進位制日記檔名稱
修改從配置檔案:
server-id = 2
log-bin = mysql-bin
replicate-do-db=test
3、在主庫新增一個使用者 repl 並指定replication許可權
create user "repl"@"127.0.0.1" identified by "asdf";
GRANT REPLICATION SLAVE ON *.* TO "repl"@"127.0.0.1"; -- --這裡指定資料庫(test.*)時報錯,而指定全庫(*.*)時會成功。
4、保持主從mysql的test資料庫初始狀態一致。
一般是先將所有的表加讀鎖,然後copy磁碟上的資料庫資料夾。這裡直接停止服務,然後將資料檔案複製過去。
5、在主資料庫裡面執行show master status;記下file和position欄位對應的引數。
mysql> show master status;
+------------------+----------+--------------+------------------+
| File | Position | Binlog_Do_DB | Binlog_Ignore_DB |
| mysql-bin.000001 | 107 | test | |
1 row in set (0.00 sec)
6、在從庫設定它的master:
mysql> change master to master_host="127.0.0.1",master_port=3306,master_user="repl",master_password="asdf",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記下的引數。
7、在從庫開啟從資料庫複製功能。
slave start;
mysql> slave start;
Query OK, 0 rows affected (0.00 sec)
在從庫可以透過show slave status來檢視一些引數。
8. 此時在主庫建立表或插入資料,在從庫就會很快也能看到了。
-- 主庫
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 |
同理,可以搭建第二、第三個從節點。
備註:兩個服務的serve_id必須不同,否則在開啟複製功能時會提示錯誤
ERROR 1200 (HY000): The server is not configured as slave; fix in config file or with CHANGE MASTER TO
這裡設定的主節點id為1,從節點id為2。也可以按照ip或埠進行設定,好用來區分。
注意:
* 主從間的資料庫不是實時同步,就算網路連線正常,也存在瞬間,主從資料不一致。
* 如果主從的網路斷開,從會在網路正常後,批次同步。
* 如果對從進行修改資料,那麼很可能從在執行主的bin-log時出現錯誤而停止同步,這個是很危險的操作。所以一般情況下,非常小心的修改從上的資料。
1、首先要在本地建立兩個mysql服務(參考這裡),指定不同的埠。這裡一個主(3306),一個從(3307)。
2、然後修改主配置檔案:
[mysqld]
server-id = 1
binlog-do-db=test #要同步的資料庫
#binlog-ignore-db=mysql #不同步的資料庫,如果指定了binlog-do-db這裡應該可以不用指定的
log-bin=mysql-bin #要生成的二進位制日記檔名稱
修改從配置檔案:
[mysqld]
server-id = 2
log-bin = mysql-bin
replicate-do-db=test
3、在主庫新增一個使用者 repl 並指定replication許可權
create user "repl"@"127.0.0.1" identified by "asdf";
GRANT REPLICATION SLAVE ON *.* TO "repl"@"127.0.0.1"; -- --這裡指定資料庫(test.*)時報錯,而指定全庫(*.*)時會成功。
4、保持主從mysql的test資料庫初始狀態一致。
一般是先將所有的表加讀鎖,然後copy磁碟上的資料庫資料夾。這裡直接停止服務,然後將資料檔案複製過去。
5、在主資料庫裡面執行show master status;記下file和position欄位對應的引數。
mysql> show master status;
+------------------+----------+--------------+------------------+
| File | Position | Binlog_Do_DB | Binlog_Ignore_DB |
+------------------+----------+--------------+------------------+
| mysql-bin.000001 | 107 | test | |
+------------------+----------+--------------+------------------+
1 row in set (0.00 sec)
6、在從庫設定它的master:
mysql> change master to master_host="127.0.0.1",master_port=3306,master_user="repl",master_password="asdf",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記下的引數。
7、在從庫開啟從資料庫複製功能。
slave start;
mysql> slave start;
Query OK, 0 rows affected (0.00 sec)
在從庫可以透過show slave status來檢視一些引數。
8. 此時在主庫建立表或插入資料,在從庫就會很快也能看到了。
-- 主庫
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或埠進行設定,好用來區分。
注意:
* 主從間的資料庫不是實時同步,就算網路連線正常,也存在瞬間,主從資料不一致。
* 如果主從的網路斷開,從會在網路正常後,批次同步。
* 如果對從進行修改資料,那麼很可能從在執行主的bin-log時出現錯誤而停止同步,這個是很危險的操作。所以一般情況下,非常小心的修改從上的資料。