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)
個中各個參數的意義以下:
消除緩存
mysql的FLUSH句法(消除緩存)
FLUSH flush_option [,flush_option]
假如你想要消除一些MySQL應用外部緩存,你應當應用FLUSH敕令。為了履行FLUSH,你必需有reload權限。
flush_option可所以以下任何器械:
普通來說,Flush操作都邑記載在二進制日記文件中,然則FLUSH LOGS、FLUSH MASTER、FLUSH SLAVE、FLUSH TABLES WITH READ LOCK不會記載,是以上述操作假如記載在二進制日記文件中話,會對從數據庫形成影響。留意:Reset操作其實飾演的是一個Flush操作的加強版的腳色。