程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> MYSQL數據庫 >> MySQL綜合教程 >> MySQL cache功能匯總

MySQL cache功能匯總

編輯:MySQL綜合教程

以下的文章主要是對MySQL cache功能的描述,同時也對MySQL cache功能的分析,MySQL cache調試筆記與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。

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

配置query_cache_type,同時改寫程序。

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

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

  1. SELECT SQL_NO_CACHE * FROM my_table WHERE ... 

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

  1. SELECT SQL_CACHE * FROM my_table WHERE ... 

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

  1. SELECT SQL_CACHE * FROM... 

的方式進行SELECT。

MySQL cache調試筆記

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

  1. SET GLOBAL query_cache_size = 102400000; 

因為當query_cache_size默認為0時,是不開啟MySQL cache功能的。

2 調試:

查看cache的設置:

  1. show variables like '%query_cache%'; 

性能監控:

  1. show status like '%Qcache%'; 

MySQL cache的清理:

可以使用FLUSH QUERY CACHE語句來清理查詢緩存碎片以提高內存使用性能。該語句不從緩存中移出任何查詢。

RESET QUERY CACHE語句從查詢緩存中移出所有查詢。FLUSH TABLES語句也執行同樣的工作。

以上的相關內容就是對MySQL cache功能的介紹,望你能有所收獲。

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved