設置Redis最大佔用內存

設置Redis最大佔用內存

Redis須要設置最大佔用內存嗎?若是Redis內存使用超出了設置的最大值會怎樣?html

設置Redis最大佔用內存

Redis設置最大佔用內存,打開redis配置文件,找到以下段落,設置maxmemory參數,maxmemory是bytes字節類型,注意轉換。修改以下所示:python

# In short... if you have slaves attached it is suggested that you set a lower # limit for maxmemory so that there is some free RAM on the system for slave # output buffers (but this is not needed if the policy is 'noeviction'). # # maxmemory <bytes> maxmemory 268435456 

本機服務器redis配置文件路徑:/etc/redis/6379.conf,因爲本機自帶內存只有1G,通常推薦Redis設置內存爲最大物理內存的四分之三,因此設置0.75G,換成byte是751619276.linux

能夠在CentOS下輸入命令:find / -name redis查找redis目錄:nginx

[root@iZ94r80gdghZ ~]# find / -name redis /usr/share/nginx/html/blog.tanteng.me/wp-content/cache/supercache/blog.tanteng.me/tag/redis /etc/redis /var/redis 

Redis配置文件通常在etc下的redis安裝目錄下。git

Redis使用超過設置的最大值

若是Redis的使用超過了設置的最大值會怎樣?咱們來改一改上面的配置,故意把最大值設爲1個byte試試。web

# output buffers (but this is not needed if the policy is 'noeviction'). # # maxmemory <bytes> maxmemory 1 

打開debug模式下的頁面,提示錯誤:OOM command not allowed when used memory > ‘maxmemory’.redis

設置了maxmemory的選項,redis內存使用達到上限。能夠經過設置LRU算法來刪除部分key,釋放空間。默認是按照過時時間的,若是set時候沒有加上過時時間就會致使數據寫滿maxmemory。算法

若是不設置maxmemory或者設置爲0,64位系統不限制內存,32位系統最多使用3GB內存。shell

LRU是Least Recently Used 近期最少使用算法。centos

  • volatile-lru -> 根據LRU算法生成的過時時間來刪除。
  • allkeys-lru -> 根據LRU算法刪除任何key。
  • volatile-random -> 根據過時設置來隨機刪除key。
  • allkeys->random -> 無差異隨機刪。
  • volatile-ttl -> 根據最近過時時間來刪除(輔以TTL)
  • noeviction -> 誰也不刪,直接在寫操做時返回錯誤。

若是設置了maxmemory,通常都要設置過時策略。打開Redis的配置文件有以下描述,Redis有六種過時策略:

# volatile-lru -> remove the key with an expire set using an LRU algorithm # allkeys-lru -> remove any key accordingly to the LRU algorithm # volatile-random -> remove a random key with an expire set # allkeys-random -> remove a random key, any key # volatile-ttl -> remove the key with the nearest expire time (minor TTL) # noeviction -> don't expire at all, just return an error on write operations 

那麼打開配置文件,添加以下一行,使用volatile-lru的過時策略:

maxmemory-policy volatile-lru 

保存文件退出,重啓redis服務。

info命令查看Redis內存使用狀況

如服務器Redis所在目錄:/usr/local/redis-3.0.7/src

在終端輸入./redis-cli,打開Redis客戶端,輸入info命令。

出來以下信息:

[root@iZ94r80gdghZ src]# ./redis-cli 127.0.0.1:6379> info # Server redis_version:3.0.7 redis_git_sha1:00000000 redis_git_dirty:0 redis_build_id:f07a42660a61a05e redis_mode:standalone os:Linux 3.10.0-327.10.1.el7.x86_64 x86_64 arch_bits:64 multiplexing_api:epoll gcc_version:4.8.5 process_id:2165 run_id:8ec8a8dc969d6e2f2867d9188ccb90850bfc9acb tcp_port:6379 uptime_in_seconds:668 uptime_in_days:0 hz:10 lru_clock:15882419 config_file:/etc/redis/6379.conf # Clients connected_clients:1 client_longest_output_list:0 client_biggest_input_buf:0 blocked_clients:0 # Memory used_memory:816232 used_memory_human:797.10K used_memory_rss:7655424 used_memory_peak:816232 used_memory_peak_human:797.10K used_memory_lua:36864 mem_fragmentation_ratio:9.38 mem_allocator:jemalloc-3.6.0 # Persistence loading:0 rdb_changes_since_last_save:0 rdb_bgsave_in_progress:0 rdb_last_save_time:1458722327 rdb_last_bgsave_status:ok rdb_last_bgsave_time_sec:-1 rdb_current_bgsave_time_sec:-1 aof_enabled:0 aof_rewrite_in_progress:0 aof_rewrite_scheduled:0 aof_last_rewrite_time_sec:-1 aof_current_rewrite_time_sec:-1 aof_last_bgrewrite_status:ok aof_last_write_status:ok # Stats total_connections_received:1 total_commands_processed:0 instantaneous_ops_per_sec:0 total_net_input_bytes:14 total_net_output_bytes:0 instantaneous_input_kbps:0.00 instantaneous_output_kbps:0.00 rejected_connections:0 sync_full:0 sync_partial_ok:0 sync_partial_err:0 expired_keys:0 evicted_keys:0 keyspace_hits:0 keyspace_misses:0 pubsub_channels:0 pubsub_patterns:0 latest_fork_usec:0 migrate_cached_sockets:0 # Replication role:master connected_slaves:0 master_repl_offset:0 repl_backlog_active:0 repl_backlog_size:1048576 repl_backlog_first_byte_offset:0 repl_backlog_histlen:0 # CPU used_cpu_sys:0.30 used_cpu_user:0.29 used_cpu_sys_children:0.00 used_cpu_user_children:0.00 # Cluster cluster_enabled:0 # Keyspace db0:keys=1,expires=1,avg_ttl=425280 

其中used_memory:816232,僅用了0.7M左右。

本文在網上查閱資料,在阿里雲CentOS主機實踐。

 

Redis設置內存最大佔用值:

Redis設置佔用物理機最大的內存

#佔用最大20G maxmemory 20480mb

Redis設置內存裝不下了,有限刪除即將過時的

當前已用內存超過maxmemory限定時,觸發主動清理策略

  • volatile-lru:只對設置了過時時間的key進行LRU(默認值)
  • allkeys-lru : 刪除lru算法的key
  • volatile-random:隨機刪除即將過時key
  • allkeys-random:隨機刪除
  • volatile-ttl : 刪除即將過時的
  • noeviction : 永不過時,返回錯誤當mem_used內存已經超過maxmemory的設定,對於全部的讀寫請求;
#超事後刪除即將過時的 maxmemory-policy volatile-ttl
相關文章
相關標籤/搜索