>데이터 베이스 >Redis >Redis 메모리 제거 메커니즘 소개

Redis 메모리 제거 메커니즘 소개

尚
앞으로
2020-05-10 08:57:112579검색

Redis 메모리 제거 메커니즘 소개

Redis 메모리 제거는 사용자가 저장한 일부 키가 Redis에 의해 인스턴스에서 적극적으로 삭제되어 읽기 누락이 발생할 수 있음을 의미합니다. 그러면 Redis에 이 기능이 있는 이유는 무엇일까요? 이것이 우리가 탐구해야 할 원래의 디자인 의도입니다.

Redis의 가장 일반적인 두 가지 애플리케이션 시나리오는 캐싱과 영구 스토리지입니다. 먼저 명확히 해야 할 질문은 메모리 제거 전략이 어떤 시나리오에 더 적합한가입니다. 영구 저장소인가요 아니면 캐시인가요?

메모리 제거 메커니즘의 원래 의도는 메모리 사용 효율을 높이는 대신 메모리를 더 잘 활용하고 특정 캐시 누락을 사용하는 것입니다.

Redis 사용자는 Redis에서 제공하는 이 기능을 어떻게 사용하나요? 다음 구성을 살펴보세요

# maxmemory <bytes>

redis.conf에서 maxmemory 값을 구성하여 메모리 제거 기능을 활성화할 수 있습니다. 이 값의 의미는 메모리 제거 과정을 이해하면 그 의미를 이해할 수 있습니다. 1. 클라이언트가 추가 메모리를 적용해야 하는 명령(예: set)을 시작했습니다.

2. Redis는 사용된 메모리가 maxmemory보다 큰 경우 특정 양의 메모리를 교환하여 사용자가 구성한 다양한 제거 전략에 따라 메모리(키) 제거를 시작합니다.

3. 위의 내용에 문제가 없다면 이 명령은 성공적으로 실행된 것입니다.

maxmemory가 0이면 Redis의 메모리 사용량에 제한이 없다는 의미입니다.

Redis는 사용자가 선택할 수 있는 다음 제거 전략을 제공하며 기본 전략은 noeviction 전략입니다.

    noeviction: 메모리 사용량이 임계값에 도달하면 메모리 적용을 유발하는 모든 명령이 오류를 보고합니다.
  • allkeys-lru: 기본 키 공간에서 최근에 사용하지 않은 키를 먼저 제거합니다.

  • 휘발성-lru: 만료 시간이 설정된 키 공간에서 최근 사용하지 않은 키를 먼저 제거합니다.

  • allkeys-random: 기본 키 공간에서 키를 무작위로 제거합니다.

  • 휘발성-random: 만료 시간이 설정된 키 공간에서 키를 무작위로 제거합니다.
  • 휘발성-ttl: 만료 시간이 설정된 키 공간에서 만료 시간이 더 빠른 키가 먼저 제거됩니다.
  • 여기서 기본 키 공간과 만료 시간이 설정된 키 공간을 추가합니다. 예를 들어 Redis에 키 배치가 저장되어 있다고 가정하면 이 키 배치와 해당 값을 저장하는 데 사용되는 해시 테이블이 있습니다. 이 배치의 일부 키에 만료 시간이 설정된 경우 이 키 배치는 다른 해시 테이블에 저장됩니다. 이 해시 테이블의 값은 키에 설정된 만료 시간에 해당합니다. 만료 시간이 설정된 키 공간은 기본 키 공간의 하위 집합입니다.

Redis는 대략적으로 몇 가지 제거 전략을 제공하는 것으로 알고 있는데 어떻게 선택해야 할까요? 제거 전략 선택은 다음 구성을 통해 지정할 수 있습니다.

# maxmemory-policy noeviction

그런데 이 값으로 무엇을 채워야 할까요? 이 문제를 해결하려면 애플리케이션이 Redis에 저장된 데이터 세트에 대한 액세스를 요청하는 방법과 요구 사항이 무엇인지 이해해야 합니다. 동시에 Redis는 제거 전략을 수정하는 런타임도 지원하므로 Redis 인스턴스를 다시 시작하지 않고도 실시간으로 메모리 제거 전략을 조정할 수 있습니다.

몇 가지 전략의 적용 가능한 시나리오를 살펴보겠습니다.

    allkeys-lru: 캐시에 대한 애플리케이션의 액세스가 거듭제곱 분포를 따르는 경우(즉, 상대적으로 핫한 데이터가 있는 경우), 그렇지 않으면 우리 애플리케이션의 캐시에 대해 많이 알지 못합니다. 액세스 배포 상태에 대해 allkeys-lru 전략을 선택할 수 있습니다.
  • allkeys-random: 애플리케이션이 캐시 키에 대한 액세스 확률이 동일하다면 이 전략을 사용할 수 있습니다.

  • 휘발성-ttl: 이 전략을 사용하면 어떤 키가 제거에 더 적합한지 Redis에 알릴 수 있습니다.

  • 또한 휘발성-lru 전략과 휘발성-랜덤 전략은 하나의 Redis 인스턴스를 캐시와 영구 저장소에 모두 적용하는 경우에 적합합니다. 그러나 두 개의 Redis 인스턴스를 사용하여도 동일한 결과를 얻을 수 있습니다. , 키 만료 시간을 설정하면 실제로 더 많은 메모리가 소비된다는 점을 언급할 가치가 있으므로 메모리를 보다 효율적으로 사용하려면 allkeys-lru 전략을 사용하는 것이 좋습니다.

더 많은 Redis 지식을 알고 싶다면

redis 입문 튜토리얼

칼럼을 주목해 주세요.

위 내용은 Redis 메모리 제거 메커니즘 소개의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
이 기사는 cnblogs.com에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제