日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

詳解MySQL InnoDB存儲引擎的內存管理

瀏覽:808日期:2023-10-03 19:26:14
存儲引擎之內存管理

在InnoDB存儲引擎中,數據庫中的緩沖池是通過LRU(Latest Recent Used,最近最少使用)算法來進行管理的,即最頻繁使用的頁在LRU列表的最前段,而最少使用的頁在LRU列表的尾端,當緩沖池不能存放新讀取到的頁時,首先釋放LRU列表尾端的頁。

詳解MySQL InnoDB存儲引擎的內存管理

上面的圖中,我使用8個數據頁來表示隊列,具體作用,先賣個關子。在InnoDB存儲引擎中,緩沖池中頁的默認大小是16KB,LRU列表中有一個midpoint的位置,新讀取到的數據頁并不是直接放入到LRU列表的首部,而是放入到LRU列表的midpoint位置,這個操作稱之為midpoint insertion stategy,也叫中間點插入策略。在默認配置下,該位置在LRU長度的5/8處,這也就是上面使用8個數據頁的作用。下面的圖示意了新的數據頁的插入過程:

詳解MySQL InnoDB存儲引擎的內存管理

mitpoint的位置可通過參數innodb_old_blocks_pct控制,如下:

mysql> show variables like ’innodb_old_blocks_pct’;+-----------------------+-------+| Variable_name | Value |+-----------------------+-------+| innodb_old_blocks_pct | 37 |+-----------------------+-------+ row in set (. sec)

從上面的例子看出,結果是37,這個37意味著新讀取的頁將被插入到大概距離LRU列表尾端37%的位置,差不多3/8的位置,在InnoDB存儲引擎中,midpoint之前的頁稱為new列表,后面的頁稱之為old列表,new列表中的頁是最為活躍的數據。

為什么不直接把數據頁放在LRU隊列的首部?

之所以不把新讀取的數據頁放在LRU隊列的首部,是因為某些全表掃描的SQL操作可能會將所有的熱點數據都刷新出LRU隊列,導致下一次訪問熱點數據的時候,必須從磁盤中取相應的數據,從而影響緩沖池的效率。為了解決這個問題,InnoDB使用另外一個參數來管理LRU列表,就是innodb_old_blocks_time,用于表示頁讀取到midpoint之后,多久才會加入到LRU列表的熱端。因此當需要執行上述所說的SQL操作時,可以通過下面的方法盡可能使LRU列表中的熱點數據不被刷出。

mysql> set global innodb_old_blocks_time=;Query OK, rows affected (0.00 sec)

這表示在1000s之后,才允許這些數據刷新到LRU列表的熱端。

如果在實際情況中,數據頁活躍的比率不止63%,用戶還可以通過設置innodb_old_blocks_pct來減少熱點頁可能被刷出的概率。

mysql> set global innodb_old_blocks_pct=; Query OK, rows affected (0.00 sec)

當數據庫剛啟動時,LRU的內容是空的,這個時候,所有的數據頁都放在Free列表中,當需要從緩沖池中分頁時,首先從Free列表中查找是否有可用的Free頁,如果存在,則將該頁從Free頁中刪除,然后放入到LRU的列表中。淘汰掉LRU列表末尾的數據頁,將該內存空間分配給新的頁。這個過程的流程圖如下:

詳解MySQL InnoDB存儲引擎的內存管理

當LRU列表中的頁從old部分加入到new部分時,稱此時發生的操作是page made young,而因為innodb_old_blocks_time的設置而沒有從old部分移動到new部分的操作稱之為page_not_made young。可以通過show engine innodb status來觀察LRU列表以及Free列表的使用情況和運行狀態。

mysql> show engine innodb statusG******----------------------BUFFER POOL AND MEMORY----------------------Total large memory allocated Dictionary memory allocated Buffer pool size Free buffers Database pages Old database pages Modified db pages Pending reads Pending writes: LRU , flush list , single page Pages made young , not young 0.00 youngs/s, 0.00 non-youngs/sPages read , created , written 0.00 reads/s, 0.00 creates/s, 0.00 writes/sNo buffer pool page gets since the last printoutPages read ahead 0.00/s, evicted without access 0.00/s, Random read ahead 0.00/sLRU len: , unzip_LRU len: I/O sum[]:cur[], unzip sum[]:cur[]--------------ROW OPERATIONS-------------- queries inside InnoDB, queries in queue read views open inside InnoDBProcess ID=, Main thread ID=, state: sleepingNumber of rows inserted , updated , deleted , read 0.00 inserts/s, 0.00 updates/s, 0.00 deletes/s, 0.00 reads/s----------------------------END OF INNODB MONITOR OUTPUT============================ row in set (0.00 sec)

