1.Key命令
设置key的过期时间。
expire key second:设置key的过期时间
ttl key:查看key的有效期(如果显示正数说明该key正在倒计时,如果是-1说明该key永久保存,是持久化的,如果是-2该key不存在)
persist key:清除key的过期时间。key持久化
使用场景:电商活动有时间限制
2.Redis的持久化方案
redis的所有数据都是保存到内存中。
Rdb:快照形式,定期把内存中当前时刻的数据保存到磁盘。redis默认支持到持久化方案。
aof形式:append only file。把所有对redis数据库操作的命令,增删改操作的命令。保存到文件中。数据库恢复时把所有的命令执行一遍即可。
在redis.conf配置文件中配置。
Rdb:
Aof的配置:
两种持久化方案同时开启使用aof文件来恢复数据库。但是开启redis持久化。会影响redis数据库性能,所以一般默认不开启持久化
3.Redis的特性
3.1 多数据库
一个redis实例可以包含多个数据库,客户端可以指定连接某个redis实例的哪个数据库,就如同一个mysql中创建了多个数据库,客户端连接时指定连接哪个数据库。
可以根据redis的图形化界面,看到一个redis实例最多提供16个数据库,下表从0到15,客户端默认链接第0号数据库,也可以通过select选择链接那个数据库:
以下是连接库的命令
连接1号库:
连接2号库
将key一直到1号库:
3.2 消息订阅与发布
(1) subscribe channel:订阅频道,例:subscribe mychat,订阅mychat这个频道
(2) psubscribe channel*:批量订阅频道,例:psubscribe s*,订阅以"s"开头的频道
(3) publish channel content:在指定的频道中发布消息,例:publish mychat 'today is a newday'
步骤:
(1) 在第一个连接中,订阅cctv频道。此时如果没有人"发布"消息,当前窗口处于等待状态
(2) 在另个连接窗口中,在cctv频道中发布消息(这种消息订阅与发布的实时性很强)
3.3 redis事务
命令解释:
(1)multi:开启事务用于标记事务的开始,其后执行的命令都将被存入命令队列,直到执行exec时,这些命令才会被原子的执行,类似于关系型数据库中的:begin transaction
(2)exec:提交事务,类似于关系型数据库中commit
(3)discard:事务回滚,类似与关系型数据中的rollback