Redis占用內存大小


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-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
  LRU算法

轉載: https://blog.csdn.net/asade12345/article/details/103215904


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM