php使用redis記憶體不足怎麼辦

2022-11-06 10:00:11

php使用redis記憶體不足的解決辦法:1、通過組態檔或者命令設定Redis最大佔用記憶體大小為100M;2、獲取當前記憶體淘汰策略;3、通過「config set maxmemory-policy allkeys-lru」命令修改淘汰策略即可。

千萬級資料並行如何處理?進入學習

本教學操作環境:windows7系統、PHP8.1版、Dell G3電腦。

Redis佔用記憶體大小

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

1、通過組態檔設定

通過在Redis安裝目錄下面的redis.conf組態檔中新增以下設定設定記憶體大小

//設定Redis最大佔用記憶體大小為100M maxmemory 100mb

redis的組態檔不一定使用的是安裝目錄下面的redis.conf檔案,啟動redis服務的時候是可以傳一個引數指定redis的組態檔的

2、通過命令修改

Redis支援執行時通過命令動態修改記憶體大小

//設定Redis最大佔用記憶體大小為100M 127.0.0.1:6379> config set maxmemory 100mb //獲取設定的Redis能使用的最大記憶體大小 127.0.0.1:6379> config get maxmemory

如果不設定最大記憶體大小或者設定最大記憶體大小為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-lruvolatile-randomvolatile-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

LRU演演算法

什麼是LRU?

上面說到了Redis可使用最大記憶體使用完了,是可以使用LRU演演算法進行記憶體淘汰的,那麼什麼是LRU演演算法呢?

LRU(Least Recently Used),即最近最少使用,是一種快取置換演演算法。在使用記憶體作為快取的時候,快取的大小一般是固定的。當快取被佔滿,這個時候繼續往快取裡面新增資料,就需要淘汰一部分老的資料,釋放記憶體空間用來儲存新的資料。這個時候就可以使用LRU演演算法了。其核心思想是:如果一個資料在最近一段時間沒有被用到,那麼將來被使用到的可能性也很小,所以就可以被淘汰掉。

LRU在Redis中的實現

近似LRU演演算法

Redis使用的是近似LRU演演算法,它跟常規的LRU演演算法還不太一樣。近似LRU演演算法通過隨機取樣法淘汰資料,每次隨機出5(預設)個key,從裡面淘汰掉最近最少使用的key。

可以通過maxmemory-samples引數修改取樣數量:例:maxmemory-samples 10 maxmenory-samples設定的越大,淘汰的結果越接近於嚴格的LRU演演算法

Redis為了實現近似LRU演演算法,給每個key增加了一個額外增加了一個24bit的欄位,用來儲存該key最後一次被存取的時間。

推薦學習:《》

以上就是php使用redis記憶體不足怎麼辦的詳細內容,更多請關注TW511.COM其它相關文章!