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語句也執行同樣的工作。轉自:http://tech.e800.com.cn/articles/2009/1013/1255397010152_1.Html 幾個命令:
mysql> show status like 'Qcache%'; #查看MySQL查詢緩存的運行時狀態
mysql> reset query cache; #重置MySQL查詢緩存
MySQL> flush query cache #清理查詢緩存碎片在my.ini 下面 添加 query_cache_size = 268435456
query_cache_type = 1
query_cache_limit = 1048576 以上語句的設置中 query_cache_size 是分配256M內存給Query Cache;query_cache_type=1,是給所有的查詢做Cache;query_cache_limit 是指定個別的查詢語句1MB的內存。這些數據可以根據自己的需求作出適當的更改,設置完成之後,保存文檔,重新啟動MySQL即可。