Redis EXPIRE Hash Key

Redis Expire Hash Key



Hash Redis הם סוג מיוחד של סוג נתונים שדומה הרבה יותר לאובייקט JSON, Java HashMap או מילון Python. יתר על כן, זהו אוסף של צמדי שדה-ערך שניתן להשתמש בהם כדי לדגמן אובייקטי תחום. מבנה נתוני הגיבוב של Redis יעיל ביותר בזיכרון כאשר כל מפתח hash יכול לאחסן עד ארבעה מיליארד זוגות ערכי שדה. והכי חשוב, פעולות הגיבוב הבסיסיות כמו HSET, HGET, HMGET וכו' פועלות במורכבות זמן קבועה.


למפתחות ה-Hash של Redis יש אינסוף זמן לחיות (TTL) מה שאומר שהם מתמידים, הם נמחקים במפורש באמצעות פקודות כמו DEL. במאמר זה, נתמקד בהגדרת ה-TTL עבור הגיבובים של Redis באמצעות הפקודה EXPIRE.







Redis פקודת EXPIRE

הפקודה EXPIRE משמשת כדי להגדיר פסק זמן על מפתח נתון של hash Redis, סט, רשימה וכו'. מפתח Redis נמחק ממסד הנתונים אם פג תוקף הזמן הקצוב. והכי חשוב, הזמן הקצוב לא נמחק עד שתוכן המפתח נמחק או מוחלף. שינוי הערכים המשויכים למפתח אינו משפיע על זמן התפוגה.



התחביר של הפקודה EXPIRE הוא כדלקמן:



מפתח EXPIRE expiry_time_seconds [ NX | GX | GT | LT ]


מַפְתֵחַ: המפתח של Hash, List או Set שאתה צריך כדי להגדיר פסק זמן.





תפוגה_זמן_שניות: ערך הזמן הקצוב בשניות.

מספר ארגומנטים אופציונליים מתקבלים על ידי הפקודה EXPIRE.



NX: ערך הזמן הקצוב נקבע רק אם למפתח שצוין אין כבר תוקף.

XX: כאשר למפתח שצוין יש ערך זמן קצוב קיים, תאריך התפוגה החדש מוגדר.

GT: אם ערך הזמן הקצוב החדש גדול מהקיים, תאריך התפוגה החדש מוגדר.

LT: ערך הזמן הקצוב החדש נקבע אם הקיים גדול מהחדש.

והכי חשוב, הפקודה EXPIRE פועלת על מורכבות זמן קבועה. המספר השלם 1 מוחזר אם ביצוע הפקודה מצליח. אם הפעולה נכשלת עקב ארגומנטים שגויים או מפתחות לא קיימים, 0 מוחזר.

אנו נשתמש בפקודה EXPIRE ב-hash כדי להגדיר זמן תפוגה כפי שמוצג בסעיף הבא:

פג תוקף Redis Hash באמצעות פקודת EXPIRE

נניח שמידע הפעלה לכל משתמש מאוחסן ב-Hash של Redis session:id:1000:user:10. אנו יכולים להשתמש בפקודה HMSET כדי ליצור Hash Redis עם צמדי שדה-ערך מרובים באופן הבא:

hmset session:id: 1000 :מִשׁתַמֵשׁ: 10 שם משתמש 'ג'יי' עוגייה 'כן' סיסמה '389Ysu2'


בואו נבדוק את ה-hash שנוצר באמצעות הפקודה HGETALL.

hgetall session:id: 1000 :מִשׁתַמֵשׁ: 10



בנוסף, תוקף ההפעלה יפוג לאחר 10 שניות אם המשתמש לא פעיל יותר מ-60 שניות. תפוגת הפעלה מושגת על ידי הגדרת זמן התפוגה עבור ה-hash המאחסן את פרטי ההפעלה.

אנו יכולים להשתמש בפקודה EXPIRE באופן הבא:

expire session:id: 1000 :מִשׁתַמֵשׁ: 10 10


כאמור, ערך הזמן הקצוב מוגדר ל-10 שניות.


