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