緩存的優點和缺點


為什么要用緩存?

用緩存,主要有兩個用途:高性能、高並發。

高性能

假設這么個場景,你有個操作,一個請求過來,吭哧吭哧你各種亂七八糟操作 mysql,半天查出來一個結果,耗時 600ms。但是這個結果可能接下來幾個小時都不會變了,或者變了也可以不用立即反饋給用戶。那么此時咋辦?

緩存啊,折騰 600ms 查出來的結果,扔緩存里,一個 key 對應一個 value,下次再有人查,別走 mysql 折騰 600ms 了,直接從緩存里,通過一個 key 查出來一個 value,2ms 搞定。性能提升 300 倍。

就是說對於一些需要復雜操作耗時查出來的結果,且確定后面不怎么變化,但是有很多讀請求,那么直接將查詢出來的結果放在緩存中,后面直接讀緩存就好。

高並發

mysql 這么重的數據庫,壓根兒設計不是讓你玩兒高並發的,雖然也可以玩兒,但是天然支持不好。mysql 單機支撐到 2000QPS 也開始容易報警了。

所以要是你有個系統,高峰期一秒鍾過來的請求有 1萬,那一個 mysql 單機絕對會死掉。你這個時候就只能上緩存,把很多數據放緩存,別放 mysql。緩存功能簡單,說白了就是 key-value 式操作,單機支撐的並發量輕松一秒幾萬十幾萬,支撐高並發 so easy。單機承載並發量是 mysql 單機的幾十倍。

緩存是走內存的,內存天然就支撐高並發。

用了緩存之后會有什么不良后果?

常見的緩存問題有以下幾個:


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM