MySQL中的置換是一種優化技術,可以在數據緩存不足時提高查詢效率。當MySQL需要從磁盤讀取數據時,會先將數據從磁盤讀入到緩存(即內存)中,這個過程稱為緩存淘汰。當緩存已滿且需要緩存新數據時,需要淘汰掉一些舊的數據,讓出空間。這時就需要選擇一種置換策略。
/* 以下是 LRU 置換策略的實現 */ SET GLOBAL innodb_old_blocks_pct = 60; /* 表示 LRU 列表快滿時開始淘汰數據 */ SET GLOBAL innodb_old_blocks_time = 1000; /* 表示 LRU 列表中一個數據塊最多可以存活多長時間(單位:毫秒) */
常見的置換策略有:
- 最近最少使用(LRU)
- 先進先出(FIFO)
- 隨機(Random)
LRU置換策略會淘汰最長時間未被使用的數據塊,即根據數據塊的訪問時間來決定淘汰順序。FIFO置換策略則是按照進入緩存的時間先后來淘汰數據塊。隨機置換策略則是隨機選擇一個數據塊來淘汰。
/* 以下是 FIFO 置換策略的實現 */ SET GLOBAL innodb_old_blocks_pct = 60; /* 表示 FIFO 列表快滿時開始淘汰數據 */ SET GLOBAL innodb_old_blocks_time = 0; /* 表示 FIFO 列表中的數據塊可以存活任意長的時間 */
MySQL默認采用的是LRU置換策略,但在某些情況下FIFO策略也可以表現得更好。另外,對于大部分場景下,隨機策略效果較差,不建議使用。
上一篇微信小程序css顯示邊框
下一篇css輸入框邊角