mariadb 多源複製

      最近做慢sql優化,比較頭疼,看到慢sql中全是一些select  count(*) 或者sum這樣的聚合統計的sql,由於本人的數據庫就是傳統的主從,或者一主多從,這樣的慢sql直接在數據庫上統計,對線上存在一定影響,而且由於多個db主從,統計一些相關數據也相對比較麻煩,所以決定搭建一臺專門用來給運營或者聚合統計操作查詢的多主從庫,彙集線上數據,方便查詢,也可以減少這些統計對線上庫的影響!

    搭建前,先說一下以前官方mysql版本都只支持一個master向一個slave複製,而mariadb 從10 開始已經支持多個master 向一個slave複製。mariadb 多源(主)複製適用場景:1) 現在很多公司動不動就想分庫分表,分表放在同一個實例還好說(但是這種情況下,相對於分區表,分表並沒有多大優勢吧),如果將分的表拆分到了不同的實例中,我們經常需要做一些彙總數據統計,沒有中間件或者一定的程序代碼是很難一次做到的,或者想要做線上兩個不同的db之間的誇實例join,這樣的操作,如果有一個多主從庫,有一份完整的數據,也會容易很多!2)備份,如果想要一份完整的線上數據備份,備份多主從庫是個不錯的選擇!

     

 搭建環境:

192.168.190.128   master128(主1)

192.168.190.129   master129(主2)

192.168.190.130    slave (從)

       步驟一、搭建主要步驟相對於傳統的主從沒有特別打的差異,只是各別的命令會有差異。我這裏因爲 master128  和master129都是有數據的,所以採取備份恢復的方式,先將兩個主的數據彙總到從庫當中:1.master128數據量比較大,採取xtrabackup 備份方式,2.master129採用mydump   --master-data -B  dbname1,dbname2......  >all0414.sql   這種備份方式

        步驟二、採用innobackupex 將maser128的數據恢復到slave中,具體恢復步驟這裏不說了,採用mysql -U  -P  < all0414.sql的恢復方式將master129的數據恢復到slave中,129這裏面數據庫訪問權限,需要單獨提添加下!

        步驟三、

CHANGE MASTER 'master128' to MASTER_HOST='192.168.190.128',MASTER_USER='rep_user', MASTER_PASSWORD='123456',MASTER_PORT=3306, MASTER_LOG_FILE='mysql-bin.000015',MASTER_LOG_POS=335; 

CHANGE MASTER 'master129' to MASTER_HOST='192.168.190.129',MASTER_USER='rep_user', MASTER_PASSWORD='123456',MASTER_PORT=3306, MASTER_LOG_FILE='mysql-bin.000008',MASTER_LOG_POS=486; 

         步驟四: start  slave  'master128';  start slave 'master129';    show all slaves status\G;

wKiom1jwaKeSeQcWAACPOO0DQN8012.png-wh_50

wKioL1jwaKfiejowAACPh8ZyP_o913.png-wh_50

        步驟五、上圖可以看出同步正常,我們在不同的db名中插入數據驗證同步情況,對於相同的db名,也是可以正常同步的,如果想要忽略同步,我們需要指定不同的master128.replicate_ignore_db=mysql  或者master129.replicate_ignore_db=mysql,如果不制定,直接指定replicate_ignore_db=mysql  則默認mysql都忽略!


   命令不相同的地方:

 stop  all  slaves  ,或者stop  slave 'maser128', stop  slave 'maser129'

 reset  slave 'maser128'  all    ;  reset  slave 'maser129' all 

show slave 'master128' status\G    show slave 'master129' status\G  

show all slaves status\G;



其他不同的地方參考官方文檔:https://mariadb.com/kb/zh-cn/multi-source-replication/#todo

     

    

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