Поскольку Redis хранит данные в оперативной памяти, управление памятью имеет критическое значение — понимание лимита maxmemory, политик вытеснения, оптимизации памяти и мониторинга необходимо для надёжной работы Redis без риска переполнения.
maxmemory и вытеснение
Set a memory limit so Redis doesn't consume all RAM:
maxmemory 2gb # cap Redis at 2GB
maxmemory-policy allkeys-lru # what to do when the limit is reached
When the limit is hit, Redis EVICTS keys per the policy (or rejects writes):
allkeys-lru → evict least-recently-used (any key) — common for a pure cache
allkeys-lfu → evict least-frequently-used
volatile-lru → evict LRU among keys WITH a TTL only
volatile-ttl → evict keys closest to expiry
noeviction → reject writes when full (good if Redis holds important data)