כצפוי, ערך ההחזרה הוא 1 מה שאומר שה-TTL מוגדר בהצלחה עבור ה-hash. בואו נבדוק את הזמן שנותר לפני שמפתח ה-hash יוסר מחנות Redis. ניתן להשתמש בפקודת TTL באופן הבא:

ttl session:id: 1000 :מִשׁתַמֵשׁ: 10



כפי שמוצג בפלט, נותרו שלוש שניות לפני הסרת ה-hash באופן אוטומטי. לאחר 10 שניות, פלט פקודת TTL הוא כדלקמן:


מכיוון שהתשובה במספר שלם -2 מסומנת, ה-hash לא קיים.

הגדר זמן קצוב על סמך קיומו של זמן תפוגה

הפקודה EXPIRE מקבלת ארגומנטים NX ו-XX כדי להגדיר פסק זמן חדש בהתבסס על קיומו של תפוגה עבור hash שצוין. בואו ניצור hash חדש עם ה- noTimeOut מַפְתֵחַ .

שם hmset noTimeOut 'מִבְחָן'


בואו ננסה להגדיר תפוגה חדשה ל-hash הקודם. בנוסף, אנו מעבירים את הארגומנט XX לפקודת EXPIRE גם כן.

יפוג noTimeOut חֲמֵשׁ עֶשׂרֵה XX


מכיוון שאנו מציינים את XX אפשרות בפקודה, זמן התפוגה לא יוגדר. האפשרות XX אינה מאפשרת לך להגדיר זמן תפוגה חדש אם אין פסק זמן קיים המשויך למפתח ה-hash שצוין.


אם נשתמש ב NX אפשרות, ערך הזמן הקצוב מוגדר ל-15.

יפוג noTimeOut חֲמֵשׁ עֶשׂרֵה NX



הפקודה EXPIRE מחזירה את תשובת המספר השלם 1, כלומר פסק הזמן מוגדר כהלכה.

הגדר זמן קצוב על סמך ערך הזמן הקצוב הקיים

ניתן להשתמש באפשרויות GT ו-LT כדי להגדיר את זמן תפוגת ה-hash בהתבסס על אורך הזמן הקצוב הקיים.

בואו ניצור hash חדש בשם hashWithTimeout.

hmset hashWithTimeout field1 value1


לאחר מכן, הגדרנו זמן תפוגה של 200 שניות עבור ה-hash.

expire hashWithTimeout 200


בואו ננסה להגדיר פסק זמן חדש של 100 שניות עבור ה-hash יחד עם אפשרות GT באופן הבא:

expire hashWithTimeout 100 GT


מאז שצוינה אפשרות GT, הפקודה EXPIRE תבדוק אם ערך הזמן הקצוב החדש גדול מהקיים ותגדיר את זמן התפוגה החדש. בדוגמה זו, הזמן הקצוב החדש אינו גדול מהזמן הקצוב הקיים. לפיכך, הפקודה לא תגדיר את זמן התפוגה החדש ו-0 יוחזר.


בואו נשתמש באפשרות LT במקום GT. מכיוון שזמן התפוגה החדש נמוך מהנוכחי, הפקודה הבאה אמורה להגדיר בהצלחה את הזמן הקצוב החדש.

expire hashWithTimeout 100 LT


סיכום

בקיצור, הפקודה Redis EXPIRE משמשת להגדרת ערך TTL עבור מפתח נתון. כברירת מחדל, מפתחות הגיבוב של Redis אינם משויכים לזמן קצוב כלשהו שנקרא לא נדיף. כפי שצוין, הפקודה EXPIRE משמשת להגדרת ערך פסק זמן ב-Hash Redis. בדרך כלל, ה-hash נמחק ממאגר הנתונים של Redis לאחר פרק הזמן שצוין כערך פסק זמן. כפי שמוצג בדוגמאות, הפקודה EXPIRE מקבלת כמה ארגומנטים אופציונליים כמו XX, NX, GT ו-LT כדי להגדיר את תפוגת ה-hash בהתבסס על תנאי.