從上面的結果可以看到:當前buffer pool size總共有8191個頁,每個數據頁的大小是16k,總共的大小是8191*16k=128M的緩沖池,其中Free buffers表示當前Free列表中頁的數量。page made young顯示了LRU列表中頁移動到前端的次數,因為該服務器在運行階段沒有改變innodb_old_blocks_time的值,因此not young為0,youngs/s、non_youngs/s表示每秒這兩類操作的次數。

InnoDB存儲引擎從1.0.x版本開始支持壓縮頁的功能,即將原本16kb的數據頁壓縮成1KB、2KB、4KB和8KB。對于非16KB的頁,是通過unzip_LRU來管理的,上述命令中的第22行就顯示了壓縮頁和非壓縮頁的信息。

需要注意的一點是Free buffers的值與Database Pages的值之和不一定等于buffer pool size,因為緩沖池中的頁可能還會被分配各自適應哈希索引、鎖信息等頁,而這部分頁并不需要LRU算法進行維護。

臟頁

在LRU列表中的頁被修改之后,這個頁就稱之為“臟頁”,即緩沖池中的數據頁和磁盤上的數據產生了不一致,緩沖池的數據比較新,這時數據庫會通過checkpoint機制將臟頁刷新回磁盤,而Flush列表中的頁也就是臟頁列表,臟頁既存在于LRU列表中,也存在與Flush列表中,LRU列表用來管理緩沖池中頁的可用性,Flush列表用來管理將頁刷新回磁盤,二者不影響。Flush列表也可以通過show engine innodb status來查看,前面的結果列表中的第13行,modified db pages就是當前的臟頁數量,用戶可以通過元數據表INNODB_BUFFER_PAGE_LRU表來查看。

以上就是詳解MySQL InnoDB存儲引擎的內存管理的詳細內容,更多關于InnoDB 內存管理的資料請關注好吧啦網其它相關文章!

