本篇博客是redis系列的第6篇,主要讲解以下内容:
本系列的前5篇可以点击以下链接查看:
redis系列(三):redis的持久化机制(rdb、aof)
默认情况下,redis服务器有16个数据库,分别为db0~db15,如下图所示:
该数量是由配置文件中的databases
选项决定的,默认值为16:
默认情况下,我们执行的命令的目标数据库是db0,比如我们执行如下命令:
set message "hello,redis"
这个键值对会保存在数据库db0里,如下图所示:
如果想要切换目标数据库,可以使用select
命令,比如切换到db1,可以执行如下命令:
select 1
然后执行如下图所示的命令:
此时该键值对会保存在db1里,如下图所示:
在实际使用时,建议遵循以下规范:
redis提供了7个和key的过期时间相关的命令,分别如下所示:
接下来详细讲解每个命令的使用方法。
ttl
是time to live的缩写,用来查看某个key的剩余生存时间,单位为秒。
如果key没有设置过期时间,返回-1。
如果key不存在,返回-2。
pttl
和ttl
类似,也是用来查看某个key的剩余生存时间,但单位为毫秒。
如果key没有设置过期时间,返回-1。
如果key不存在,返回-2。
expire
命令用来给指定的key设置过期时间,单位为秒。
如果过期时间设置成功,返回1。
如果key不存在,返回0。
pexpire
与expire
类似,也是用来给指定的key设置过期时间,但单位为毫秒。
如果过期时间设置成功,返回1。
如果key不存在,返回0。
expireat
命令用来给指定的key设置过期时间,但指定的是某个时间点秒数的unix时间戳。
如果过期时间设置成功,返回1。
如果key不存在,返回0。
可以使用如下java代码获取秒数的时间戳:
system.out.println(localdatetime.now().plusminutes(2).toepochsecond(zoneoffset.ofhours(8)));
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());
persist
命令用来移除指定key的过期时间。
如果过期时间移除成功,返回1。
如果key不存在或者key没有设置过期时间,返回0。
黄健宏 《redis设计与实现》
如对本文有疑问, 点击进行留言回复!!
MongoDB中数据的替换方法实现类Replace()函数功能详解
理解Redis持久化,RDB持久化和AOF持久化的不同处理方式
网友评论