EXPIRE key seconds
wird verwendet, um eine Ablaufzeit für einen Schlüssel festzulegen. Der zweite Parameter gibt an, wie viele Sekunden vergehen, bevor der Schlüssel abläuft. Nach Ablauf eines Schlüssels wird der Schlüssel automatisch gelöscht. In der Redis-Terminologie werden Schlüssel mit Ablaufzeit oft als flüchtig bezeichnet.
Bei Verwendung von Lösch- oder Überschreibvorgängen für diesen Schlüssel wird die Ablaufzeit gelöscht. Diese Vorgänge umfassen DEL, SET, GETSET und alle *STORE-Befehle. Die Befehle, die den Schlüsselwert ändern, ändern nicht die Ablaufzeit, z. B. IINCR zum Ändern des Werts, LPUSH zum Hinzufügen eines neuen Werts zur Warteschlange und HSET zum Ändern der Mitglieder in der Hash-Tabelle.
Wenn Sie nur die Ablaufzeit löschen möchten, können Sie den Befehl PERSIST aufrufen, damit der Schlüssel nicht abläuft. Die Ablaufzeit ist ein Attribut des Schlüssels und ändert sich durch die Änderung des Schlüsselnamens (RENAME) nicht. Wenn RENAME verwendet wird, um andere Schlüssel zu überschreiben, ist lediglich ein Überschreibeffekt aufgetreten, und der umbenannte Schlüssel behält weiterhin seine Ablaufzeit.
Hinweis: Wenn Sie den Befehl EXPIRE/PEXPIRE mit einer nicht positiven Zahl auf einem Schlüssel aufrufen oder EXPIREAT/PEXPIREAT mit einer vergangenen Zeit aufrufen, wird der Schlüssel direkt entfernt.
Ablaufzeit aktualisieren
Der Aufruf von EXPIRE für einen Schlüssel mit Ablaufzeit kann die Ablaufzeit dieses Schlüssels aktualisieren.
Rückgabewert
Call EXPIRE key seconds gibt 0 oder 1 zurück, 0 bedeutet, dass der Schlüssel nicht existiert, 1 bedeutet, dass der Schlüssel auf Timeout eingestellt wurde.
Wie Redis mit Schlüsseln mit Ablaufzeit umgeht
Schlüssel mit Ablaufzeit
Unter normalen Umständen ist Redis Der Schlüssel existiert bis Der Schlüssel wird explizit gelöscht (über den Befehl DEL) oder aufgrund von Speicherbeschränkungen gelöscht. Das Festlegen eines Zeitlimits für einen Schlüssel erfordert zusätzlichen Speicher, um relevante Informationen aufzuzeichnen. Redis stellt sicher, dass der Schlüssel entfernt wird, wenn er abläuft.
Genauigkeit der Ablaufzeit
Ab redis2.6 liegt die Abweichung der Ablaufzeit zwischen 0 und 1 Millisekunde.
Ablaufzeitlogik
Die Ablaufzeit des Schlüssels verwendet den absoluten Unix-Zeitstempel (mit Millisekunden als Genauigkeit), auch wenn die Redis-Instanz bis dahin geschlossen ist Unix-Zeit Wenn Sie ihn anstecken, läuft der Schlüssel ebenfalls ab (er wird nur nicht sofort gelöscht).
Wenn Sie Daten von einem Redis auf ein Redis auf einem anderen Computer verschieben möchten, indem Sie RDB-Dateien verschieben, müssen Sie sicherstellen, dass die absoluten Unix-Zeitstempel der beiden Computer konsistent sind.
Wenn Sie eine Ablaufzeit für einen Schlüssel festlegen, ändern Sie die Zeit Ihres Computers nicht beiläufig, da Redis häufig die Systemzeit überprüft. Wenn Sie die Zeit nach vorne anpassen, laufen die Schlüssel, die ablaufen sollen, nicht ab. Wenn Sie die Zeit zurückstellen, verfallen Schlüssel, die nicht ablaufen sollten.
So bereinigt Redis abgelaufene Schlüssel:
Redis bereinigt abgelaufene Schlüssel auf zwei Arten: passive Reinigung und aktive Reinigung.
(1) Passive Reinigung: Wenn beim Zugriff auf einen Schlüssel mit einer Ablaufzeit festgestellt wird, dass der Schlüssel abgelaufen ist, wird der Schlüssel gelöscht.
(2) Redis führt 10 Prüfungen pro Sekunde durch. Jede Prüfung umfasst:
Wählen Sie zufällig 20 Schlüssel mit Ablaufzeit aus und löschen Sie dann alle abgelaufenen Schlüssel.
Wenn mehr als 25 % der Schlüssel dieser 20 abgelaufen sind, dann führen Sie Schritt 1) erneut durch.
Dies ist ein einfacher probabilistischer Algorithmus. Wir gehen davon aus, dass der ausgewählte Schlüssel als Stichprobe aller Schlüssel mit Ablaufzeit verwendet werden kann. Durch die oben genannten Vorgänge können wir grundsätzlich feststellen, dass das Verhältnis von Schlüsseln mit Zeitüberschreitung zu Schlüsseln mit Zeitüberschreitung weniger als 25 % beträgt. Dann sollte der überschüssige Speicher, der von abgelaufenen Schlüsseln belegt wird, die nicht bereinigt wurden, weniger als 25 % betragen.
So handhaben Sie die Ablaufbereinigung in Replikations- und AOF-Dateien
Um die Konsistenz nicht zu zerstören, wird der DEL-Vorgang beim Ablaufen und Bereinigen eines Schlüssels mit der AOF-Datei und allen Replikaten synchronisiert Knoten. Auf diese Weise ist der Master-Knoten für die Ablaufbereinigung verantwortlich. Der Slave-Knoten verarbeitet die Ablaufbereinigung der Schlüssel nicht, sondern wartet nur auf den DEL-Befehl vom Master-Knoten, sodass die Schlüsselräume des Master-Knotens und Der Slave-Knoten bleibt konsistent.
Weitere Redis-Kenntnisse finden Sie in der Spalte Redis-Einführungs-Tutorial.
Das obige ist der detaillierte Inhalt vonEinstellungen für den Ablauf des Redis-Schlüssels. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!