Redis EXPIRE hash Key

Redis Expire Hash Key



Redis räsid on eritüüpi andmetüüp, mis on palju sarnasem JSON-objekti, Java HashMapi või Pythoni sõnastikuga. Lisaks on see välja-väärtuste paaride kogum, mida saab kasutada domeeniobjektide modelleerimiseks. Redise räsiandmete struktuur on äärmiselt mälutõhus, kus iga räsivõti suudab salvestada kuni neli miljardit välja-väärtuste paari. Kõige tähtsam on see, et põhilised räsioperatsioonid, nagu HSET, HGET, HMGET jne, töötavad pideva aja keerukusega.


Redis räsivõtmetel on lõpmatu eluiga (TTL), mis tähendab, et need on püsivad, need kustutatakse selgesõnaliselt selliste käskude nagu DEL abil. Selles artiklis keskendume Redis räsi TTL-i seadistamisele, kasutades käsku EXPIRE.







Redis EXPIRE käsk

Käsku EXPIRE kasutatakse Redise räsi, komplekti, loendi jne võtmele ajalõpu määramiseks. Redise võti kustutatakse andmebaasist, kui aeg aegub. Kõige tähtsam on see, et ajalõpp jääb kustutamata, kuni võtme sisu kustutatakse või üle kirjutatakse. Võtmega seotud väärtuste muutmine ei mõjuta aegumisaega.



Käsu EXPIRE süntaks on järgmine:



Võti EXPIRE aegumise_aeg_sekundid [ NX | GX | GT | LT ]


võti: Räsi, loendi või komplekti võti, mille jaoks peate ajalõpu määrama.





expirty_time_seconds: Ajalõpu väärtus sekundites.

Käsk EXPIRE aktsepteerib mitmeid valikulisi argumente.



NX: Ajalõpu väärtus määratakse ainult siis, kui määratud võtmel pole juba aegumist.

XX: Kui määratud võtmel on olemasolev ajalõpu väärtus, määratakse uus aegumisaeg.

GT: Kui uus aegumisväärtus on suurem kui olemasolev, määratakse uus aegumisaeg.

LT: Uus ajalõpu väärtus määratakse juhul, kui olemasolev väärtus on suurem kui uus.

Kõige tähtsam on see, et käsk EXPIRE töötab pideva aja keerukusega. Kui käsu täitmine õnnestub, tagastatakse täisarv 1. Kui toiming nurjub valede argumentide või olematute võtmete tõttu, tagastatakse 0.

Kasutame räsidel käsku EXPIRE, et määrata aegumisaeg, nagu on näidatud järgmises jaotises:

Aegutage Redis Hash, kasutades käsku EXPIRE

Oletame, et seansi teave kasutaja kohta on salvestatud Redise räsi session:id:1000:user:10. Käsku HMSET saame kasutada mitme välja-väärtuse paariga Redise räsi loomiseks järgmiselt:

hmset seanss:id: 1000 :kasutaja: 10 kasutajanimi 'jae' küpsis 'jah' parool '389Ysu2'


Kontrollime loodud räsi, kasutades käsku HGETALL.

hgetall session:id: 1000 :kasutaja: 10



Lisaks aegub seanss 10 sekundi pärast, kui kasutaja ei ole enam kui 60 sekundit jõude. Seansi aegumine saavutatakse seansi teavet salvestava räsi aegumisaja määramisega.

Käsku EXPIRE saame kasutada järgmiselt:

aegumise seanss:id: 1000 :kasutaja: 10 10


Nagu mainitud, on ajalõpu väärtuseks seatud 10 sekundit.


Ootuspäraselt on tagastusväärtus 1, mis tähendab, et TTL on räsi jaoks edukalt seadistatud. Kontrollime aega, mis on jäänud enne räsivõtme Redise poest eemaldamist. TTL-käsku saab kasutada järgmiselt:

ttl seanss:id: 1000 :kasutaja: 10



Nagu väljundis näidatud, on jäänud kolm sekundit enne räsi automaatset eemaldamist. 10 sekundi pärast on TTL-käsu väljund järgmine:


Kuna on näidatud täisarvuline vastus -2, pole räsi olemas.

Määrake aegumisaja olemasolu aegumisaja järgi

Käsk EXPIRE aktsepteerib NX- ja XX-argumente, et määrata kindlaksmääratud räsi aegumise olemasolu põhjal uus ajalõpp. Loome rakendusega uue räsi noTimeOut võti .

hmset noTimeOut nimi 'test'


Proovime määrata eelmisele räsile uue aegumise. Lisaks edastame argumendi XX ka käsule EXPIRE.

aeguma noTimeOut viisteist XX


Kuna me täpsustame XX suvandit käsus, aegumisaega ei määrata. Valik XX ei võimalda teil määrata uut aegumisaega, kui määratud räsivõtmega pole seotud olemasolevat ajalõppu.


Kui me kasutame NX suvandi korral on ajalõpu väärtuseks seatud 15.

aeguma noTimeOut viisteist NX



Käsk EXPIRE tagastab täisarvu 1 vastuse, mis tähendab, et ajalõpp on õigesti seadistatud.

Seadke ajalõpp olemasoleva ajalõpu väärtuse põhjal

GT ja LT valikuid saab kasutada räsi aegumise aja määramiseks olemasoleva ajalõpu pikkuse alusel.

Loome uue räsi nimega hashWithTimeout.

hmset hashWithTimeout field1 väärtus1


Järgmisena määrame räsi aegumisaja 200 sekundit.

aeguma hashWithTimeout 200


Proovime määrata räsi jaoks uue 100-sekundilise ajalõpu koos valikuga GT järgmiselt:

aeguma hashWithTimeout 100 GT


Kuna suvand GT on määratud, kontrollib käsk EXPIRE, kas uus ajalõpu väärtus on suurem kui olemasolev ja määrab uue aegumisaja. Selles näites ei ole uus ajalõpp suurem kui olemasolev ajalõpp. Seetõttu ei määra käsk uut aegumisaega ja tagastatakse 0.


Kasutame GT asemel LT valikut. Kuna uus aegumisaeg on praegusest madalam, peaks järgmine käsk uue ajalõpu edukalt seadistama.

aeguma hashWithTimeout 100 LT


Järeldus

Lühidalt, Redis EXPIRE käsku kasutatakse antud võtme jaoks TTL väärtuse määramiseks. Vaikimisi ei ole Redise räsivõtmed seotud ühegi ajalõpuga, mida nimetatakse püsimatuks. Nagu arutatud, kasutatakse Redise räsi ajalõpu väärtuse määramiseks käsku EXPIRE. Tavaliselt kustutatakse räsi Redise andmesalvest pärast ajalõpu väärtuseks määratud aja möödumist. Nagu näidetes näidatud, aktsepteerib käsk EXPIRE mõningaid valikulisi argumente, nagu XX, NX, GT ja LT, et määrata räsi aegumise aeg vastavalt tingimusele.