windows mysql主從服務器建立

bgn4 9年前發布 | 10K 次閱讀 MySQL 數據庫服務器

首先要在本地建立兩個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)

同理,可以搭建第二、第三個從節點。

參考:http://blog.sina.com.cn/s/blog_4d06da1f01010m55.html

備注:兩個服務的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時出現錯誤而停止同步,這個是很危險的操作。所以一般情況下,非常小心的修改從上的數據。

 本文由用戶 bgn4 自行上傳分享,僅供網友學習交流。所有權歸原作者,若您的權利被侵害,請聯系管理員。
 轉載本站原創文章,請注明出處,并保留原始鏈接、圖片水印。
 本站是一個以用戶分享為主的開源技術平臺,歡迎各類分享!