久久精品国产亚洲高清|精品日韩中文乱码在线|亚洲va中文字幕无码久|伊人久久综合狼伊人久久|亚洲不卡av不卡一区二区|精品久久久久久久蜜臀AV|国产精品19久久久久久不卡|国产男女猛烈视频在线观看麻豆

    1. <style id="76ofp"></style>

      <style id="76ofp"></style>
      <rt id="76ofp"></rt>
      <form id="76ofp"><optgroup id="76ofp"></optgroup></form>
      1. 千鋒教育-做有情懷、有良心、有品質(zhì)的職業(yè)教育機構(gòu)

        手機站
        千鋒教育

        千鋒學(xué)習(xí)站 | 隨時隨地免費學(xué)

        千鋒教育

        掃一掃進入千鋒手機站

        領(lǐng)取全套視頻
        千鋒教育

        關(guān)注千鋒學(xué)習(xí)站小程序
        隨時隨地免費學(xué)習(xí)課程

        當(dāng)前位置:首頁  >  技術(shù)干貨  > MySQL中,既有redo log作為WAL,為什么還要change buffer只作用于二級索引?

        MySQL中,既有redo log作為WAL,為什么還要change buffer只作用于二級索引?

        來源:千鋒教育
        發(fā)布人:xqq
        時間: 2023-10-13 15:10:19 1697181019

        一、MySQL中,為什么還要change buffer只作用于二級索引

        先說一下普通一個數(shù)據(jù)修改的過程(這里不涉及到改主鍵索引或少數(shù)索引B+樹結(jié)構(gòu)的,就說改普通字段的值)

        名列前茅步:INNODB要修改一個數(shù)據(jù)時,先判斷內(nèi)存(Buffer Pool)中有沒有這個數(shù)據(jù),有的話則直接修改內(nèi)存。沒有的話,先從磁盤中讀到內(nèi)存,再進行修改(先假設(shè)是這樣)。

        第二步:寫redo log,將事務(wù)的狀態(tài)標(biāo)位prepare

        第三步:寫binlog

        第四步;將redo log中事務(wù)的狀態(tài)標(biāo)位commit

        到這里,一個事務(wù)已經(jīng)結(jié)束了,但是你會發(fā)現(xiàn),數(shù)據(jù)壓根就沒落盤,只在Buffer Pool進行了相應(yīng)的修改。

        而這些在內(nèi)存中的數(shù)據(jù)(臟頁)會在一段時間后因為某些原因才會被刷到磁盤中,那在這中間還沒有刷到磁盤的過程中,則有可能發(fā)生斷電,那還沒有保存到磁盤中的buffer pool中的數(shù)據(jù)也就丟了,而redo log的作用,就是斷電重啟之后,用來恢復(fù)這部分的數(shù)據(jù)。(在我看來,redo log的作用僅此而已,有誤的話可以指正)

        再回過頭看名列前茅步:如果是普通索引(非少數(shù)索引),哪怕內(nèi)存中沒有這條數(shù)據(jù),直接保存修改就行了,連去磁盤讀取出這條數(shù)據(jù)這一步都不需要,節(jié)省了磁盤IO的時間。也就是上面說的流程中的名列前茅步其實應(yīng)該改為:如果僅僅修改了普通索引的話,內(nèi)存中若有這條數(shù)據(jù),則直接修改,若沒這條數(shù)據(jù),則先將修改的操作寫到change buffer中。

        回到問題:change buffer是做什么的?

        答:當(dāng)然是為了提高效率的,但是有一定的局限性,基本上只能用在:數(shù)據(jù)在磁盤中而不在內(nèi)存中,而這次修改不會涉及到改動主鍵索引以及少數(shù)索引的結(jié)構(gòu) 的情況之下。也就是優(yōu)化了上面流程中的名列前茅步。

        第二個問題:我沒太理解是什么意思,不過我上面一段的描述或許能夠解釋?

        問:change buffer似乎只能作用于二級索引?

        答:什么時候不能夠用change buffer呢?如果涉及到修改聚簇索引(主鍵索引)的結(jié)構(gòu)時,比如新增一條字段,或者直接把主鍵的值給改了,類似于這樣的操作,當(dāng)然是用不了change buffer的。因為為了主鍵少數(shù)性校驗,必須先去磁盤中讀有沒有這條數(shù)據(jù)(或者內(nèi)存中有對應(yīng)的數(shù)據(jù)頁也可以),才能進行更新,比如插入了一條id=5的數(shù)據(jù),那當(dāng)然要去判斷一下有沒有id = 5的數(shù)據(jù),才能進行插入了,此時change buffer也就沒有意義了。

        延伸閱讀:

        二、為什么要持久化連接

        這和 web 服務(wù)器的工作方式有關(guān)。web 服務(wù)器可以通過三種方法來利用 PHP 生成 web 頁面。

        名列前茅種方法是將 PHP 自以為 CGI“包裝器”用作一個單獨運行的語言解釋器(CGI Wapper)。當(dāng)以這種方法運行時,PHP 會為向 web 服務(wù)器的每個 PHP 頁面請求創(chuàng)建并銷毀 PHP 解釋器的時候?qū)嵗?。由于其會隨每個請求的結(jié)束而銷毀,因此其獲取的任何資源(例如指向 SQL 數(shù)據(jù)庫服務(wù)器的鏈接)都會在銷毀時關(guān)閉。在這種情況下,不會從使用持久連接中獲得任何好處——因為根本不會持久。

        第二,也是最流行的方法是把 PHP 用作多進程 web 服務(wù)器的一個模塊,這種方法目前只適用于 Apache。多進程的服務(wù)器通常有一個父進程和一組子進程協(xié)調(diào)運行,子進程負(fù)責(zé)提供網(wǎng)頁的工作。每當(dāng)接收達到客戶端提出請求時,該請求會傳遞給尚未給其它客戶端提供服務(wù)的某個子進程。這也就是說當(dāng)相同的客戶端第二次向服務(wù)端發(fā)出請求時,它將有可能由與名列前茅次不同的某個子進程提供服務(wù)。在開啟了一個持久連接后,所有請求 SQL 服務(wù)的后繼頁面都能夠重用與 SQL 服務(wù)器建立的相同連接。

        最后一種方法是將 PHP 用作多線程 web 服務(wù)器的插件。目前 PHP 支持 WSAPI 和 NSAPI(在 Windows 上),允許 PHP 作為 Netscape FastTrack(iPlanet)、Microsoft 的 Internet Information Server (IIS) 和 O’Reilly 的 WebSite Pro 等多線程服務(wù)器的插件使用。該行為與前面描述的多過程模型相同。

        聲明:本站稿件版權(quán)均屬千鋒教育所有,未經(jīng)許可不得擅自轉(zhuǎn)載。
        10年以上業(yè)內(nèi)強師集結(jié),手把手帶你蛻變精英
        請您保持通訊暢通,專屬學(xué)習(xí)老師24小時內(nèi)將與您1V1溝通
        免費領(lǐng)取
        今日已有369人領(lǐng)取成功
        劉同學(xué) 138****2860 剛剛成功領(lǐng)取
        王同學(xué) 131****2015 剛剛成功領(lǐng)取
        張同學(xué) 133****4652 剛剛成功領(lǐng)取
        李同學(xué) 135****8607 剛剛成功領(lǐng)取
        楊同學(xué) 132****5667 剛剛成功領(lǐng)取
        岳同學(xué) 134****6652 剛剛成功領(lǐng)取
        梁同學(xué) 157****2950 剛剛成功領(lǐng)取
        劉同學(xué) 189****1015 剛剛成功領(lǐng)取
        張同學(xué) 155****4678 剛剛成功領(lǐng)取
        鄒同學(xué) 139****2907 剛剛成功領(lǐng)取
        董同學(xué) 138****2867 剛剛成功領(lǐng)取
        周同學(xué) 136****3602 剛剛成功領(lǐng)取
        相關(guān)推薦HOT
        如何建立數(shù)據(jù)庫,利用什么軟件建立數(shù)據(jù)庫?

        一、如何建立數(shù)據(jù)庫CREATE DATABASE:MySQL語法示例應(yīng)該提到的在MySQL中創(chuàng)建數(shù)據(jù)庫的名列前茅種方法是使用CREATE DATABASE語句。該語句以指定的...詳情>>

        2023-10-13 16:56:43
        為什么使用Redis做緩存而不會使用關(guān)系型數(shù)據(jù)庫?

        一、為什么使用Redis做緩存而不會使用關(guān)系型數(shù)據(jù)庫首先要知道緩存緩存是干什么的,緩存是指可以進行高速數(shù)據(jù)交換的存儲器,它先于內(nèi)存與CPU交換...詳情>>

        2023-10-13 16:43:22
        mysql 非少數(shù)索引的等值查詢?yōu)槭裁匆觛ap鎖?

        一、mysql 非少數(shù)索引的等值查詢?yōu)槭裁匆觛ap鎖mysql 中非少數(shù)索引使用的也是 B+ 樹來組織數(shù)據(jù)結(jié)構(gòu)。假設(shè) id 的索引結(jié)構(gòu)在葉子節(jié)點從左到右的...詳情>>

        2023-10-13 16:33:11
        mongoDB和python連接處理數(shù)據(jù)慢怎么解決?

        一、mongoDB和python連接處理數(shù)據(jù)慢怎么解決mongoDB和python連接處理數(shù)據(jù)慢可以考慮用并行計算,單機多線程并行,或者集群并行。集算器提供封裝...詳情>>

        2023-10-13 16:29:19
        MySQL DDL會鎖表不能寫,怎么保證持續(xù)讀寫呢?

        一、MySQL DDL會鎖表不能寫,怎么保證持續(xù)讀寫比較笨的方法通常就是最常用的方法。搞一個臨時表,新數(shù)據(jù)寫兩份,舊數(shù)據(jù)分段導(dǎo)入臨時表。舊數(shù)據(jù)...詳情>>

        2023-10-13 16:26:29
        快速通道
        南昌县| 博爱县| 布尔津县| 堆龙德庆县| 上思县| 铜梁县| 木兰县| 四川省| 龙岩市| 离岛区| 宽甸| 甘南县| 葵青区| 洞头县| 德化县| 临安市| 福建省| 建湖县| 瑞丽市| 永泰县| 台湾省| 宁强县| 瓦房店市| 隆回县| 冕宁县| 天柱县| 榕江县| 鄂州市| 和硕县| 宿州市| 嘉义市| 三门县| 小金县| 观塘区| 通榆县| 永春县| 洪泽县| 北宁市| 菏泽市| 花垣县| 措美县|