亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Redis設(shè)置鍵的生存時(shí)間或過(guò)期時(shí)間的方法詳解

 更新時(shí)間:2024年03月21日 10:28:18   作者:coffee_babe  
這篇文章主要介紹了Redis如何設(shè)置鍵的生存時(shí)間或過(guò)期時(shí)間,通過(guò)EXPIRE命令或者PEXIPIRE命令,客戶(hù)端可以以秒或者毫秒精度為數(shù)據(jù)庫(kù)中的某個(gè)鍵設(shè)置生存時(shí)間,文中有詳細(xì)的代碼供供大家參考,需要的朋友可以參考下

鍵的生存時(shí)間或過(guò)期時(shí)間

概述

通過(guò)EXPIRE命令或者PEXIPIRE命令,客戶(hù)端可以以秒或者毫秒精度為數(shù)據(jù)庫(kù)中的某個(gè)鍵設(shè)置生存時(shí)間(Time To Live,TTL),在經(jīng)過(guò)指定的秒數(shù)或者毫秒數(shù)之后,服務(wù)器就會(huì)自動(dòng)刪除生存時(shí)間為0的鍵:

127.0.0.1:6379> SET key value
OK
127.0.0.1:6379> EXPIRE key 5
(integer) 1
// 5秒之內(nèi)
127.0.0.1:6379> GET key
"value"
// 5秒之后
127.0.0.1:6379> GET key
(nil)

注意:

SETEX命令可以在設(shè)置一個(gè)字符串鍵的同時(shí)為鍵設(shè)置過(guò)期時(shí)間,因?yàn)檫@個(gè)命令是一個(gè)類(lèi)型限定的命令(只能用于字符串鍵)
與EXPIRE命令和PEXPIRE命令類(lèi)似,客戶(hù)端可以通過(guò)EXPIREAT命令或PEXPIREAT命令,以秒或者毫秒精度給數(shù)據(jù)庫(kù)中的某個(gè)鍵設(shè)置過(guò)期時(shí)間(expire time)過(guò)期時(shí)間是一個(gè)UNIX時(shí)間戳,當(dāng)鍵的過(guò)期時(shí)間來(lái)臨時(shí),服務(wù)器就會(huì)自動(dòng)從數(shù)據(jù)庫(kù)中刪除這個(gè)鍵

127.0.0.1:6379> SET key value
OK
127.0.0.1:6379> EXPIREAT key 1710944249
(integer) 1
// 過(guò)期時(shí)間之前
127.0.0.1:6379> GET key
"value"
// 過(guò)期時(shí)間之后
127.0.0.1:6379> GET key
(nil)

TTL和PTTL

TTL命令和PTTL命令接受一個(gè)帶有生存時(shí)間或者過(guò)期時(shí)間的鍵,返回這個(gè)鍵的剩余生存時(shí)間,也就是,返回距離這個(gè)鍵被服務(wù)器自動(dòng)刪除還有多長(zhǎng)時(shí)間

127.0.0.1:6379> SET key value
OK
127.0.0.1:6379> EXPIRE key 1000
(integer) 1
127.0.0.1:6379> TTL key
(integer) 996

設(shè)置過(guò)期時(shí)間

Redis有四個(gè)不同的命令可以用于設(shè)置鍵key的生存時(shí)間(鍵可以存在多久)或過(guò)期時(shí)間(鍵什么時(shí)候會(huì)被刪除)

  • 1.EXPIRE 命令用于將鍵key的生存時(shí)間設(shè)置為ttl秒
  • 2.PEXPIRE命令用于將鍵key的生存時(shí)間設(shè)置為ttl毫秒
  • 3.EXPIREAT 命令用于將鍵key的過(guò)期時(shí)間設(shè)置為timestamp所指定的秒數(shù)時(shí)間戳
  • 4.PEXIREAT命令用于將鍵key的過(guò)期時(shí)間設(shè)置為timestamp所指定的毫秒數(shù)時(shí)間戳
    雖然有多種不同單位和不同形式的設(shè)置命令,但實(shí)際上EXPIRE、PEXIPIRE、EXPIREAT三個(gè)命令都是使用PEXIPREAT命令來(lái)實(shí)現(xiàn)的:無(wú)論客戶(hù)端執(zhí)行的是以上四個(gè)命令中的哪一個(gè),經(jīng)過(guò)轉(zhuǎn)換之后,最終的執(zhí)行效果都和執(zhí)行PEXIPIREAT命令一樣

內(nèi)部實(shí)現(xiàn)

首先,EXPIRE命令可以轉(zhuǎn)換成PEXIPIRE命令

def EXPIRE(key, ttl_in_sec):
#將TTL從秒轉(zhuǎn)換成毫秒
ttl_in_ms = sec_to_ms(ttl_in_ec)

接著,PEXIRE命令又可以轉(zhuǎn)換成PEXIREAT命令:

