摘要:性能未必所有場合總是會改善性能當有大量的查詢和大量的修改時,機制可能會造成性能下降。緩存機制的內存使用使用內存池技術,自己管理內存釋放和分配,而不是通過操作系統。內存池使用的基本單位是變長的一個的通過鏈表把這些串起來。
轉自:https://www.cnblogs.com/lpfut...
介紹mysql Query Cache 默認為打開。從某種程度可以提高查詢的效果,但是未必是最優的解決方案,如果有的大量的修改和查詢時,由于修改造的cache失效,會給服務器造成很大的開銷,可以通過query_cache_type【0(OFF)1(ON)2(DEMAND)】來控制緩存的開關.
需要注意的是mysql query cache 是對大小寫敏感的,因為Query Cache 在內存中是以 HASH 結構來進行映射,HASH 算法基礎就是組成 SQL 語句的字符,所以 任何sql語句的改變重新cache,這也是項目開發中要建立sql語句書寫規范的原因吧
何時cachemysql query cache內容為 select 的結果集, cache 使用完整的 sql 字符串做 key, 并區分大小寫,空格等。即兩個sql必須完全一致才會導致cache命中。
prepared statement永遠不會cache到結果,即使參數完全一樣。在 5.1 之后會得到改善。
where條件中如包含了某些函數永遠不會被cache, 比如current_date, now等。
date 之類的函數如果返回是以小時或天級別的,最好先算出來再傳進去。
select * from foo where date1=current_date -- 不會被 cache select * from foo where date1="2008-12-30" -- 被cache, 正確的做法
太大的result set不會被cache (< query_cache_limit)
何時更新一旦表數據進行任何一行的修改,基于該表相關cache立即全部失效。
為什么不做聰明一點判斷修改的是否cache的內容?因為分析cache內容太復雜,服務器需要追求最大的性能。
性能
ache 未必所有場合總是會改善性能
當有大量的查詢和大量的修改時,cache機制可能會造成性能下降。因為每次修改會導致系統去做cache失效操作,造成不小開銷。
另外系統cache的訪問由一個單一的全局鎖來控制,這時候大量>的查詢將被阻塞,直至鎖釋放。所以不要簡單認為設置cache必定會帶來性能提升。
大result set不會被cache的開銷
太大的result set不會被cache, 但mysql預先不知道result set的長度,所以只能等到reset set在cache添加到臨界值 query_cache_limit 之后才會簡單的把這個cache 丟棄。這并不是一個高效的操作。如果mysql status中Qcache_not_cached太大的話, 則可對潛在的大結果集的sql顯式添加 SQL_NO_CACHE 的控制。
query_cache_min_res_unit = (query_cache_size – Qcache_free_memory) / Qcache_queries_in_cache
緩存機制的內存使用mysql query cache 使用內存池技術,自己管理內存釋放和分配,而不是通過操作系統。內存池使用的基本單位是變長的block, 一個result set的cache通過鏈表把這些block串起來。因為存放result set的時候并不知道這個resultset最終有多大。block最短長度為query_cache_min_res_unit, resultset 的最后一個block會執行trim操作。
使用步驟
修改配置文件,設置query_cache_type和query_cache _size,以及query_cache_min_res_unit(可以采用默認值)
query_cache_type 0 代表不使用緩沖, 1 代表使用緩沖,2 代表根據需要使用。
如果query_cache_type=1,如果不需要緩沖,則query如下
SELECT SQL_NO_CACHE * FROM my_table WHERE ...
如果query_cache_type=2,如果需要緩沖,則query如下
SELECT SQL_CACHE * FROM my_table WHERE ...總結
Query Cache 在提高數據庫性能方面具有非常重要的作用。
其設定也非常簡單,僅需要在配置文件寫入兩行: query_cache_type 和 query_cache _size,而且 MySQL 的 query cache 非常快!而且一旦命中,就直接發送給客戶端,節約大量的 CPU 時間。
當然,非 SELECT 語句對緩沖是有影響的,它們可能使緩沖中的數據過期。一個 UPDATE 語句引起的部分表修改,將導致對該表所有的緩沖數據失效,這是 MySQL 為了平衡性能而沒有采取的措施。因為,如果每次 UPDATE 需要檢查修改的數據,然后撤出部分緩沖將導致代碼的復雜度增加。
使用場景
寫操作少于讀操作;數據實時性要求較強(即不允許緩存中存在過期數據)
如果允許緩存中存在過期數據,可以自己使用Redis等工具進行緩存
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://specialneedsforspecialkids.com/yun/62006.html
摘要:但是這將嚴重影響程序的性能。垂直分區的優點在于可以使得行數據變小,在查詢時減少讀取的數,減少次數。此外,垂直分區可以簡化表的結構,易于維護。垂直分區的缺點在于主鍵會出現冗余,需要管理冗余列,并會引起操作,可以通過在應用層進行來解決。 Java面試通關手冊(Java學習指南,歡迎Star,會一直完善下去,歡迎建議和指導):https://github.com/Snailclimb/Jav...
摘要:串行最高的隔離級別,完全服從的隔離級別。但是這將嚴重影響程序的性能。此外,垂直分區可以簡化表的結構,易于維護。 我自己總結的Java學習的一些知識點以及面試問題,目前已經開源,會一直完善下去,歡迎建議和指導歡迎Star: https://github.com/Snailclimb/Java_Guide 書籍推薦 《高性能MySQL : 第3版》 文字教程推薦 MySQL 教程(菜鳥教程...
閱讀 1814·2021-10-09 09:44
閱讀 2690·2021-09-22 15:38
閱讀 2451·2021-09-09 09:33
閱讀 686·2021-09-07 09:58
閱讀 1785·2021-09-02 15:41
閱讀 2485·2019-08-30 15:55
閱讀 1796·2019-08-30 15:55
閱讀 533·2019-08-30 15:44