中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

MySQL半同步復制

發布時間:2020-06-28 10:52:05 來源:網絡 閱讀:228 作者:吳金瑞 欄目:建站服務器

    

1、半同步復制簡介

  何為半同步復制模式呢?在此我們先了解異步復制模式,這是MySQL的默認復制選項。異步復制即是master數據庫把binlog日志發送給slave數據庫,然后就沒有了然后了。在此暴露一個問題,當slave服務器發生故障了,那么肯定會導致主從數據庫服務器的數據不一致。

  為了解決上面的問題,MySQL5.5引入一種叫做半同步復制模式。開啟這種模式,可以保證slave數據庫接收完master數據庫發送過來的binlog日志并寫入自己的中繼日志中,然后反饋給master數據庫,告知已經復制完畢。

  開啟這種模式后,當出現超時,主數據庫將會自動轉為異步復制模式,直到至少有一臺從服務器接受到主數據庫的binlog,并且反饋給主數據庫。這時主數據庫才會切換回半同步復制模式。

注意:

半同步復制模式必須在主服務器和從服務器同時中開啟,否則將會默認為異步復制模式。


2、環境說明

  兩臺linux虛擬主機

  Linux版本CentOS6.6、MySQL 5.5

  ip:192.168.95.11(主)、192.168.95.12(從)


3、安裝與配置


  3.1、安裝前提

    1、必須是MySQL5.5或者以上

    2、MySQL必須有自動加載功能,即have_dynamic_loading變量為YES(因為我們是在MySQL里面來加載安裝這個功能插件)

       show variables like 'have_dynamic_loading';  #檢查是否具有自動加載功能

MySQL半同步復制

    3、主從復制已經配置好,并且已經ing工作著的。

      主從復制配置教程:h tt p:// w w w.cn blo gs.co m/ph pstud y2015-6/p/6485819.html


  3.2、安裝

    192.168.95.11加載安裝:

MySQL半同步復制

1 mysql>install plugin rpl_semi_sync_master soname 'semisync_master.so';2 3 mysql>show plugins;   #查看是否加載成功4 5 mysql>SET GLOBAL rpl_semi_sync_master_enabled = 1;  #開啟半同步復制,默認是關閉的

MySQL半同步復制

MySQL半同步復制

    192.168.95.12加載安裝

MySQL半同步復制

 1 mysql>INSTALL PLUGIN rpl_semi_sync_slave SONAME 'semisync_slave.so'; 2  3 mysql>show plugins;   #查看是否加載成功 4  5 mysql>SET GLOBAL rpl_semi_sync_slave_enabled = 1;  #開啟半同步復制,默認是關閉的 6  7 #重啟從服務器IO線程,手動將異步模式切換為半同步模式 8  9 mysql>STOP SLAVE IO_THREAD;10 11 mysql>START SLAVE IO_THREAD;

MySQL半同步復制

 


  3.3、配置文件
1 rpl_semi_sync_master_enabled=1  #主庫配置文件添加,表示以后啟動MySQL將會自動開啟半同步復制2 3 rpl_semi_sync_slave_enabled=1  #從庫配置文件添加,同上


4、查看相關參數

  1、主從執行命令show variables like '%semi%';

  master:

MySQL半同步復制

  Rpl_semi_sync_master_enabled=ON表示開啟半同步復制

  Rpl_semi_sync_master_timeout=1000默認1000毫秒,即10秒超時,將切換為異步復制

  Rpl_semi_sync_master_wait_no_slave表示是否允許master每個事物都要等待slave接收確認,默認為ON

  Rpl_semi_sync_master_trace_level=32表示用于開啟半同步復制時的調試級別,默認32

  slave:

MySQL半同步復制

  Rpl_semi_sync_slave_enabled=ON表示在slave已經開始半同步復制模式

  Rpl_semi_sync_slave_trace_level=32表示用于開啟半同步復制時的調試級別,默認32

  2、主從執行命令show status like '%semi%';

  master

MySQL半同步復制

  Rpl_semi_sync_master_status表示主服務器使用是異步還是半同步復制

  Rpl_semi_sync_master_client表示從服務器有多少個配置成半同步復制

  Rpl_semi_sync_master_yes_tx表示從服務器確認成功提交的數量

  Rpl_semi_sync_master_no_tx表示從服務器確認失敗提交的數量

  slave:

MySQL半同步復制

  Rpl_semi_sync_slave_status表示從服務器開啟半同步復制


5、測試

  模擬slave掛掉,master等待10s仍沒接收到反饋信號,則轉為異步復制模式,繼續執行

  首先同步創建數據庫aa

  1、slave執行stop slave;關閉主從復制

  2、master在aa數據庫中創建表tab1,沒接收到反饋信號,等待十秒后(Rpl_semi_sync_master_timeout=1000等待超時),繼續執行

    master:

    MySQL半同步復制

    slave:

    MySQL半同步復制

  3、master在數據庫中再創建tab2,不需要等待反饋,直接執行

   【當反饋超時時,master將切換到異步復制模式。此時是異步模式,不需要等待】

    MySQL半同步復制

  4、slave執行start slave,數據開始同步,建立tab1、tab2,反饋給master,并切換為半同步復制

   MySQL半同步復制

  5、slave執行stop slave;關閉主從復制

  6、master在數據庫中創建表tab3,此時需要等待10s,接收slave反饋信號;等待超時,切換為異步復制模式,繼續執行

   【步驟4時,數據同步已經反饋給master,此時master已經是半同步復制模式】

   MySQL半同步復制


6、總結

  半同步復制模式的性能和并發比異步復制模式低的,因為每次復制都要進行反饋,相比之下多了一個步驟。

  說實話我還是不太明白為什么半同步復制就可以保持數據的完整性呢?若是slave掛了,master還不是變回異步復制。和之前的全異步沒什么區別。還有就是即使多了個信息反饋,但是反饋回來除了讓master確認還有什么作用?假若slave掛了,沒有反饋信息,那master還是沒什么進一步的處理方法呀。


向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

胶州市| 永丰县| 乌兰县| 务川| 灵台县| 榆社县| 保靖县| 页游| 车致| 栾城县| 保德县| 洱源县| 原平市| 平南县| 固原市| 湖北省| 太湖县| 城步| 南安市| 汉中市| 通海县| 赣州市| 专栏| 赤壁市| 华亭县| 秭归县| 雷波县| 界首市| 垫江县| 宣恩县| 双鸭山市| 梅州市| 洱源县| 永顺县| 平江县| 潼南县| 锦州市| 疏勒县| 玉山县| 拉萨市| 铜川市|