MySQL資料庫快取

2021-07-22 06:25:17 字數 3400 閱讀 9608

原文:mysql 資料庫快取cache功能總結***

mysql cache功能分析:

1 mysql的cache功能的key的生成原理是:把select語句按照一定的hash規則生成唯一的key,select的結果生成value,即 key=>value。所以對於cache而言,select語句是區分大小寫的,也區分空格的。兩個select語句必須完完全 全一致,才能夠獲取到同乙個cache。

2 生成cache之後,只要該select中涉及到的table有任何的資料變動(insert,update,delete操作等),相 關的所有cache都會被刪除。因此只有資料很少變動的table,引入mysql 的cache才較有意義。關於這方面的測試,可以參考:《query cache,看上去很美》一文。

所以,mysql的cache功能只適用於下列場合:資料變動較少,select較多的table。

那麼。在複雜的系統中,如何使用mysql的cache功能呢,基本方法如下:

配置query_cache_type,同時改寫程式。

query_cache_type 0 代表不使用緩衝, 1 代表使用緩衝,2 代表根據需要使用。

設定 1 代表緩衝永遠有效,如果不需要緩衝,就需要使用如下語句:

select sql_no_cache * from my_table where …

如果設定為 2 ,需要開啟緩衝,可以用如下語句:

select sql_cache * from my_table where …

so,最簡單又可靠的做法是:把query_cache_type設定為2,然後在需要提高select速度的地方,使用:

select sql_cache * from…

的方式進行select。

【mysql cache除錯筆記】

1 可以使用下列命令開啟mysql的select cache功能:

set global query_cache_size = 102400000;

因為當query_cache_size預設為0時,是不開啟cache功能的。

2 除錯:

檢視cache的設定:

show variables like 『%query_cache%』;

效能監控:

show status like 『%qcache%』;

3 mysql cache的清理:

可以使用flush query cache語句來清理查詢快取碎片以提高記憶體使用效能。該語句不從快取中移出任何查詢。

reset query cache語句從查詢快取中移出所有查詢。flush tables語句也執行同樣的工作。

query cache

當你的資料庫開啟了query cache(簡稱qc)功能後,資料庫在執行select語句時,會將其結果放到qc中,當下一次處理同樣的select請求時,資料庫就會從qc取得結 果,而不需要去資料表中查詢。

在這個「cache為王」的時代,我們總是通過不同的方式去快取我們的結果從而提高響應效率,但乙個快取機制是否有效,效果如何,卻是乙個需要好好 思考的問題。在mysql中的query cache就是乙個適用較少情況的快取機制。在上圖中,如果快取命中率非常高的話,有測試表明在極端情況下可以提高效率238%[1]。 但實際情況如何?query cache有如下規則,如果資料表被更改,那麼和這個資料表相關的全部cache全部都會無效,並刪除之。這裡「資料表更改」包括:insert,update,delete,truncate,alter table,drop table, ordrop database等。舉 個例子,如果資料表posts訪問頻繁,那麼意味著它的很多資料會被qc快取起來,但是每一次posts資料表的更新,無論更新是不是影響到了cache 的資料,都會將全部和posts表相關的cache清除。如果你的資料表更新頻繁的話,那麼query cache將會成為系統的負擔。有實驗表明,糟糕時,qc會降低系統13%[1]的處理能力。

如果你的應用對資料庫的更新很少,那麼qc將會作用顯著。比較典型的如部落格系統,一般部落格更新相對較慢,資料表相對穩定不變,這時候qc的作用會比 較明顯。

再如,乙個更新頻繁的bbs系統。下面是乙個實際執行的論壇資料庫的狀態引數:

qcache_hit

5280438

qcache_insert

8008948

qcache_not_cache

95372

com select

8104159

可以看到,資料庫一共往qc中寫入了約800w次快取,但是實際命中的只有約500w次。也就是說,每乙個快取的使用率約為0.66次。很難說,該 快取的作用是否大於qc系統所帶來的開銷。但是有一點是很肯定的,qc快取的作用是很微小的,如果應用層能夠實現快取,將可以忽略qc的效果。

————-下面是關於qc的一些其他細節—————–

一、query cache相關引數:

二、query cache觀察:

create table t1(id int,var1 varchar(10));

//com_select:8 qcache_hits:1

insert into t1 values(1,』www』);

//com_select:8 qcache_hits:1

select * from t1 where id=1;

//com_select:9 qcache_hits:1

select * from t1 where id=1;

//com_select:9 qcache_hits:2 qcache_queries_in_cache:1

insert into t1 values(2,』rrrr』);

//com_select:9 qcache_hits:2 qcache_queries_in_cache:0

select * from t1 where id=1; //insert後cache失效

//com_select:10 qcache_hits:2 qcache_queries_in_cache:1

參考:

scofield

原文: query cache

mysql資料庫快取

開啟mysql查詢快取的方案 1.在my.cnf中新增如下配置並重啟,開啟mysql快取 query cache size 256m query cache limit 10m query cache type 1 query cache size為總快取大小,官方推薦不要超過256m query ...

Mysql 資料庫快取cache功能

mysql cache功能分析 1 mysql的cache功能的key的生成原理是 把select語句按照一定的hash規則生成唯一的key,select的結果生成value,即 key value。所以對於cache而言,select語句是區分大小寫的,也區分空格的。兩個select語句必須完完全...

MySQL資料庫中新增快取

mysql將快取分為buffer快取和cache快取。buffer快取。由於硬碟的寫入速度過慢,或者頻繁的i o,對於硬碟來說是極大的效率浪費。那麼可以等到快取中儲存一定量的資料之後,一次性的寫入到硬碟中。buffer 快取主要用於寫資料,提公升i o效能。cache 快取。cache 快取一般是一...