首頁技術文章正文

redis緩存原理與實現:為什么redis可以做緩存?【python面試題】

更新時間:2020-11-30 來源:黑馬程序員 瀏覽量:

1577370495235_學IT就到黑馬程序員.gif

為什么redis可以做緩存?

(1)問題分析

這個題目考得是你對redis的理解,他能做緩存的原因是什么,回答時主要回答redis的優(yōu)點。

(2)核心問題講解

1)Redis將其數據完全保存在內存中,僅使用磁盤進行持久化。與其它鍵值數據存儲相比,Redis有一組相對豐富的數據類型。Redis可以將數據復制到任意數量的從機中。

2)異常快 - Redis非??欤棵肟蓤?zhí)行大約110000次的設置(SET)操作,每秒大約可執(zhí)行81000次的讀取/獲取(GET)操作。支持豐富的數據類型 - Redis支持開發(fā)人員常用的大多數數據類型 ,例如列表,集合,排序集和散列等等。這使得Redis很容易被用來解決各種問題,因為我們知道哪些問題可以更好使用地哪些數據類型來處理解決。

3)操作具有原子性 - 所有Redis操作都是原子操作,這確保如果兩個客戶端并發(fā)訪問,Redis服務器能接收更新的值。

4)Redis是一個內存數據庫,但在磁盤數據庫上是持久的,因此它代表了一個不同的權衡,在這種情況下,在不能大于存儲器(內存)的數據集的限制下實現非常高的寫和讀速度

5)redis支持多種數據結構,Redis不僅僅支持簡單的k/v類型的數據,同時還提供list,set,zset,hash等數據結構的存儲

6)Redis支持master-slave(主-從)模式應用

7)Redis單個value的最大限制是1GB,memcached只能保存1MB的數據。

(3)問題拓展

1)Redis和memcached的比較

Redis的優(yōu)勢是

Redis支持的數據類型比memcached豐富,memcached只有一種(字符串)

Redis可以持久化數據

redis中能存儲的數據量大

2)redis提供了三種緩存數據淘汰機制,LFU,LRU,TTL

LFU,least frequently used,即最小使用頻率淘汰,每個對象使用共計24bit空間用來實施這個算法,24bit分成2個部分,前16bit用來記錄上次減少時間(減少的是后面8bit計數器),后面8個bit是一個對數計數器,用來記錄這個對象的訪問次數。需要注意的是,這個字段不是一直增加的,也需要減少,否則會出現一個情況,一個對象很久之前被頻繁的使用,但是最近沒有被使用,若這個值不減少的話,那么這個對象會一直處在一個不會被淘汰的位置。前面16bit的作用就是,記錄一個“減量時間”,這是一個降低精度的Unix時間,將16bit的時間轉換成分鐘,不關心回繞問題。若這個時間很大,那么8bit計數器的值減半,否則只是簡單的每次遞減1

LRU,last recently used,即最近最少使用淘汰,一般做法是,將hash表的value做成一個指針,指向一個雙鏈表節(jié)點,節(jié)點中保存實際的value,雙鏈表按照上次訪問時間降序排列,當訪問到一個對象之后,更新訪問時間,并將這個節(jié)點移動到表頭,若節(jié)點不存在就直接插入到表頭。當內存門限達到的時候,從鏈表尾開始刪除若干entry。redis為了減少內存使用,不使用雙鏈表或其他結構管理對象,采用隨機算法,每次從hash表中隨機選擇一些key,一般是5個,將這些key存入一個全局的池,池大小一般是16,池中entry按照上次訪問時間降序排列,每次從池中選擇尾部的entry,就是最差的對象,將這個對象淘汰

TTL,即生存時間,按照生存時間設置一個對象的生命周期,一個對象生命周期結束之后將其銷毀

(4)在項目中的使用

我們在廣告數據、solr中搜索的品牌、規(guī)格數據以及購物車里面都是用過redis,結合spring來使用,springDataRedis。


猜你喜歡

Python if判斷語句的用法詳細介紹

緩存穿透及解決方案 

Paginator進行大數據集分頁:如何提升性能? 

Django如何進行單元測試?

黑馬程序員Python+數據分析課程



分享到:
在線咨詢 我要報名
和我們在線交談!