第九节-springboot高并发条件下缓存穿透问题处理

第九节-springboot高并发条件下缓存穿透问题处理_第1张图片

public List<User> getAllUsers() {
        //字符串序列化器
        RedisSerializer redisSerializer = new StringRedisSerializer();
        redisTemplate.setKeySerializer(redisSerializer);
        //查询缓存
        List<User> users = (List<User>) redisTemplate.opsForValue().get("allUsers");
        /**
         * 在高并发的情况下可能会出现缓存击穿的问题,此刻采用双重检测锁,
         * 假设有1万个人进行查询,此刻缓存为null,判断users==null,一万人进入,此时对象已上锁,那么
         * 等待,第一个人成功查询了数据库,并放入缓存,退出,第二个人进入同步代码块,此刻再去缓存中进行查询
         * 到值,退出,第三个。。。到一万个,那么等下一万个人就不比进入同步锁,直接在上方的缓存中就可以查询
         * 到值。
         */
        if (users == null){
            synchronized (this){
                users = (List<User>) redisTemplate.opsForValue().get("allUsers");
                if (users == null){
                    //缓存为null,查询一遍数据库。
                    users = userMapper.selectAllStudent();
                    redisTemplate.opsForValue().set("allUsers",users);
                }
            }

        }
        return users;
    }

相关介绍:https://www.cnblogs.com/duanxz/category/394740.html

你可能感兴趣的:(SpringBoot)