標簽: MySQL 數據庫
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
日韩激情综合| 精品少妇一区| 久久av资源| 国产亚洲在线观看| 樱桃成人精品视频在线播放| 一本大道色婷婷在线| 热三久草你在线| 精品视频亚洲| 国产色播av在线| 91精品韩国| 成人精品视频| 模特精品在线| 蜜桃久久久久久| 国际精品欧美精品| 最新国产精品久久久| 日本免费久久| 欧美日韩99| 爽好多水快深点欧美视频| 久久精品国产亚洲一区二区三区| 激情欧美一区二区三区| 精品一区二区三区四区五区| 免费看欧美美女黄的网站| 亚洲精品在线二区| 欧美一级一区| 中文一区一区三区高中清不卡免费| 国产综合色区在线观看| 水蜜桃久久夜色精品一区的特点| 日韩久久99| 蜜桃精品在线| 日本h片久久| 在线亚洲人成| 在线免费观看亚洲| 国产精品一页| 肉色欧美久久久久久久免费看| 国产国产精品| 美女视频免费精品| 亚洲精品1区2区| 国产精品3区| 久久天堂成人| 狂野欧美性猛交xxxx| 亚洲精品88| 视频一区中文字幕精品 | 在线亚洲免费| 日韩成人精品一区二区三区| 成人亚洲精品| 日本精品久久| 亚洲特色特黄| 欧美在线黄色| 亚洲一区二区三区高清| 国产成人精品福利| 婷婷亚洲精品| 在线日韩视频| 成人台湾亚洲精品一区二区| 亚洲人成亚洲精品| 久久久777| 国产一区国产二区国产三区| 亚洲一区二区小说| 久久精品国产大片免费观看| 国产精品九九| 乱一区二区av| 国产不卡人人| 日韩国产一区二区| 精品视频一区二区三区四区五区 | 成人午夜亚洲| 久久精品国产在热久久| 精品一区二区三区在线观看视频| 国产在视频一区二区三区吞精| 精品九九在线| 黄毛片在线观看| 成人精品天堂一区二区三区| 欧美日韩一区自拍| 另类综合日韩欧美亚洲| 久久久国产精品网站| 久久精品三级| 日韩免费一区| 久久精品国产亚洲夜色av网站| 1024精品久久久久久久久| 亚洲精品一区二区在线看| 视频一区免费在线观看| 青青草91久久久久久久久| 日韩在线网址| 国产韩日影视精品| 蜜臀国产一区二区三区在线播放| 亚洲欧美视频一区二区三区| 美美哒免费高清在线观看视频一区二区| 亚洲人成毛片在线播放女女| 日韩av三区| 国产精品欧美大片| 九九精品调教| 国产精品外国| 久久午夜影院| 日韩天堂av| 精品黄色一级片| 日本一区二区三区中文字幕| 国产一区二区三区四区五区传媒| 欧美精品一区二区三区精品| 欧美日本久久| 亚洲欧美日韩精品一区二区| 国产精品久一| 模特精品在线| 综合亚洲视频| 久久蜜桃资源一区二区老牛| 中文字幕亚洲精品乱码| 日本不卡的三区四区五区| 日韩国产欧美| 美女毛片一区二区三区四区最新中文字幕亚洲 | 久久国产精品免费精品3p| 视频一区欧美日韩| 亚洲欧美日本视频在线观看| 亚洲在线成人| 日本不卡高清| 久久99蜜桃| av免费不卡国产观看| 成人福利视频| 99精品视频精品精品视频| 亚洲免费网址| 国产日韩高清一区二区三区在线 | 激情综合五月| 日韩精品三级| 免费观看在线综合色| 好看的av在线不卡观看| 久久久精品久久久久久96| 日韩av免费大片| 国产不卡av一区二区| 午夜亚洲福利| 91嫩草精品| 国产欧美一区二区色老头| 国产精品三p一区二区| 欧美亚洲综合视频| 久久av综合| 色综合五月天| 成人av三级| 91精品一区国产高清在线gif | 久久精品导航| 亚洲综合电影| 亚洲激情久久| 日韩中文字幕1| 久久亚洲国产精品一区二区| 美日韩精品视频| 日本一区中文字幕| 国产精品久一| 中文一区二区| 国产欧美欧美| 久久久精品日韩| 国产视频亚洲| 国产精品一区免费在线| а√天堂中文在线资源8| 女同性一区二区三区人了人一 | 动漫av一区| 亚洲午夜精品久久久久久app| 美日韩精品视频| 欧美亚洲人成在线| 久久国产精品亚洲77777| 国产一区二区精品| 国产欧美日韩在线观看视频| 四季av一区二区凹凸精品| 亚洲少妇在线| 欧美国产三级| 美女网站一区| 另类综合日韩欧美亚洲| 玖玖玖国产精品| 中文字幕在线看片| 日韩欧美三区| 欧美jjzz| 日韩伦理在线一区| 国产精品视频一区二区三区| 久久国产日韩| 久久99青青| 婷婷精品在线| 久久婷婷久久| 精品深夜福利视频| 国产精品最新自拍| 日韩精品一级| 亚洲一区二区免费看| 成人国产精品一区二区免费麻豆| 亚洲影院天堂中文av色| 婷婷综合亚洲| 国产亚洲精品美女久久| 蜜臀av一区二区在线免费观看| 亚洲a一区二区三区| 风间由美中文字幕在线看视频国产欧美 | 亚洲一级在线| 精品视频免费| 国产精品亚洲成在人线| 亚洲免费福利一区| 丝袜美腿亚洲色图| 亚洲天堂黄色| 91精品综合| 久久网站免费观看| 久久高清免费| 天堂av在线| 日韩欧美综合| 欧美日韩一区二区综合| 黄色在线观看www| 欧美黑人做爰爽爽爽| 国产精品99久久免费| 久久精品国产久精国产| 日韩综合一区| 国产欧美一区二区三区精品酒店| 久久99精品久久久久久园产越南 |