MySQL雙機主從同步與雙向同步

第一部分:主從關係的同步


master端 192.168.0.1
slave端  192.168.0.2

1。MASTER端
a.進入mysql,創建一個數據庫abc:
      create database abc;
b.創建一個用來同步的用戶,指定只能在192.168.0.2登錄:
      grant replication slave on *.* to 'ha'@'192.168.0.2' identified by 'hapwd';
c.修改master端的/etc/my.cnf文件
      server_id = 1 (爲1表示master,2表示slave)
      binlog-do-db = abc (abc表示要同步的數據庫),如果有多個數據庫,每個數據庫一行
      binlog-ignore-db= mysql    設置不需要同步的數據庫,每個數據庫一行 (一般這條可以不寫)
      log-bin = mysql-bin
d.重啓mysql

2。SLAVE端
a.修改slave端的/etc/my.cnf文件
      server_id = 2
      log-bin = mysql-bin
      master-host = 192.168.0.1
      master-user = ha
      master-password = 'hapwd' (如果爲空也要打上兩個單引號)
      master-port = 3306 (根據具體設置的端口號填)
      master-connect-retry = 10 連接重試次數
      replicate-do-db = abc 要接收的數據庫名,如果有多個數據庫,每個數據庫一行
      replicate-ignore-db= mysql   設置不要接收的數據庫,每個數據庫一行   (一般這條可以不寫)
b.重啓mysql
      配置成功後會在mysql目錄下生成master.info,如果要更改slave設置,要先將master.info刪除,纔會起作用
c.進入mysql,執行:
      slave start;
   用show slave status 或show master status 查看同步情況

第二部分:雙向關係的同步

master端 192.168.0.1
slave端  192.168.0.2

1。MASTER端
a.進入mysql,創建一個數據庫abc:
      create database abc;
b.創建一個用來同步的用戶,指定只能在192.168.0.2登錄:
      grant replication slave on *.* to 'ha'@'192.168.0.2' identified by 'hapwd';
c.修改master端的/etc/my.cnf文件
     log-bin
     server-id = 1
     sql-bin-update-same 同步模式 ,在mysql5以上的版本都不需要這句,否則會啓動不了mysql服務 
     binlog-do-db= abc    設置同步數據庫,如果有多個數據庫,每個數據庫一行
     binlog-ignore-db = mysql 設置不要同步的數據庫,如有多個數據庫,每個數據庫一行
     master-host=192.168.0.2
     master-user=ha
     master-password='hapwd'
     master-port=3306
     master-connect-retry=10
     replicate-do-db=abc   設置要接收的數據庫,如有多個數據庫,每個數據庫一行
     replicate-ignore-db= mysql   設置不要接收的數據庫,每個數據庫一行   (一般這條可以不寫)
     log-slave-updates    在mysql5以上的版本都不需要這句
d.重啓mysql
e.進入mysql,執行:
     slave start;

2。SLAVE端
a.進入mysql,創建一個數據庫abc:
      create database abc;
b.創建一個用來同步的用戶,指定只能在192.168.0.1登錄:
      grant replication slave on *.* to 'ha'@'192.168.0.1' identified by 'hapwd';
c.修改slave端的/etc/my.cnf文件
     log-bin
     server-id       = 2
     binlog-do-db= abc    設置同步數據庫,如果有多個數據庫,每個數據庫一行
     binlog-ignore-db = mysql 設置不要同步的數據庫,如有多個數據庫,每個數據庫一行
     sql-bin-update-same   同步模式 ,在mysql5以上的版本都不需要這句,否則會啓動不了mysql服務 
     master-host=192.168.0.1
     master-user= ha
     master-password='hapwd'
     master-port=3306
     master-connect-retry=10
     replicate-do-db=abc   設置要接收的數據庫,如有多個數據庫,每個數據庫一行
     replicate-ignore-db= mysql   設置不要接收的數據庫,每個數據庫一行   (一般這條可以不寫)
     log-slave-updates   在mysql5以上的版本都不需要這句
d.重啓mysql
e.進入mysql,執行:
     slave start;

注意:
1。如果有一端修改了數據後,另一端接收不到,手工執行命令load data from master;就可以了
2。如果因爲誤刪了二進制日誌文件導致無法同步,則執行:(這幾步很有用,你甚至可以把slave上的abc庫刪除掉,他會自動從master上覆制過來重建)
slave stop;
reset slave;
slave start;
3。我們經常會在reset slave後發現重新同步時會出現重複數據無法倒入的情況,比如:
               Last_Errno: 1062
                 Last_Error: Error 'Duplicate entry '1472533' for key 1' on query. Default database: 'epg'. Query: 'insert into boot_info(stbid,begintime)
                values('zk124070c819','1259128442')'
這時可以這樣,跳過沖突的這一行:
slave stop;
set GLOBAL SQL_SLAVE_SKIP_COUNTER=1;  
slave start;


發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章