程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> MYSQL數據庫 >> MySQL綜合教程 >> MySQL緩存的查詢和消除敕令應用詳解

MySQL緩存的查詢和消除敕令應用詳解

編輯:MySQL綜合教程

MySQL緩存的查詢和消除敕令應用詳解。本站提示廣大學習愛好者:(MySQL緩存的查詢和消除敕令應用詳解)文章只能為提供參考,不一定能成為您想要的結果。以下是MySQL緩存的查詢和消除敕令應用詳解正文


Mysql 查詢緩存
查詢緩存的感化就是當查詢吸收到一個和之前異樣的查詢,辦事器將會從查詢緩存種檢索成果,而不是再次剖析和履行前次的查詢。如許就年夜年夜進步了機能,節儉時光。
1.設置裝備擺設查詢緩存
修正設置裝備擺設文件,修正[mysqld]下的query_cache_size和query_cache_type(假如沒有則添加)。個中query_cache_size表現緩存的年夜小,而query_cache_type有3個值,表現緩存那品種  型的select成果集,query_cache_type各個值以下:
0或off封閉緩存
1或on開啟緩存,然則不保留應用sql_no_cache的select語句,如不緩存select  sql_no_cache name from wei where id=2
2或demand開啟有前提緩存,只緩存帶sql_cache的select語句,緩存select  sql_cache name from wei where id=4
例子的設置裝備擺設為下,設置裝備擺設完成重啟Mysql辦事器便可。

query_cache_size=10M 
query_cache_type=1 

可以用以下敕令檢查能否開啟,個中have_query_cache為能否開啟,query_cache_limit 指訂單個查詢可以或許應用的緩沖區年夜小,缺省為1M;query_cache_min_res_unit為體系分派的最小緩存塊年夜小,默許是4KB,設置值年夜對年夜數據查詢有利益,但假如你的查詢都是小數據 查詢,就輕易形成內存碎片和糟蹋;query_cache_size和query_cache_type就是下面我們的設置裝備擺設;query_cache_wlock_invalidate表現當有其他客戶正直在對MyISAM表停止寫操作時,假如查詢在query cache中,能否前往cache成果照樣等寫操作完成再讀表獲得成果。

mysql> show variables like '%query_cache%'; 
+------------------------------+----------+ 
| Variable_name        | Value  | 
+------------------------------+----------+ 
| have_query_cache       | YES   | 
| query_cache_limit      | 1048576 | 
| query_cache_min_res_unit   | 4096   | 
| query_cache_size       | 10485760 | 
| query_cache_type       | ON    | 
| query_cache_wlock_invalidate | OFF   | 
+------------------------------+----------+ 
6 rows in set (0.00 sec) 

2.測試
我們先履行一次,select  count(*) from wei ;然後再履行一次,可以看出第二次用的時光遠遠低於第一次的履行,由於第二次從緩存中讀取了select成果。

mysql> select count(*) from wei ; 
+----------+ 
| count(*) | 
+----------+ 
| 4194304 | 
+----------+ 
1 row in set (3.92 sec) 
 
mysql> select count(*) from wei ; 
+----------+ 
| count(*) | 
+----------+ 
| 4194304 | 
+----------+ 
1 row in set (0.00 sec) 

我們可以經由過程以下敕令檢查如今緩存的情形

mysql> show status like 'qcache%'; 
+-------------------------+----------+ 
| Variable_name      | Value  | 
+-------------------------+----------+ 
| Qcache_free_blocks   | 1    | 
| Qcache_free_memory   | 10475424 | 
| Qcache_hits       | 1    | 
| Qcache_inserts     | 1    | 
| Qcache_lowmem_prunes  | 0    | 
| Qcache_not_cached    | 0    | 
| Qcache_queries_in_cache | 1    | 
| Qcache_total_blocks   | 4    | 
+-------------------------+----------+ 
8 rows in set (0.00 sec) 

