第一部分:主從關係的同步 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;
MySQL雙機主從同步與雙向同步
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.