Redis系列(六):設置/移除鍵的過時時間

本篇博客是Redis系列的第6篇,主要講解如下內容:java

  1. 數據庫數量
  2. 切換目標數據庫
  3. 設置鍵的過時時間
  4. 移除鍵的過時時間

本系列的前5篇能夠點擊如下連接查看:redis

Redis系列(一):Redis簡介及環境安裝shell

Redis系列(二):Redis的5種數據結構及其經常使用命令數據庫

Redis系列(三):Redis的持久化機制(RDB、AOF)bash

Redis系列(四):Redis的複製機制(主從複製)服務器

Redis系列(五):Redis的過時鍵刪除策略數據結構

1. 數據庫數量

默認狀況下,Redis服務器有16個數據庫,分別爲db0~db15,以下圖所示:post

該數量是由配置文件中的databases選項決定的,默認值爲16:spa

2. 切換目標數據庫

默認狀況下,咱們執行的命令的目標數據庫是db0,好比咱們執行以下命令:設計

set message "Hello,Redis"
複製代碼

這個鍵值對會保存在數據庫db0裏,以下圖所示:

若是想要切換目標數據庫,能夠使用SELECT命令,好比切換到db1,能夠執行以下命令:

SELECT 1
複製代碼

而後執行以下圖所示的命令:

此時該鍵值對會保存在db1裏,以下圖所示:

在實際使用時,建議遵循如下規範:

  1. 各個應用使用不一樣的目標數據庫
  2. 1個應用盡可能不要操做多個目標數據庫

3. 設置/移除鍵的過時時間

Redis提供了7個和key的過時時間相關的命令,分別以下所示:

  1. TTL
  2. PTTL
  3. EXPIRE
  4. PEXPIRE
  5. EXPIREAT
  6. PEXPIREAT
  7. PERSIST

接下來詳細講解每一個命令的使用方法。

3.1 TTL

TTL是Time To Live的縮寫,用來查看某個key的剩餘生存時間,單位爲秒。

若是key沒有設置過時時間,返回-1。

若是key不存在,返回-2。

3.2 PTTL

PTTLTTL相似,也是用來查看某個key的剩餘生存時間,但單位爲毫秒。

若是key沒有設置過時時間,返回-1。

若是key不存在,返回-2。

3.3 EXPIRE

EXPIRE命令用來給指定的key設置過時時間,單位爲秒。

若是過時時間設置成功,返回1。

若是key不存在,返回0。

3.4 PEXPIRE

PEXPIREEXPIRE相似,也是用來給指定的key設置過時時間,但單位爲毫秒。

若是過時時間設置成功,返回1。

若是key不存在,返回0。

3.5 EXPIREAT

EXPIREAT命令用來給指定的key設置過時時間,但指定的是某個時間點秒數的UNIX時間戳。

若是過時時間設置成功,返回1。

若是key不存在,返回0。

能夠使用以下Java代碼獲取秒數的時間戳:

System.out.println(LocalDateTime.now().plusMinutes(2).toEpochSecond(ZoneOffset.ofHours(8)));
複製代碼

3.6 PEXPIREAT

PEXPIREATEXPIREAT相似,用來給指定的key設置過時時間,但指定的是點毫秒數的UNIX時間戳。

若是過時時間設置成功,返回1。

若是key不存在,返回0。

能夠使用以下Java代碼獲取毫秒數的時間戳:

System.out.println(System.currentTimeMillis());

System.out.println(LocalDateTime.now().plusMinutes(2).toInstant(ZoneOffset.ofHours(8)).toEpochMilli());
複製代碼

3.7 PERSIST

PERSIST命令用來移除指定key的過時時間。

若是過時時間移除成功,返回1。

若是key不存在或者key沒有設置過時時間,返回0。

4. 源碼及參考

黃健宏 《Redis設計與實現》

redis.io/commands

相關文章
相關標籤/搜索