国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 數(shù)據(jù)庫 > MySQL > 正文

MySQL緩存的查詢和清除命令使用詳解

2024-07-24 13:08:27
字體:
供稿:網(wǎng)友
這篇文章主要介紹了MySQL緩存的查詢和清除命令使用詳解,對于一些不常改變數(shù)據(jù)且有大量相同sql查詢的表,查詢緩存會顯得比較有用一些,需要的朋友可以參考下
 

Mysql 查詢緩存 
查詢緩存的作用就是當查詢接收到一個和之前同樣的查詢,服務(wù)器將會從查詢緩存種檢索結(jié)果,而不是再次分析和執(zhí)行上次的查詢。這樣就大大提高了性能,節(jié)省時間。 
1.配置查詢緩存 
修改配置文件,修改[mysqld]下的query_cache_size和query_cache_type(如果沒有則添加)。其中query_cache_size表示緩存的大小,而query_cache_type有3個值,表示緩存那種類  型的select結(jié)果集,query_cache_type各個值如下: 
0或off關(guān)閉緩存 
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服務(wù)器即可。 

query_cache_size=10M query_cache_type=1 

可以用如下命令查看是否開啟,其中have_query_cache為是否開啟,query_cache_limit 指定單個查詢能夠使用的緩沖區(qū)大小,缺省為1M;query_cache_min_res_unit為系統(tǒng)分配的最小緩存塊大小,默認是4KB,設(shè)置值大對大數(shù)據(jù)查詢有好處,但如果你的查詢都是小數(shù)據(jù) 查詢,就容易造成內(nèi)存碎片和浪費;query_cache_size和query_cache_type就是上面我們的配置;query_cache_wlock_invalidate表示當有其他客戶端正在對MyISAM表進行寫操作時,如果查詢在query cache中,是否返回cache結(jié)果還是等寫操作完成再讀表獲取結(jié)果。 

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.測試 
我們先執(zhí)行一次,select  count(*) from wei ;然后再執(zhí)行一次,可以看出第二次用的時間遠遠低于第一次的執(zhí)行,因為第二次從緩存中讀取了select結(jié)果。 

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) 

我們可以通過如下命令查看現(xiàn)在緩存的情況 

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) 

其中各個參數(shù)的意義如下:

  • Qcache_free_blocks:緩存中相鄰內(nèi)存塊的個數(shù)。數(shù)目大說明可能有碎片。FLUSH QUERY CACHE會對緩存中的碎片進行整理,從而得到一個空閑塊。
  • Qcache_free_memory:緩存中的空閑內(nèi)存。
  • Qcache_hits:每次查詢在緩存中命中時就增大
  • Qcache_inserts:每次插入一個查詢時就增大。命中次數(shù)除以插入次數(shù)就是不中比率。
  • Qcache_lowmem_prunes:緩存出現(xiàn)內(nèi)存不足并且必須要進行清理以便為更多查詢提供空間的次數(shù)。這個數(shù)字最好長時間來看;如果這個 數(shù)字在不斷增長,就表示可能碎片非常嚴重,或者內(nèi)存很少。(上面的 free_blocks和free_memory可以告訴您屬于哪種情況)
  • Qcache_not_cached:不適合進行緩存的查詢的數(shù)量,通常是由于這些查詢不是 SELECT 語句或者用了now()之類的函數(shù)。
  • Qcache_queries_in_cache:當前緩存的查詢(和響應(yīng))的數(shù)量。
  • Qcache_total_blocks:緩存中塊的數(shù)量。


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

FLUSH flush_option [,flush_option]

如果你想要清除一些MySQL使用內(nèi)部緩存,你應(yīng)該使用FLUSH命令。為了執(zhí)行FLUSH,你必須有reload權(quán)限。
flush_option可以是下列任何東西:

  • HOSTS       這個用的最多,經(jīng)常碰見。主要是用來清空主機緩存表。如果你的某些主機改變IP數(shù)字,或如果你得到錯誤消息Host ... isblocked,你應(yīng)該清空主機表。當在連接MySQL服務(wù)器時,對一臺給定的主機有多于 max_connect_errors個錯誤連續(xù)不斷地發(fā)生,MySQL為了安全的需要將會阻止該主機進一步的連接請求。清空主機表允許主機再嘗試連接。
  • LOGS        關(guān)閉當前的二進制日志文件并創(chuàng)建一個新文件,新的二進制日志文件的名字在當前的二進制文件的編號上加1。
  • PRIVILEGES  這個也是經(jīng)常使用的,每當重新賦權(quán)后,為了以防萬一,讓新權(quán)限立即生效,一般都執(zhí)行一把,目地是從數(shù)據(jù)庫授權(quán)表中重新裝載權(quán)限到緩存中。
  • TABLES       關(guān)閉所有打開的表,同時該操作將會清空查詢緩存中的內(nèi)容。
  • FLUSH TABLES WITH READ LOCK   關(guān)閉所有打開的表,同時對于所有數(shù)據(jù)庫中的表都加一個讀鎖,直到顯示地執(zhí)行unlock tables,該操作常常用于數(shù)據(jù)備份的時候。
  • STATUS       重置大多數(shù)狀態(tài)變量到0。
  • MASTER        刪除所有的二進制日志索引文件中的二進制日志文件,重置二進制日志文件的索引文件為空,創(chuàng)建一個新的二進制日志文件,不過這個已經(jīng)不推薦使用,改成reset master 了??梢韵胂螅郧白约菏嵌嗤涟?,本來一條簡單的命令就可以搞定的,卻要好幾條命令來,以前的做法是先查出來當前的二進制日志文件名,再用purge 操作。
  • QUERY CACHE   重整查詢緩存,消除其中的碎片,提高性能,但是并不影響查詢緩存中現(xiàn)有的數(shù)據(jù),這點和Flush table 和Reset Query  Cache(將會清空查詢緩存的內(nèi)容)不一樣的。
  • SLAVE        類似于重置復(fù)制吧,讓從數(shù)據(jù)庫忘記主數(shù)據(jù)庫的復(fù)制位置,同時也會刪除已經(jīng)下載下來的relay log,與Master一樣,已經(jīng)不推薦使用,改成Reset Slave了。這個也很有用的。

  一般來講,F(xiàn)lush操作都會記錄在二進制日志文件中,但是FLUSH LOGS、FLUSH MASTER、FLUSH SLAVE、FLUSH TABLES WITH READ LOCK不會記錄,因此上述操作如果記錄在二進制日志文件中話,會對從數(shù)據(jù)庫造成影響。注意:Reset操作其實扮演的是一個Flush操作的增強版的角色。



注:相關(guān)教程知識閱讀請移步到MYSQL教程頻道。
發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 富民县| 湛江市| 江永县| 运城市| 广灵县| 大荔县| 普格县| 连江县| 萝北县| 乳源| 英吉沙县| 济阳县| 桑日县| 石嘴山市| 高唐县| 永寿县| 高雄县| 化德县| 双城市| 镇江市| 丰县| 略阳县| 建瓯市| 芦山县| 阿拉尔市| 大关县| 吉林省| 连州市| 黄大仙区| 富平县| 格尔木市| 安吉县| 英德市| 恩施市| 西昌市| 泰来县| 南京市| 玉环县| 沈丘县| 循化| 五常市|