91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

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

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

MySQL double write

發布時間:2020-08-09 17:28:56 來源:ITPUB博客 閱讀:302 作者:哎呀我的天吶 欄目:MySQL數據庫

double write 技術的引入就是為了提高數據寫入的可靠性。當寫入部分數據的時候,比如:512bytes。

為什么Oracle沒有解決這個問題,而MySQL通過double write去解決這個事情呢。

 doublewrite 默認存放在ibdata1中共享表空間里,默認大小2M,寫之前將臟頁寫入到innodb buffer中的doublewrite buffer(2M)中,將2M的buffer數據直接寫入到共享表空間的doublewrite段中,當寫共享表空間的doublewrite失敗了,沒有關系,因為此時的數據文件ibd中的數據是干凈的,處于一致的狀態,可以通過redo進行恢復,【先寫共享表空間的double 再寫數據文件ibd】,doublewrite是覆蓋寫,共享表空間只存2M給doublewrite用。Redo能恢復的頁一定是干凈的完整的一致的,因為mysql會有partial write所以引入doublewrite機制。

  double write buffer à double write(ibdata1) à ibd

MySQL double write                        

doublewrite 對性能影響大嗎

如果頁大小是 16k ,那么就有 128 個頁 (1M) 需要寫,但是 128 個頁寫入到共享表空間是 1 IO 完成,也就是說 doublewrite 寫開銷是 1+128 次。其中 128 次是寫數據文件表空間。

 

doublewrite 寫入是順序的,性能開銷取決于寫入量,通常 5%-25% 的性能影響。

當系統負載非常高的情況下,性能開銷減少 25%

 

對應數據庫參數

Double write 技術對用戶來說是透明的,我們只關注下面參數開啟或關閉即可。

mysql> show variables like '%double%write%';
+--------------------+-------+
| Variable_name      | Value |
+--------------------+-------+
| innodb_doublewrite | ON    |
+--------------------+-------+
1 row in set (0.00 sec)

什么情況下可以關閉 doublewrite 特性能

1、Fursion-io 原子寫,如果每次寫16k就是16k,每次寫都是16k不會出現部分寫partial write寫4k的情況。設備帶來的益處。

2、 特定的文件系統,支持原子寫。 b-tree file system





介紹double write之前我們有必要了解partial page write 問題 : 
    InnoDB 的Page Size一般是16KB,其數據校驗也是針對這16KB來計算的,將數據寫入到磁盤是以Page為單位進行操作的。而計算機硬件和操作系統,在極端情況下(比如斷電)往往并不能保證這一操作的原子性,16K的數據,寫入4K 時,發生了系統斷電/os crash ,只有一部分寫是成功的,這種情況下就是 partial page write 問題。
很多DBA 會想到系統恢復后,MySQL 可以根據redolog 進行恢復,而mysql在恢復的過程中是檢查page的checksum,checksum就是pgae的最后事務號,發生partial page write 問題時,page已經損壞,找不到該page中的事務號,就無法恢復。

一 double write是什么?
    Double write 是InnoDB在 tablespace上的128個頁(2個區)是2MB;
其原理:
    為了解決 partial page write 問題 ,當mysql將臟數據flush到data file的時候, 先使用memcopy 將臟數據復制到內存中的double write buffer ,之后通過double write buffer再分2次,每次寫入1MB到共享表空間,然后馬上調用fsync函數,同步到磁盤上,避免緩沖帶來的問題,在這個過程中,doublewrite是順序寫,開銷并不大,在完成doublewrite寫入后,在將double write buffer寫入各表空間文件,這時是離散寫入。
如果發生了極端情況(斷電),InnoDB再次啟動后,發現了一個Page數據已經損壞,那么此時就可以從doublewrite buffer中進行數據恢復了。
MySQL double write

二double write的缺點是什么?
     位于共享表空間上的double write buffer實際上也是一個文件,寫DWB會導致系統有更多的fsync操作, 而硬盤的fsync性能, 所以它會降低mysql的整體性能. 但是并不會降低到原來的50%. 這主要是因為: 
1) double write 是一個連接的存儲空間, 所以硬盤在寫數據的時候是順序寫, 而不是隨機寫, 這樣性能更高. 
2) 將數據從double write buffer寫到真正的segment中的時候, 系統會自動合并連接空間刷新的方式, 每次可以刷新多個pages; 三 double write在恢復的時候是如何工作的?
If there’s a partial page write to the doublewrite buffer itself, the original page will still be on disk in its real location.-
--如果是寫doublewrite buffer本身失敗,那么這些數據不會被寫到磁盤,InnoDB此時會從磁盤載入原始的數據,然后通過InnoDB的事務日志來計算出正確的數據,重新 寫入到doublewrite buffer.
When InnoDB recovers, it will use the original page instead of the corrupted copy in the doublewrite buffer. However, if the doublewrite buffer succeeds and the write to the page’s real location fails, InnoDB will use the copy in the doublewrite buffer during recovery. 
--如果 doublewrite buffer寫成功的話,但是寫磁盤失敗,InnoDB就不用通過事務日志來計算了,而是直接用buffer的數據再寫一遍.
InnoDB knows when a page is corrupt because each page has a checksum at the end; the checksum is the last thing to be written, so if the page’s contents don’t match the checksum, the page is corrupt. Upon recovery, therefore, InnoDB just reads each page in the doublewrite buffer and verifies the checksums. If a page’s checksum is incorrect, it reads the page from its original location.
--在恢復的時候,InnoDB直接比較頁面的checksum,如果不對的話,就從硬盤載入原始數據,再由事務日志 開始推演出正確的數據.所以InnoDB的恢復通常需要較長的時間. 四 我們是否一定需要 double write ?
In some cases, the doublewrite buffer really isn’t necessary—for example, you might want to disable it on slaves. Also, some filesystems (such as ZFS) do the same thing themselves, so it is redundant for InnoDB to do it. You can disable the doublewrite buffer by setting InnoDB_doublewrite to 0.

五  如何使用 double write
InnoDB_doublewrite=1表示啟動double write
show status like 'InnoDB_dblwr%'可以查詢double write的使用情況;
相關參數與狀態
Double write的使用情況:
show status like  "%InnoDB_dblwr%"; InnoDB_dblwr_pages_written 從bp flush 到 DBWB的個數
InnoDB_dblwr_writes            寫文件的次數
每次寫操作合并page的個數= InnoDB_dblwr_pages_written/InnoDB_dblwr_writes   

向AI問一下細節

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

AI

辽宁省| 鹤岗市| 德化县| 新建县| 陆丰市| 尤溪县| 赤水市| 吉木萨尔县| 麻江县| 浙江省| 逊克县| 邯郸县| 凌海市| 中阳县| 家居| 天全县| 安龙县| 老河口市| 青河县| 华安县| 南靖县| 清镇市| 龙川县| 东明县| 潮安县| 岑巩县| 会东县| 沅江市| 甘洛县| 通化县| 齐齐哈尔市| 高州市| 临湘市| 滨州市| 新巴尔虎右旗| 应城市| 亳州市| 法库县| 四平市| 瑞丽市| 吉水县|