def PEXIPRE(key, ttl_in_ms):
# 獲取以毫秒計(jì)算的當(dāng)前UNIX時(shí)間戳
now_ms = get_curent_unix_timestamp_in_ms();
# 當(dāng)前時(shí)間加上TTL,得出毫秒格式的鍵過(guò)期時(shí)間
PEXIREAT(key,now_ms+ttl_in_ms)

并且,EXPIREAT命令也可以轉(zhuǎn)換成PEXIREAT命令:

def EXPIREAT (key, expire_time_in_sec):
# 將過(guò)期時(shí)間從秒轉(zhuǎn)換為毫秒
expire_time_in_ms = sec_to_ms(expire_time_in_sec)
PEXPIREAT(key, expire_tiime_in_ms);

最終,EXPIRE、PEXPIRE和EXPIREAT三個(gè)命令都會(huì)轉(zhuǎn)化成PEXIREAT命令來(lái)執(zhí)行

在這里插入圖片描述

保存過(guò)期時(shí)間

redisDb結(jié)構(gòu)的expire字典保存了數(shù)據(jù)庫(kù)中所有鍵的過(guò)期時(shí)間,我們稱(chēng)這個(gè)字典為過(guò)期字典:

  • 1.過(guò)期字典的鍵是一個(gè)指針,這個(gè)指針指向鍵是一個(gè)指針,這個(gè)指針指向鍵空間的某個(gè)鍵對(duì)象(也即是某個(gè)數(shù)據(jù)庫(kù)鍵)
  • 2.過(guò)期字典的值是一個(gè)long long類(lèi)型的整數(shù)。這個(gè)整數(shù)保存了鍵所指向的數(shù)據(jù)庫(kù)鍵的過(guò)期時(shí)間——一個(gè)毫秒精度的UNIX時(shí)間戳。
typedef struct redisDb {
 // ..
 
 // 過(guò)期字典,保存著鍵的過(guò)期時(shí)間
 dict *expire;
 
 // ...
}redisDb;

例子

在這里插入圖片描述

舉個(gè)例子,圖中的過(guò)期字典保存了兩個(gè)鍵值對(duì):
1.第一個(gè)鍵值對(duì)的鍵為alphabet鍵對(duì)象,值為1385877900000,這表示數(shù)據(jù)庫(kù)鍵alphabet的過(guò)期時(shí)間為1385877600000(2013年12月)
2.第二個(gè)鍵值對(duì)的鍵為book鍵對(duì)象,值為1388556000000,這表示數(shù)據(jù)庫(kù)鍵book的過(guò)期時(shí)間為1388556000000(2014年1月1日零時(shí))當(dāng)客戶(hù)端執(zhí)行PEXPIREAT命令(或者其他三個(gè)會(huì)轉(zhuǎn)換成PEXIPREAT命令的命令)為一個(gè)
數(shù)據(jù)庫(kù)鍵設(shè)置過(guò)期時(shí)間時(shí),服務(wù)器會(huì)在數(shù)據(jù)庫(kù)的過(guò)期字典中關(guān)聯(lián)給定的數(shù)據(jù)庫(kù)和過(guò)期時(shí)間

讀寫(xiě)鍵空間時(shí)的維護(hù)操作

當(dāng)使用Redis命令對(duì)數(shù)據(jù)庫(kù)進(jìn)行讀寫(xiě)時(shí),服務(wù)器不僅會(huì)對(duì)鍵空間執(zhí)行指定的讀寫(xiě)操作還會(huì)執(zhí)行一些額外的維護(hù)操作,其中包括

  • 在讀取一個(gè)鍵之后(讀操作和寫(xiě)操作都要對(duì)鍵進(jìn)行讀取),服務(wù)器會(huì)根據(jù)鍵是否存在來(lái)更新服務(wù)器的鍵空間命中(hit)次數(shù)或鍵空間不命中(miss)次數(shù),這兩個(gè)值可以在INFO stats命令的keyspace_hits屬性和keyspace_misses屬性中查看
127.0.0.1:6379> info stats
# Stats
total_connections_received:15
total_commands_processed:1887
instantaneous_ops_per_sec:0
total_net_input_bytes:9624
total_net_output_bytes:2803
instantaneous_input_kbps:0.00
instantaneous_output_kbps:0.00
rejected_connections:0
sync_full:0
sync_partial_ok:0
sync_partial_err:0
expired_keys:3
evicted_keys:0
keyspace_hits:38
keyspace_misses:11
pubsub_channels:0
pubsub_patterns:0
latest_fork_usec:9925
migrate_cached_sockets:0
127.0.0.1:6379>
  • 在讀取一個(gè)鍵之后,服務(wù)器會(huì)更新鍵的LRU(最后一次使用)時(shí)間,這個(gè)值可以用于計(jì)算鍵的閑置時(shí)間,使用OBJECT idle time key命令可以查看鍵的閑置時(shí)間。
