優化MySQL 還是使用快取?
今天我想對一個Greenfield專案上可以採用的各種效能優化策略作個對比。換言之,該專案沒有之前決策強加給它的各種約束限制,也還沒有被優化過。
具體來說,我想比較的兩種優化策略是優化MySQL和快取。提前指出,這些優化是正交的,唯一讓你選擇其中一者而不是另一者的原因是他們都耗費了資源,即開發時間。
優化MySQL
優化MySQL時,一般會先檢視傳送給mysql的查詢語句,然後執行explain命令。稍加審查後很常見的做法是增加索引或者對模式做一些調整。
優點
1、一個經過優化的查詢對於所有使用應用的使用者來說都是快速的。因為索引通過對數複雜度的速度來檢索資料(又名分制,正如你搜尋一個電話簿一樣,逐步縮小搜尋範圍),而且隨著資料量的遞增也能維持良好的效能。對一個未經索引化的查詢的結果做快取隨著資料的增長有時候則可能會表現得更差。隨著資料的增長,那些未命中快取的使用者可能會得到很糟糕的體驗,這樣的應用是不可用的。
2、優化MySQL不需要擔心快取失效或者快取資料過期的問題。
3、優化MySQL可以簡化技術架構,在開發環境下複製和工作會更加容易。
缺點
1、有一些查詢不能光通過索引得到效能上的改善,可能還需要改變模式,在某些情況下這對於一些應用可能會很麻煩。
2、有些模式的更改可能用於反規範化(資料備份)。儘管對於DBA來說,這是一項常用的技術,它需要所有權以確保所有的地方都是由應用程式更新,或需要安裝觸發器來保證這種變化。
3、一些優化手段可能是MySQL所特有的。也就是說,如果底層軟體被移植到多個資料庫上工作,那麼很難確保除了增加索引外一些更復雜的優化技術可以通用。
使用快取
這種優化需要人來分析應用的實際情況,然後將處理代價昂貴的部分從MySQL中剝離出來用第三方快取替代,比如memcached或Redis。
優點
1、快取對於一些MySql自身很難優化的查詢來說會工作地很好,比如大規模的聚合或者分組的查詢。
2、快取對於提高系統的吞吐率來說可能是個不錯的方案。比如對於多人同時訪問應用時響應速度很慢的情況。
3、快取可能更容易構建在另一個應用之上。比如:你的應用可能是另一個用MySQL儲存資料的軟體包的前端,而要對這個軟體包做任何資料庫方面的改動都非常難。
缺點
1、如果資料對外提供多種存取正規化(例如,在不同的頁面上用不同的形式展示),那麼讓快取過期或者更新可能會很難,同時/或者可能需要容忍已過期的資料。一個可行的替代方案是設計一套更加精細的快取機制,當然它也有缺點,即多次獲取快取會增加時延。
2、快取一個產生代價昂貴的物件對於那些未命中快取的使用者(見優化MySQL的優勢#1)而言可能會產生潛在的效能差異。一些好的效能實踐表明你應該儘量縮小使用者之間的差異性,而不僅僅是平均化(快取傾向於這麼做)。
3、幼稚的快取實現無力應對一些微妙的漏洞,比如雪崩效應。就在上週我幫助了一個人,他的資料庫伺服器被多個試圖同時再生同樣快取內容的使用者請求沖垮。正確的策略是引入一定級別的鎖來將快取再生的請求序列化。
總結
一般情況下,我會建議使用者先對MySQL進行優化,因為這是我認為開始階段最合適的解決方案。但長期來看,大部分應用都會有一些用例需要一定程度上同時實現以上這些方案。
原文連結: Morgan Tocker 翻譯: 伯樂線上 - 高磊
相關文章
- Laravel 優化 Auth 使用快取驅動Laravel優化快取
- Laravel Passport 使用快取優化記錄LaravelPassport快取優化
- Web 效能優化:理解及使用 JavaScript 快取Web優化JavaScript快取
- Redis不僅僅是快取,還是……Redis快取
- 頁面快取優化快取優化
- redis快取優化案例Redis快取優化
- 【譯】Web 效能優化:理解及使用 JavaScript 快取Web優化JavaScript快取
- 快取,究竟是淘汰,還是修改?快取
- 你管這破玩意叫快取穿透?還是快取擊穿?快取穿透
- 究竟先操作快取,還是資料庫?快取資料庫
- 使用Redis做為MySQL的快取RedisMySql快取
- mysql查詢快取簡單使用MySql快取
- 前端效能優化之快取技術前端優化快取
- 前端效能優化之HTTP快取策略前端優化HTTP快取
- 【譯】Google - 使用 webpack 進行 web 效能優化(二):利用好持久化快取GoWeb優化持久化快取
- MySQL每秒57萬的寫入,快還是慢?MySql
- Web靜態資源快取及優化Web快取優化
- 前端效能優化 之 瀏覽器快取前端優化瀏覽器快取
- HTTP前端效能優化(壓縮與快取)HTTP前端優化快取
- SpringBoot之日誌註解和快取優化Spring Boot快取優化
- 快取最佳化(快取穿透)快取穿透
- 如何優雅的設計和使用快取?快取
- 快取架構設計細節二三事--究竟先操作快取,還是資料庫?快取架構資料庫
- 到底是先更新資料庫還是先更新快取?資料庫快取
- 都在使用的快取,騰訊大牛告訴你他們是如何使用快取的快取
- [譯]谷歌Web效能優化系列:HTTP 快取(中英)谷歌Web優化HTTP快取
- 什麼是redis快取雪崩、快取穿透、快取擊穿Redis快取穿透
- 快取穿透、快取雪崩和快取擊穿是什麼?快取穿透
- cocos2d-x 優化(紋理渲染優化、資源快取、記憶體優化)優化快取記憶體
- mysql索引的使用和優化MySql索引優化
- MySQL 索引使用策略及優化MySql索引優化
- PHP Mysql support: 是mysql 還是mysqlnd?PHPMySql
- 前端優化:瀏覽器快取技術介紹前端優化瀏覽器快取
- 前端效能優化(二)——瀏覽器快取機制前端優化瀏覽器快取
- 分散式系統關注點——先寫DB還是「快取」?分散式快取
- MySQL8取消快取MySql快取
- 快取和web快取分別是什麼?快取Web
- 評論模組優化 - 資料表優化、新增快取及用 Feign 與使用者服務通訊優化快取
- MySQL: 使用explain 優化查詢效能MySqlAI優化