1.简介
- 字符串键值结构(key value)
- value的值小于512m,一般建议一个key-value的大小为100k
- 使用场景
- 缓存
- 计数器
- 分布式锁
2.命令
- 设置key-value
- 不管key是否存在都设置
set key value
- key不存在才设置
setnx key value
- key存在才设置
set key value xx
时间复杂度为O(1)
- 获取key对应的value
get key
时间复杂度为O(1)
- key自增1,如果key不存在,自增后key的值为1
incr key
时间复杂度为O(1)
- key自减1,如果key不存在,自增后key的值为-1
decr key
时间复杂度为O(1)
- key自增k,如果key不存在,自增后key的值为k
incrby key k
时间复杂度为O(1)
- key自减k,如果key不存在,自增后key的值为-k
decrby key k
时间复杂度为O(1)
- 设置新值并返回旧值
getset key newvalue
时间复杂度为O(1)
- 将value值追加到旧的value
append key value
时间复杂度为O(1)
- 返回字符串的长度(注意中文)
strlen key
时间复杂度为O(1)
- 浮点类型增加操作
incrbyfloat key floatvalue
时间复杂度为O(1)
- 获取字符串指定下标所有值
getrange key start end
时间复杂度为O(1)
- 设置指定下标所有对应的值
setrange key index value
时间复杂度为O(1)
3.实战
(1).使用场景
缓存视频的基本信息(数据源在MySql中)。
(2).缓存步骤
- 定义key
- 从Redis中获取key对应的value
- 如果value为空,则去MySql中获取视频的基本信息,然后缓存在Redis中,如果value不为空则直接返回视频基本信息给用户
(3).伪代码
public VideoInfo get(int id){
String redisKey = redisPrefix + id;
VideoInfo videoInfo = redis.get(redisKey);
if(videoInfo == null){
videoInfo = mysql.get(id);
if(videoInfo != null){
redis.set(redisKey,serialize(videoInfo));
}
}
return videoInfo;
}