天天看點

面試官:Redis 記憶體資料滿了,會當機嗎?

背景

Redis 資料庫記憶體資料滿了,會當機嗎?答案是:不會讓它出現存滿的情況,在使用Redis的時候我們要配置Redis能使用的最大的記憶體大小,存到一定容量的時候還有Redis的記憶體淘汰政策呢,還有LRU算法進行淘汰,等等。

Redis的記憶體淘汰政策

1、Redis占用記憶體大小

我們知道Redis是基于記憶體的key-value資料庫,因為系統的記憶體大小有限,是以我們在使用Redis的時候可以配置Redis能使用的最大的記憶體大小。

通過配置檔案配置

通過在Redis安裝目錄下面的redis.conf配置檔案中添加以下配置設定記憶體大小

面試官:Redis 記憶體資料滿了,會當機嗎?
通過指令修改

Redis支援運作時通過指令動态修改記憶體大小

面試官:Redis 記憶體資料滿了,會當機嗎?

如果不設定最大記憶體大小或者設定最大記憶體大小為0,在64位作業系統下不限制記憶體大小,在32位作業系統下最多使用3GB記憶體

Redis的記憶體淘汰

既然可以設定Redis最大占用記憶體大小,那麼配置的記憶體就有用完的時候。那在記憶體用完的時候,還繼續往Redis裡面添加資料不就沒記憶體可用了嗎?

實際上Redis定義了幾種政策用來處理這種情況:

noeviction(預設政策):對于寫請求不再提供服務,直接傳回錯誤(DEL請求和部分特殊請求除外)

allkeys-lru:從所有key中使用LRU算法進行淘汰

volatile-lru:從設定了過期時間的key中使用LRU算法進行淘汰

allkeys-random:從所有key中随機淘汰資料

volatile-random:從設定了過期時間的key中随機淘汰

volatile-ttl:在設定了過期時間的key中,根據key的過期時間進行淘汰,越早過期的越優先被淘汰

當使用volatile-lru、volatile-random、volatile-ttl這三種政策時,如果沒有key可以被淘汰,則和noeviction一樣傳回錯誤

如何擷取及設定記憶體淘汰政策

擷取目前記憶體淘汰政策:

127.0.0.1:6379> config get maxmemory-policy

通過配置檔案設定淘汰政策(修改redis.conf檔案):

maxmemory-policy allkeys-lru

通過指令修改淘汰政策:

127.0.0.1:6379> config set maxmemory-policy allkeys-lru`