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語句也執行同樣的工作。
mysql cache除錯筆記
mysql cache除錯筆記 1 可以使用下列命令開啟mysql的select cache功能 set global query cache size 102400000 因為當query cache size預設為0時,是不開啟cache功能的。2 除錯 檢視cache的設定 show vari...
簡易搜尋功能小記
簡易搜尋功能小記 自從上個版本軟體中加入了列表的搜尋功能,現在是個列表的地方產品都要給提供搜尋。類似聯絡人 簡訊或者檔案等的集合資料,使用者輸入關鍵字,然後根據標題或者內容文字去匹配。搜尋功能第一步就是處理使用者輸入,然後發起搜尋。有兩種 類似網頁中常見的搜尋功能,在輸入關鍵字過程中會即時顯示對應的...
Mysql Cache配置使用 mysql快取配置
如果 mysql server 負載比較高,處理非常繁忙的話,可以啟動query cache 以加速響應時間,啟動方法可以在my.cnf linux 或my.ini windows 中加入不以下專案 redhat下面是 etc my.cnf debian和ubuntu是在 etc mysql my....