Unterstützte Instanzkonfigurationen

Auf dieser Seite werden Maxmemory-Richtlinien und andere für Memorystore for Valkey verfügbare Konfigurationen beschrieben. Memorystore for Valkey unterstützt nur Instanzen im Clustermodus.

Eine Anleitung zum Ändern der auf dieser Seite aufgeführten Konfigurationen finden Sie unter Instanz konfigurieren.

Maxmemory-Richtlinien

Wenn der Instanzspeicher voll ist und ein neuer Schreibvorgang eingeht, werden die Schlüssel von Valkey entfernt, um Platz für den Schreibvorgang zu schaffen. Dieser Vorgang basiert auf der Maximalspeicherrichtlinie Ihrer Instanz. Die standardmäßige Richtlinie für max. Speicher für Memorystore for Valkey ist volatile-lru. Sie können auch eine der folgenden Maximalspeicher-Richtlinien verwenden:

  • noeviction: Gibt einen Fehler zurück, wenn die Instanz den Höchstspeicher erreicht. Daten werden nicht überschrieben oder entfernt.
  • allkeys-lfu: Entfernt die am wenigsten verwendeten Schlüssel (LFU) aus dem gesamten Keyset.
  • allkeys-lru: Entfernt die am weitesten in der Vergangenheit verwendeten (LRU) Schlüssel aus dem gesamten Keyset.
  • volatile-lfu: Löscht die am weitesten in der Vergangenheit verwendeten Schlüssel, die mit TTL-Ablauf (Lebensdauer) festgelegt sind.
  • volatile-lru: Entfernt die am weitesten in der Vergangenheit verwendeten (LRU)-Schlüssel, die mit TTL-Ablaufzeiten festgelegt sind.
  • allkeys-random: Entfernt zufällige Schlüssel aus dem gesamten Schlüsselbereich.
  • volatile-random: Entfernt zufällige Schlüssel aus den Schlüsseln mit TTL-Ablauf.
  • volatile-ttl: Entfernt die Schlüssel mit der kürzesten TTL aus den Schlüsseln mit TTL-Ablauf.

Editierbare Konfigurationsparameter

Sie können die folgenden Parameter ändern, wenn Sie eine Memorystore for Redis-Instanz erstellen oder aktualisieren.

Parameter Beschreibung Zulässige Werte
maxmemory-clients Mit dieser Konfiguration können Nutzer die maximale Arbeitsspeichernutzung von Clients steuern.

Gesamte Arbeitsspeichernutzung von normalen/Pub/Sub-Clients. Wenn das Limit erreicht wird, wird der Client mit der größten Speichernutzung entfernt.
Zulässige Werte sind Ganzzahlwerte zwischen 0% und 100%. Der Prozentsatz des Maxmemory der Instanz, auf den der Clientspeicher begrenzt ist.

Der Standardwert hängt vom Knotentyp ab. Weitere Informationen finden Sie unter Knotenmerkmale.
maxmemory Gibt ein anpassbares Limit an, ab dem die Bereinigungsrichtlinie wirksam wird. Sie legen das Maxmemory-Limit auf Ebene des einzelnen Knotens fest, die Einstellung gilt jedoch für alle Knoten. Angenommen, Sie haben eine Instanz mit 3 Knoten, verwenden einen highmem-xlarge-Knotentyp mit 58 GB und möchten maxmemory auf 90% der gesamten Instanzkapazität festlegen. Dazu legen Sie maxmemory auf 52, 2 GB fest, was 90% der Knotenkapazität entspricht. Das gilt für alle Knoten, wodurch das Gesamtlimit für die Instanz auf 90 % festgelegt wird. Weitere Informationen zum standardmäßig reservierten Overhead finden Sie unter Schlüsselbereichskapazität und reservierter Overhead. Maxmemory-Limit für Ihre Instanz.

Folgende Einheiten werden unterstützt:

b (Standard)
k
kb
m
mb
g
gb
maxmemory-policy Gibt das Verhalten an, dem Valkey folgt, wenn die Instanzdaten das Limit von maxmemory erreichen. Weitere Informationen zu den einzelnen Richtlinien finden Sie unter Maxmemory-Richtlinien. noeviction
allkeys-lru
volatile-lru (Standard)
allkeys-random
volatile-random
volatile-ttl
volatile-lfu
allkeys-lfu
notify-keyspace-events Clients können Benachrichtigungen für bestimmte Keyspace-Ereignisse abonnieren. ""
Kein Ereignis (Standard)
K
Keyspace-Ereignisse mit dem Präfix __keyspace@<db>__.
E
Keyevent-Ereignisse mit dem Präfix __keyevent@<db>__.
g
Allgemeine Befehle (nicht typspezifisch), z. B. DEL, EXPIRE oder RENAME
$
Stringbefehle
l
Listenbefehle
s
Befehle für Sets
h
Hash-Befehle
z
Befehle für sortierte Sets
x
Abgelaufene Ereignisse (Ereignisse, die jedes Mal generiert werden, wenn ein Schlüssel abläuft)
e
Ausgelagerte Ereignisse (Ereignisse, die generiert werden, wenn ein Schlüssel aufgrund von „maxmemory“ ausgelagert wird)
A
Alias für g$lshzxe, sodass der String „AKE“ für alle Ereignisse steht.
slowlog-log-slower-than Hier können Sie das langsame Protokoll konfigurieren. Gibt den Grenzwert für die Ausführungszeit in Mikrosekunden an. Wenn ein Befehl diesen Grenzwert überschreitet, wird er dem Protokoll für langsame Befehle hinzugefügt. Der Standardwert ist 10.000.

Ein Wert von null erzwingt die Protokollierung aller Befehle. Der Wert -1 deaktiviert das Protokoll. Alle anderen negativen Werte werden abgelehnt.
maxclients Hier können Sie die maxclients-Konfiguration für Ihre Instanz konfigurieren. Informationen zum Maximalwert für Clients und zum Standardwert für Ihre Instanz finden Sie unter Maximale Anzahl von Clients. Der Standardwert hängt vom Knotentyp ab. Weitere Informationen finden Sie unter Knotenmerkmale.