php使用redis記憶體不足的解決辦法:1、通過組態檔或者命令設定Redis最大佔用記憶體大小為100M;2、獲取當前記憶體淘汰策略;3、通過「config set maxmemory-policy allkeys-lru」命令修改淘汰策略即可。
千萬級資料並行如何處理?進入學習
本教學操作環境:windows7系統、PHP8.1版、Dell G3電腦。
我們知道Redis是基於記憶體的key-value資料庫,因為系統的記憶體大小有限,所以我們在使用Redis的時候可以設定Redis能使用的最大的記憶體大小。
通過在Redis安裝目錄下面的redis.conf組態檔中新增以下設定設定記憶體大小
//設定Redis最大佔用記憶體大小為100M maxmemory 100mb
redis的組態檔不一定使用的是安裝目錄下面的redis.conf檔案,啟動redis服務的時候是可以傳一個引數指定redis的組態檔的
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定義了幾種策略用來處理這種情況: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
上面說到了Redis可使用最大記憶體使用完了,是可以使用LRU演演算法進行記憶體淘汰的,那麼什麼是LRU演演算法呢?
LRU(Least Recently Used),即最近最少使用,是一種快取置換演演算法。在使用記憶體作為快取的時候,快取的大小一般是固定的。當快取被佔滿,這個時候繼續往快取裡面新增資料,就需要淘汰一部分老的資料,釋放記憶體空間用來儲存新的資料。這個時候就可以使用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其它相關文章!