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

Mysql 數據庫緩存cache功能分析,調試以及性能總結

編輯:MySQL綜合教程

mysql cache 功能分析:

1 mysql 的 cache 功能的 key 的生成原理是:把 select 語句按照一定的 hash 規 則生成唯一的 key,select 的結果生成 value,即 key=>value。所以對於 cache 所以對於而言,語句是區分大小寫的,也區分空格的。兩個 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 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 大數據量快速插入方法和語句性能優化
  • 如何定位,排除和避免MySQL數據庫性能問題
  • Navicat for mysql 遠程連接 mySql數據庫提示10061,1045錯誤的解決辦法
  • 合理使用MySQL數據庫索引以使數據庫高效運行
  • 學會設置MySQL數據庫的五個常用參數
  • windows環境下mysql數據庫的主從同步備份步驟
  • 忘記PHPnow的MySQL數據庫密碼的解決辦法
  • 總結MySQL數據庫服務器逐漸變慢的原因和解決辦法

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