Redis面试热点问题

2019-08-10  本文已影响0人  柳蒿

为什么要用 redis 而不用 map/guava 做缓存?

redis 和 memcached 的区别

redis 设置过期时间

过期删除清理缓存很慢,导致没有多余的内存空间,redis会怎么处理——redis内存淘汰机制


4.0版本后增加以下两种:

redis持久化机制

缓存雪崩

简介:缓存同一时间大面积的失效,所以,后面的请求都会落到数据库上,造成数据库短时间内承受大量请求而崩掉。

解决办法

缓存穿透

简介:一般是黑客故意去请求缓存中不存在的数据,导致所有的请求都落到数据库上,造成数据库短时间内承受大量请求而崩掉。

解决办法: 有很多种方法可以有效地解决缓存穿透问题,最常见的则是采用布隆过滤器,将所有可能存在的数据哈希到一个足够大的bitmap中,一个一定不存在的数据会被 这个bitmap拦截掉,从而避免了对底层存储系统的查询压力。另外也有一个更为简单粗暴的方法(我们采用的就是这种),如果一个查询返回的数据为空(不管是数 据不存在,还是系统故障),我们仍然把这个空结果进行缓存,但它的过期时间会很短,最长不超过五分钟

Redis 的并发竞争 Key 问题

简介:所谓Redis的并发竞争Key的问题也就是多个系统同时对一个key 进行操作,但是最后执行的顺序和我们期望的顺序不同,这样也就导致了结果的不同!

解决办法:分布式锁(zookeeper 和 redis 都可以实现分布式锁)。(如果不存在 Redis 的并发竞争 Key 问题,不要使用分布式锁,这样会影响性能)

如何保证缓存与数据库双写时的数据一致性?

一般来说,就是如果你的系统不是严格要求缓存+数据库必须一致性的话,缓存可以稍微的跟数据库偶尔有不一致的情况,最好不要做这个方案,读请求和写请求串行化,串到一个内存队列里去,这样就可以保证一定不会出现不一致的情况

串行化之后,就会导致系统的吞吐量会大幅度的降低,用比正常情况下多几倍的机器去支撑线上的一个请求。

Redis 序列化方式

上一篇下一篇

猜你喜欢

热点阅读