127.0.0.1:6379> set k v
OK
127.0.0.1:6379> OBJECT idletime k
(integer) 6
  • 如果服務(wù)器在讀取一個(gè)鍵時(shí)發(fā)現(xiàn)該鍵已經(jīng)過(guò)期,那么服務(wù)器會(huì)先刪除這個(gè)過(guò)期鍵然后才執(zhí)行余下的操作
  • 如果又客戶(hù)端使用WATCH命令監(jiān)視了某個(gè)鍵,那么服務(wù)器在對(duì)被監(jiān)視的鍵進(jìn)行修改之后,會(huì)將這個(gè)鍵標(biāo)記為臟(dirty),從而讓事務(wù)程序注意到這個(gè)鍵已經(jīng)被修改過(guò)
  • 服務(wù)器每次修改一個(gè)鍵之后,都會(huì)對(duì)臟(dirty)鍵計(jì)數(shù)器的值增1,這個(gè)計(jì)數(shù)器會(huì)觸發(fā)服務(wù)器的持久化以及復(fù)制操作
  • 如果服務(wù)器開(kāi)啟了數(shù)據(jù)庫(kù)通知功能,那么在對(duì)鍵進(jìn)行修改之后,服務(wù)器將按配置發(fā)送相應(yīng)的數(shù)據(jù)庫(kù)通知

以上就是Redis設(shè)置鍵的生存時(shí)間或過(guò)期時(shí)間的方法詳解的詳細(xì)內(nèi)容,更多關(guān)于Redis設(shè)置鍵生存或過(guò)期時(shí)間的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • Redis的4種緩存模式分享

    Redis的4種緩存模式分享

    這篇文章主要介紹了Redis的4種緩存模式分享,文章圍繞主題展開(kāi)詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,感興趣的小伙伴可以參考一下
    2022-07-07
  • Redis設(shè)置key的過(guò)期時(shí)間

    Redis設(shè)置key的過(guò)期時(shí)間

    本文主要介紹了Redis設(shè)置key的過(guò)期時(shí)間,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2023-01-01
  • Redis集群詳解

    Redis集群詳解

    這篇文章主要介紹了Redis集群詳解,需要的朋友可以參考下
    2020-07-07
  • redis?哨兵集群搭建的實(shí)現(xiàn)

    redis?哨兵集群搭建的實(shí)現(xiàn)

    本文主要介紹了redis?哨兵集群搭建的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2022-08-08
  • Redis事務(wù)處理的使用操作方法

    Redis事務(wù)處理的使用操作方法

    Redis保證一個(gè)事務(wù)中的所有命令要么都執(zhí)行,要么都不執(zhí)行(原子性),如果客戶(hù)端發(fā)送了EXEC命令,所有的命令就都會(huì)被執(zhí)行,即使此后客戶(hù)端斷線(xiàn)也沒(méi)關(guān)系,因?yàn)镽edis中已經(jīng)記錄了所有要執(zhí)行的命令,下面通過(guò)本文給大家介紹Redis事務(wù)處理的使用操作,感興趣的朋友一起看看吧
    2021-10-10
  • Redis分布式鎖的幾種實(shí)現(xiàn)方法

    Redis分布式鎖的幾種實(shí)現(xiàn)方法

    本文主要介紹了Redis分布式鎖的幾種實(shí)現(xiàn)方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2025-04-04
  • 分布式鎖三種實(shí)現(xiàn)方式及對(duì)比

    分布式鎖三種實(shí)現(xiàn)方式及對(duì)比

    這篇文章主要介紹了分布式鎖三種實(shí)現(xiàn)方式及對(duì)比,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-04-04
  • 如何監(jiān)聽(tīng)Redis中Key值的變化(SpringBoot整合)

    如何監(jiān)聽(tīng)Redis中Key值的變化(SpringBoot整合)

    測(cè)試過(guò)程中我們有一部分常量值放入redis,共大部分應(yīng)用調(diào)用,但在測(cè)試過(guò)程中經(jīng)常有人會(huì)清空redis,回歸測(cè)試,下面這篇文章主要給大家介紹了關(guān)于如何監(jiān)聽(tīng)Redis中Key值變化的相關(guān)資料,需要的朋友可以參考下
    2024-03-03
  • 簡(jiǎn)介Redis中的showlog功能

    簡(jiǎn)介Redis中的showlog功能

    這篇文章主要介紹了簡(jiǎn)介Redis中的showlog功能,作者同時(shí)對(duì)比了DEL命令的性能,需要的朋友可以參考下
    2015-06-06
  • Windows下安裝Redis的流程詳解

    Windows下安裝Redis的流程詳解

    Redis作為常用開(kāi)源的非關(guān)系型數(shù)據(jù)庫(kù),是開(kāi)發(fā)中常用的數(shù)據(jù)庫(kù)之一,很多朋友不清楚Windows下安裝Redis的過(guò)程,今天小編通過(guò)分享本文給大家介紹詳細(xì)過(guò)程,一起看看吧
    2021-08-08

最新評(píng)論