MySQL cache功能匯總
以下的文章主要是對MySQL cache功能的描述,同時也對MySQL cache功能的分析,MySQL cache調(diào)試筆記與MySQL cache的清理的一些內(nèi)容的描述,以下就是文章的詳細(xì)內(nèi)容描述,望你會有所收獲。
MySQL cache功能分析:
1 MySQL的cache功能的key的生成原理是:把select語句按照一定的hash規(guī)則生成***的key,select的結(jié)果生成value,即key=>value。所以對于cache而言,select語句是區(qū)分大小寫的,也區(qū)分空格的。兩個select語句必須完完全全一致,才能夠獲取到同一個cache。
2 生成cache之后,只要該select中涉及到的table有任何的數(shù)據(jù)變動(insert,update,delete操作等),相關(guān)的所有cache都會被刪除。因此只有數(shù)據(jù)很少變動的table,引入MySQL 的cache才較有意義。關(guān)于這方面的測試,可以參考:《Query Cache,看上去很美》一文。
所以,MySQL的cache功能只適用于下列場合:數(shù)據(jù)變動較少,select較多的table。
那么。在復(fù)雜的系統(tǒng)中,如何使用MySQLcache功能呢,基本方法如下:
配置query_cache_type,同時改寫程序。
query_cache_type 0 代表不使用緩沖, 1 代表使用緩沖,2 代表根據(jù)需要使用。
設(shè)置 1 代表緩沖永遠(yuǎn)有效,如果不需要緩沖,就需要使用如下語句:
- SELECT SQL_NO_CACHE * FROM my_table WHERE ...
如果設(shè)置為 2 ,需要開啟緩沖,可以用如下語句:
- SELECT SQL_CACHE * FROM my_table WHERE ...
So,最簡單又可靠的做法是:把query_cache_type設(shè)置為2,然后在需要提高select速度的地方,使用:
- SELECT SQL_CACHE * FROM...
的方式進(jìn)行SELECT。
MySQL cache調(diào)試筆記
1 可以使用下列命令開啟MySQL的select cache功能:
- SET GLOBAL query_cache_size = 102400000;
因為當(dāng)query_cache_size默認(rèn)為0時,是不開啟MySQL cache功能的。
2 調(diào)試:
查看cache的設(shè)置:
- show variables like '%query_cache%';
性能監(jiān)控:
- show status like '%Qcache%';
MySQL cache的清理:
可以使用FLUSH QUERY CACHE語句來清理查詢緩存碎片以提高內(nèi)存使用性能。該語句不從緩存中移出任何查詢。
RESET QUERY CACHE語句從查詢緩存中移出所有查詢。FLUSH TABLES語句也執(zhí)行同樣的工作。
以上的相關(guān)內(nèi)容就是對MySQL cache功能的介紹,望你能有所收獲。
【編輯推薦】
- 安裝MySQL-python的實際操作步驟
- PHP和MySQL存儲過程的實例演示
- 解決MySQL無法遠(yuǎn)程訪問的3方案
- MySQL 常用語句的基本用法的介紹
- MySQL數(shù)據(jù)庫文件其具體的存放位置簡述