MySQL中的查詢緩存(Query Cache)可以大大提高查詢速度,從而改善 MySQL 服務器的響應時間。當 MySQL 接收到一個查詢請求時,它會首先查詢查詢緩存,如果查詢已經被緩存,MySQL就會直接返回緩存中的結果,否則才會執行查詢并將結果緩存。
對于查詢被緩存的情況,我們可以通過查詢計數器來查看。其中,Qcache_hits表示查詢被緩存的次數,Com_select表示執行 SELECT 查詢的次數。
mysql>SHOW STATUS LIKE 'Qcache%'; +-------------------------+--------+ | Variable_name | Value | +-------------------------+--------+ | Qcache_free_blocks | 356 | | Qcache_free_memory | 681728 | | Qcache_hits | 6238 | | Qcache_inserts | 2319 | | Qcache_lowmem_prunes | 0 | | Qcache_not_cached | 776 | | Qcache_queries_in_cache | 81 | | Qcache_total_blocks | 324 | +-------------------------+--------+
根據上面的查詢結果,我們可以看到 Qcache_hits 的值為 6238,表示查詢被緩存的次數。在這里,我們需要注意的是,雖然 Qcache_hits 越大表示緩存命中率越高,但也不應過于依賴查詢緩存,因為緩存命中率越高,緩存失效帶來的代價就越大。
因此,如果在業務環境中,你需要用到查詢緩存,建議合理配置緩存大小。此外,也應當避免使用使用不穩定的查詢語句或者保證業務數據的實時/近實時性,進而保證數據庫性能的平穩穩定。