国产睡熟迷奷白丝护士系列精品,中文色字幕网站,免费h网站在线观看的,亚洲开心激情在线

      <sup id="hb9fh"></sup>
          1. 千鋒教育-做有情懷、有良心、有品質(zhì)的職業(yè)教育機(jī)構(gòu)

            手機(jī)站
            千鋒教育

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

            千鋒教育

            掃一掃進(jìn)入千鋒手機(jī)站

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

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

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

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

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

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

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

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

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

            第三步:寫(xiě)binlog

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

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

            而這些在內(nèi)存中的數(shù)據(jù)(臟頁(yè))會(huì)在一段時(shí)間后因?yàn)槟承┰虿艜?huì)被刷到磁盤(pán)中,那在這中間還沒(méi)有刷到磁盤(pán)的過(guò)程中,則有可能發(fā)生斷電,那還沒(méi)有保存到磁盤(pán)中的buffer pool中的數(shù)據(jù)也就丟了,而redo log的作用,就是斷電重啟之后,用來(lái)恢復(fù)這部分的數(shù)據(jù)。(在我看來(lái),redo log的作用僅此而已,有誤的話(huà)可以指正)

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

            回到問(wèn)題:change buffer是做什么的?

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

            第二個(gè)問(wèn)題:我沒(méi)太理解是什么意思,不過(guò)我上面一段的描述或許能夠解釋?zhuān)?/p>

            問(wèn):change buffer似乎只能作用于二級(jí)索引?

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

            延伸閱讀:

            二、為什么要持久化連接

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

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

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

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

            聲明:本站稿件版權(quán)均屬千鋒教育所有,未經(jīng)許可不得擅自轉(zhuǎn)載。
            10年以上業(yè)內(nèi)強(qiáng)師集結(jié),手把手帶你蛻變精英
            請(qǐng)您保持通訊暢通,專(zhuān)屬學(xué)習(xí)老師24小時(shí)內(nèi)將與您1V1溝通
            免費(fèi)領(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ù)庫(kù),利用什么軟件建立數(shù)據(jù)庫(kù)?

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

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

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

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

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

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

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

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

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

            2023-10-13 16:26:29
            快速通道