Mysql 資料庫快取cache功能

2021-05-23 21:12:31 字數 1385 閱讀 4904

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語句也執行同樣的工作。

Cache快取(資料庫鏈結池)

當同樣一段資料,很多人要訪問時,以前我總是不斷的從資料庫裡面讀出來到dataset中,然後慢慢的處理,但是每乙個使用者的訪問資料,都要進行同樣的步驟,感覺機子承受不了啊 找了幾種方法,顯示用cookies技術,發現不安全啊,於是使用session變數來盛放資料,伺服器變數,安全沒有話說的,接下來發現...

MySQL資料庫快取

原文 mysql 資料庫快取cache功能總結 mysql cache功能分析 1 mysql的cache功能的key的生成原理是 把select語句按照一定的hash規則生成唯一的key,select的結果生成value,即 key value。所以對於cache而言,select語句是區分大小寫...

mysql資料庫快取

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