日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

面试官:缓存穿透、缓存雪崩和缓存击穿是什么?

發布時間:2025/3/20 编程问答 25 豆豆
生活随笔 收集整理的這篇文章主要介紹了 面试官:缓存穿透、缓存雪崩和缓存击穿是什么? 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

前言

原創公眾號:bigsai

對于緩存穿透、緩存雪崩和緩存擊穿常常出現在面試中,今天來看看它到底是啥吧?


redis緩存穿透


理解

  • 重在穿透吧,也就是訪問透過redis直接經過mysql,通常是一個不存在的key,在數據庫查詢為null。每次請求落在數據庫、并且高并發。數據庫扛不住會掛掉。

解決方案

  • 可以將查到的null設成該key的緩存對象。
  • 當然,也可以根據明顯錯誤的key在邏輯層就就行驗證。
  • 同時,你也可以分析用戶行為,是否為故意請求或者爬蟲、攻擊者。針對用戶訪問做限制。
  • 其他等等,比如用布隆過濾器(超大型hashmap)先過濾。

redis緩存雪崩

理解

  • 雪崩,就是某東西蜂擁而至的意思,像雪崩一樣。在這里,就是redis緩存集體大規模集體失效,在高并發情況下突然使得key大規模訪問mysql,使得數據庫崩掉。可以想象下國家人口老年化。以后那天人集中在70-80歲,就沒人干活了。國家勞動力就造成壓力。

解決方案

  • 通常的解決方案是將key的過期時間后面加上一個隨機數,讓key均勻的失效。
  • 考慮用隊列或者鎖讓程序執行在壓力范圍之內,當然這種方案可能會影響并發量。
  • 熱點數據可以考慮不失效

redis緩存擊穿

理解

緩存擊穿,是指一個key非常熱點,在不停的扛著大并發,大并發集中對這一個點進行訪問,當這個key在失效的瞬間,持續的大并發就穿破緩存,直接請求數據庫,好像蠻力擊穿一樣。

  • 擊穿和穿透不同,穿透的意思是想法繞過redis去使得數據庫崩掉。而擊穿你可以理解為正面剛擊穿,這種通常為大量并發對一個key進行大規模的讀寫操作。這個key在緩存失效期間大量請求數據庫,對數據庫造成太大壓力使得數據庫崩掉。就比如在秒殺場景下10000塊錢的mac和100塊的mac這個100塊的那個訂單肯定會被搶到爆,不斷的請求(當然具體秒殺有自己處理方式這里只是舉個例子)。所以緩存擊穿就是針對某個常用key大量請求導致數據庫崩潰。

解決方案

  • 可以使用互斥鎖避免大量請求同時落到db。
  • 布隆過濾器,判斷某個容器是否在集合中
  • 可以將緩存設置永不過期(適合部分情況)
  • 做好熔斷、降級,防止系統崩潰。

原創公眾號:「bigsai」,回復bigsai獲取8G pdf資源!

總結

以上是生活随笔為你收集整理的面试官:缓存穿透、缓存雪崩和缓存击穿是什么?的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。