本篇博客是Redis系列的第6篇,主要讲解以下内容:
- 数据库数量
- 切换目标数据库
- 设置键的过期时间
- 移除键的过期时间
本系列的前5篇可以点击以下链接查看:
Redis系列(三):Redis的持久化机制(RDB、AOF)
1. 数据库数量
默认情况下,Redis服务器有16个数据库,分别为db0~db15,如下图所示:
该数量是由配置文件中的databases
选项决定的,默认值为16:
2. 切换目标数据库
默认情况下,我们执行的命令的目标数据库是db0,比如我们执行如下命令:
set message "Hello,Redis"
复制代码
这个键值对会保存在数据库db0里,如下图所示:
如果想要切换目标数据库,可以使用SELECT
命令,比如切换到db1,可以执行如下命令:
SELECT 1
复制代码
然后执行如下图所示的命令:
此时该键值对会保存在db1里,如下图所示:
在实际使用时,建议遵循以下规范:
- 各个应用使用不同的目标数据库
- 1个应用尽量不要操作多个目标数据库
3. 设置/移除键的过期时间
Redis提供了7个和key的过期时间相关的命令,分别如下所示:
- TTL
- PTTL
- EXPIRE
- PEXPIRE
- EXPIREAT
- PEXPIREAT
- PERSIST
接下来详细讲解每个命令的使用方法。
3.1 TTL
TTL
是Time To Live的缩写,用来查看某个key的剩余生存时间,单位为秒。
如果key没有设置过期时间,返回-1。
如果key不存在,返回-2。
3.2 PTTL
PTTL
和TTL
类似,也是用来查看某个key的剩余生存时间,但单位为毫秒。
如果key没有设置过期时间,返回-1。
如果key不存在,返回-2。
3.3 EXPIRE
EXPIRE
命令用来给指定的key设置过期时间,单位为秒。
如果过期时间设置成功,返回1。
如果key不存在,返回0。
3.4 PEXPIRE
PEXPIRE
与EXPIRE
类似,也是用来给指定的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
PEXPIREAT
与EXPIREAT
类似,用来给指定的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设计与实现》