redis面试必问的三大问题是什么?redis面试必问的三大问题

Redis作为时下最火的缓存中间件之一,面试的时候面试官肯定会问Redis的相关内容,而问到redis这三个问题是必问的,那redis面试必问的三大问题是什么?下面我们就给大家讲解一下。

redis面试必问的三大问题.jpg

一、缓存雪崩

缓存雪崩表示在某一时间段,缓存集中失效,导致请求全部走数据库,有可能搞垮数据库,使整个服务瘫痪。

使缓存集中失效的原因:

1、redis服务器挂掉了。

2、对缓存数据设置了相同的过期时间,导致某时间段内缓存集中失效。

如何解决缓存集中失效:

1、针对原因1,可以实现redis的高可用,Redis Cluster 或者 Redis Sentinel(哨兵) 等方案。

2、针对原因2,设置缓存过期时间时加上一个随机值,避免缓存在同一时间过期。

< ? php
$redis = new Redis();
$redis - > connect('127.0.0.1', 6379, 60);
$redis - > auth('');
//设置过期时间加上一个随机值
$redis - > set('article_content_1', '文章内容', 60 + mt_rand(1, 60));
$redis - > set('article_content_2', '文章内容', 60 + mt_rand(1, 60));

3、使用双缓存策略,设置两个缓存,原始缓存和备用缓存,原始缓存失效时,访问备用缓存,备用缓存失效时间设置长点。

//原始缓存
$redis - > set('article_content_2', '文章内容', 60);
//设置备用缓存,失效时间设置长点
$redis - > set('article_content_backup_2', '文章内容', 1800);

二、缓存击穿

缓存击穿是指当前热点数据存储到期时,多个线程同时并发访问热点数据。因为缓存刚过期,所有并发请求都会到数据库中查询数据。

1. 解决方案

将热点数据设置为永不过期;

加互斥锁:互斥锁可以控制查询数据库的线程访问,但这种方案会导致系统的吞吐量下降,需要根据实际情况使用。

Copypublic String get(key)
{
    String value = redis.get(key);
    if (value == null)
    { // 代表缓存值过期
        // 设置3min的超时,防止del操作失败的时候,下次缓存过期一直不能load db
        if (redis.setnx(key_mutex, 1, 3 * 60) == 1)
        { // 代表设置成功
            value = db.get(key);
            redis.set(key, value, expire_secs);
            redis.del(key_mutex);
        }
        else
        { // 这个时候代表同时候的其他线程已经load db并回设到缓存了,这时候重试获取缓存值即可
            sleep(50);
            get(key); // 重试
        }
    }
    else
    {
        return value;
    }
}

三、缓存雪崩

缓存雪崩发生有几种情况,比如大量缓存集中在或者缓存同时在大范围中失效,出现了大量请求去访问数据库,从而导致CPU和内存过载,甚至停机。

一个简单的雪崩过程:

Redis 集群产生了大面积故障;

缓存失败,此时仍有大量请求去访问 Redis 缓存服务器;

在大量 Redis 请求失败后,这些请求将会去访问数据库;

由于应用的设计依赖于数据库和 Redis 服务,很快就会造成服务器集群的雪崩,最终导致整个系统的瘫痪。

解决方案

【事前】高可用缓存:高可用缓存是防止出现整个缓存故障。即使个别节点,机器甚至机房都关闭,系统仍然可以提供服务,Redis 哨兵(Sentinel) 和 Redis 集群(Cluster) 都可以做到高可用;

【事中】缓存降级(临时支持):当访问次数急剧增加导致服务出现问题时,我们如何确保服务仍然可用。在国内使用比较多的是 Hystrix,它通过熔断、降级、限流三个手段来降低雪崩发生后的损失。只要确保数据库不死,系统总可以响应请求,每年的春节 12306 我们不都是这么过来的吗?只要还可以响应起码还有抢到票的机会;

【事后】Redis备份和快速预热:Redis数据备份和恢复、快速缓存预热。

面试Redis最常问的三个问题就是缓存雪崩、击穿以及穿透,所以我们在面试之前,一定要将此相关知识点掌握好,不然问到Redis面试题肯定歇菜!最后大家如果想要了解更多Java面试题知识,敬请关注奇Q工具网。

推荐阅读:

json字符串有斜杠吗?json字符串如何转换大小写?

springcloud的gateway面试题有哪些?springcloud的gateway面试题

java可以写游戏脚本吗?java如何开发俄罗斯方块游戏?