對於修改String,redis有:set、setex、append 、incr、decr等,其中,使用set、setex來修改原來存在的String,會重置原來設定過的過期時間,嚴格來說set、setex不是“修改”,而是覆蓋,所以原來設定過的key-value,再次set/setex這個key就會覆蓋掉原來的。使用try redis測試結果如下:
如果使用append、incr、decr等指令來修改,並不會重設原來的過期時間:
所以,對於string 結構,只要進行set /setex指令,就會重置過期時間,而set指令會直接把過期時間變成永不過期。
例如我在7:00設定了一個{key1:value} ,過期時間為30分鐘,在7:00-7:30期間多次set/setex這個key 的value,這個key1 的過期時間都會重置,最終不會在7:30過期。如何確保每次設定這個過期鍵後不刷新過期時間,穩定在7:30過期?
方法一:
使用 計時器,第一次 set 的時候就建立一個計時器,到期就把這個 key 刪除。這種方法在資料量大時會比較佔用cpu資源,不建議。
方法二:
每次setex key的value 之前,先返回此時key的剩餘過期時間,在setex時把這個剩餘的過期時間賦給這個key 作為新的過期時間,就可以解決。
以Spring專案為例,利用redisTemplate.getExpire(String key) 方法傳回的剩餘過期時間戳記(毫秒等級)可以解決,本質上是給redis 傳送PTTL 指令,以傳回毫秒為單位的key的剩餘過期時間。
程式碼範例:
讓key1 每次修改都保持第一次設定時的過期時間
//获取key1的剩余时间的时间戳 Long expire = redisTemplate.getExpire("key1"); //最后一个参数可以选秒、毫秒(TimeUnit.MILLISECONDS),Redis最多只能返回毫秒级别的key的剩余过期时间 redisTemplate.opsForValue().set(key, value, expire, TimeUnit.SECONDS);
String類型的K-V 的有效期會隨著的value 值的修改,重新計時:
如存在一個K-V ,過期時間為30秒, 如果把value 值修改,則過期時間就會重設為30秒,而不是在原來設定的時間減去已經流失的時間。
除了string資料結構,對其他資料結構進行修改,不會重置過期時間
例如hash、set、Zset、list等:
以hash為範例:
#hash 的有效期限不會隨著hash 欄位值的修改重新計時。
如果需要重新計時,則需要在修改欄位值的時候,重新指定有效期限。
以上是redis過期時間的問題怎麼解決的詳細內容。更多資訊請關注PHP中文網其他相關文章!