设为首页 加入收藏

TOP

关于Redis的常见面试题解析(二)
2019-09-17 18:39:14 】 浏览:63
Tags:关于 Redis 见面 试题 解析
key

第一次返回1 删除了 第二次返回0

 

Expire 设置过期时间(单位秒)

TTL查看剩下多少时间

返回负数则key失效,key不存在了

 

Setex

设置 key 对应的值为 string 类型的 value,并指定此键值对应的有效期。

 

Mset

一次设置多个 key 的值,成功返回 ok 表示所有的值都设置了,失败返回 0 表示没有任何值被设置。

 

Getset

设置 key 的值,并返回 key 的旧值。

 

Mget

一次获取多个 key 的值,如果对应 key 不存在,则对应返回 nil

 

Incr

key 的值做加加操作,并返回新的值。注意 incr 一个不是 int value 会返回错误,incr 一个不存在的 key,则设置 key 1

 

incrby

incr 类似,加指定值 ,key 不存在时候会设置 key,并认为原来的 value 0

 

Decr

key 的值做的是减减操作,decr 一个不存在 key,则设置 key -1

 

Decrby

decr,减指定值。

 

Append

给指定 key 的字符串值追加 value,返回新字符串值的长度。

 

Strlen

取指定 key value 值的长度。

persist xxx(取消过期时间)

选择数据库(0-15库)

Select 0 //选择数据库

move age 1//age 移动到1

Randomkey随机返回一个key

Rename重命名

Type 返回数据类型

 

 

6、使用过Redis分布式锁么,它是怎么实现的?

先拿setnx来争抢锁,抢到之后,再用expire给锁加一个过期时间防止锁忘记了释放。

如果在setnx之后执行expire之前进程意外crash或者要重启维护了,那会怎么样?

set指令有非常复杂的参数,这个应该是可以同时把setnxexpire合成一条指令来用的!

 

 

7、使用过Redis做异步队列么,你是怎么用的?有什么缺点?

一般使用list结构作为队列,rpush生产消息,lpop消费消息。当lpop没有消息的时候,要适当sleep一会再重试。

缺点:

在消费者下线的情况下,生产的消息会丢失,得使用专业的消息队列如rabbitmq等。

 

 8、什么是缓存穿透?如何避免?什么是缓存雪崩?何如避免?

缓存穿透

一般的缓存系统,都是按照key去缓存查询,如果不存在对应的value,就应该去后端系统查找(比如DB)。一些恶意的请求会故意查询不存在的key,请求量很大,就会对后端系统造成很大的压力。这就叫做缓存穿透。

如何避免?

1:对查询结果为空的情况也进行缓存,缓存时间设置短一点,或者该key对应的数据insert了之后清理缓存。

2:对一定不存在的key进行过滤。可以把所有的可能存在的key放到一个大的Bitmap中,查询时通过该bitmap过滤。

缓存雪崩

当缓存服务器重启或者大量缓存集中在某一个时间段失效,这样在失效的时候,会给后端系统带来很大压力。导致系统崩溃。

如何避免?

1:在缓存失效后,通过加锁或者队列来控制读数据库写缓存的线程数量。比如对某个key只允许一个线程查询数据和写缓存,其他线程等待。

2:做二级缓存,A1为原始缓存,A2为拷贝缓存,A1失效时,可以访问A2A1缓存失效时间设置为短期,A2设置为长期

3:不同的key,设置不同的过期时间,让缓存失效的时间点尽量均匀。

 

上海尚学堂Java大数据培训课程免费试学开启,redis学习资料视频免费领取哦~~~

首页 上一页 1 2 下一页 尾页 2/2/2
】【打印繁体】【投稿】【收藏】 【推荐】【举报】【评论】 【关闭】 【返回顶部
上一篇一场由like引发的事故 下一篇cache-fusion笔记

最新文章

热门文章

Hot 文章

Python

C 语言

C++基础

大数据基础

linux编程基础

C/C++面试题目