個中各個參數的意義以下:

  • Qcache_free_blocks:緩存中相鄰內存塊的個數。數量年夜解釋能夠有碎片。FLUSH QUERY CACHE會對緩存中的碎片停止整頓,從而獲得一個余暇塊。
  • Qcache_free_memory:緩存中的余暇內存。
  • Qcache_hits:每次查詢在緩存中射中時就增年夜
  • Qcache_inserts:每次拔出一個查詢時就增年夜。射中次數除以拔出次數就是不中比率。
  • Qcache_lowmem_prunes:緩存湧現內存缺乏而且必需要停止清算以便為更多查詢供給空間的次數。這個數字最好長時光來看;假如這個 數字在赓續增加,就表現能夠碎片異常嚴重,或許內存很少。(下面的 free_blocks和free_memory可以告知您屬於哪一種情形)
  • Qcache_not_cached:不合適停止緩存的查詢的數目,平日是因為這些查詢不是 SELECT 語句或許用了now()之類的函數。
  • Qcache_queries_in_cache:以後緩存的查詢(和呼應)的數目。
  • Qcache_total_blocks:緩存中塊的數目。


消除緩存
mysql的FLUSH句法(消除緩存)

FLUSH flush_option [,flush_option]

假如你想要消除一些MySQL應用外部緩存,你應當應用FLUSH敕令。為了履行FLUSH,你必需有reload權限。
flush_option可所以以下任何器械:

  • HOSTS       這個用的最多,常常碰見。重要是用來清空主機緩存表。假如你的某些主機轉變IP數字,或假如你獲得毛病新聞Host ... isblocked,你應當清空主機表。當在銜接MySQL辦事器時,對一台給定的主機有多於 max_connect_errors個毛病持續赓續地產生,MySQL為了平安的須要將會阻攔該主機進一步的銜接要求。清空主機表許可主機再測驗考試銜接。
  • LOGS        封閉以後的二進制日記文件並創立一個新文件,新的二進制日記文件的名字在以後的二進制文件的編號上加1。
  • PRIVILEGES  這個也是常常應用的,每當從新賦權後,為了以防萬一,讓新權限立刻失效,普通都履行一把,目地是從數據庫受權表中從新裝載權限到緩存中。
  • TABLES       封閉一切翻開的表,同時該操作將會清空查詢緩存中的內容。
  • FLUSH TABLES WITH READ LOCK   封閉一切翻開的表,同時關於一切數據庫中的表都加一個讀鎖,直到顯示地履行unlock tables,該操作經常用於數據備份的時刻。
  • STATUS       重置年夜多半狀況變量到0。
  • MASTER        刪除一切的二進制日記索引文件中的二進制日記文件,重置二進制日記文件的索引文件為空,創立一個新的二進制日記文件,不外這個曾經不推舉應用,改成reset master 了。可以想象,之前本身是多土啊,原來一條簡略的敕令便可以弄定的,卻要好幾條敕令來,之前的做法是先查出來以後的二進制日記文件名,再用purge 操作。
  • QUERY CACHE   重整查詢緩存,清除個中的碎片,進步機能,然則其實不影響查詢緩存中現有的數據,這點和Flush table 和Reset Query  Cache(將會清空查詢緩存的內容)紛歧樣的。
  • SLAVE        相似於重置復制吧,讓從數據庫忘卻主數據庫的復制地位,同時也會刪除曾經下載上去的relay log,與Master一樣,曾經不推舉應用,改成Reset Slave了。這個也很有效的。

  普通來說,Flush操作都邑記載在二進制日記文件中,然則FLUSH LOGS、FLUSH MASTER、FLUSH SLAVE、FLUSH TABLES WITH READ LOCK不會記載,是以上述操作假如記載在二進制日記文件中話,會對從數據庫形成影響。留意:Reset操作其實飾演的是一個Flush操作的加強版的腳色。

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