Redis面试题

1. Redis有哪些数据类型,各有什么用?

(1) string

简单的set,get,做简单的KV缓存

(2)hash

可以将某个结构化的对象给缓存在redis里;可获得单独某个字段

hset,hget

(3) list

有序列表;

lpush mylist 1;

(4)set

无序集合自动去重,可以用来分布式环境下去重

添加一个元素:sadd mySet 1

(5)sortedSet

有序集合去重并排序

zrange board 0 3(升序获得前三个元素)

2. redis过期策略:

定时删除(隔一段时间随机选取某些Key删除)、惰性删除(当查询这个key发现已过期时删除)

3. redis内存淘汰机制

(1)内存满时,新写入报错

(2)在全部键空间/在设置了过期时间的键空间删除最近最少使用的key

  (3)   在全部键空间/在设置了过期时间的键空间随机移除某个Key

  (4)   在设置了过期时间的键空间中删除更早过期时间的key

4. redis高可用

采用redis的主从架构,即一主多从,单主用来写入数据(单机几万QPS),多从用来读取数据(10多万QPS)

如果需要更高的QPS则可以继续使用集群模式

5. redis持久化

(1) RDB:定时存储快照的方式

缺点:快照文件隔较长时间生成一次,宕机会造成数据丢失;

(2) AOF: 存储每条指令的方式

缺点:每隔一秒执行,会造成一定开销,性能不如RDB;

6. redis集群

redis集群基于指派槽的思想,即每个master认领16384个槽中的某些槽;

高可用:

当一个master节点下线,其slave会相互选举出一个新的master,采用的方式是:每个slave相别的slave发命令说选我,slave选择最先命令到达的slave作为master,哪个slave得票大于n/2+1,就成为新的master;

7.缓存雪崩 、缓存穿透、缓存击穿

(1) 缓存雪崩:

大量的键在同一时间过期,导致大量的数据达到数据库,总而造成数据库崩溃;

解决方案:键的过期时间设的分散些,或者设成永久;

(2)缓存穿透:

比如黑客频繁查询一个不存在的key,查询的键在redis中查不到,db中也查不到,导致数据库奔溃

解决方案:对于这样的键在请求分布式锁,在redis中设置一个特殊的占位符,再释放锁

(3)缓存击穿

某个键非常热门,访问频繁,当这个键过期时,大量请求打到数据库;

解决方案:请求分布式锁,从数据库回源相关信息,从新设置缓存,再释放锁

8. 如何保证数据库和缓存的双写一致性

读的时候,先读缓存,缓存读不到再读数据库,然后取出数据放入缓存;

写的时候,先写数据库,然后删除缓存;

9. redis并发竞争

使用zookeeper获得一个分布式锁

参考:https://juejin.im/post/5ea69dacf265da716c0c18af#heading-25

 

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值