`
陈睿mikechen
  • 浏览: 6190 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

高并发架构系列:如何解决Redis雪崩、穿透、并发等5大难题

阅读更多
一、缓存雪崩
数据未加载到缓存中,或者缓存同一时间大面积的失效,从而导致所有请求都去查数据库,导致数据库CPU和内存负载过高,甚至宕机。

比如一个雪崩的简单过程:

1、redis集群大面积故障
2、缓存失效,但依然大量请求访问缓存服务redis
3、redis大量失效后,大量请求转向到mysql数据库
4、mysql的调用量暴增,很快就扛不住了,甚至直接宕机
5、由于大量的应用服务依赖mysql和redis的服务,这个时候很快会演变成各服务器集群的雪崩,最后网站彻底崩溃。

如何预防缓存雪崩:
1.缓存的高可用性
缓存层设计成高可用,防止缓存大面积故障。即使个别节点、个别机器、甚至是机房宕掉,依然可以提供服务,例如 Redis Sentinel 和 Redis Cluster 都实现了高可用。

2.缓存降级
可以利用ehcache等本地缓存(暂时支持),但主要还是对源服务访问进行限流、资源隔离(熔断)、降级等。
当访问量剧增、服务出现问题仍然需要保证服务还是可用的。系统可以根据一些关键数据进行自动降级,也可以配置开关实现人工降级,这里会涉及到运维的配合。
降级的最终目的是保证核心服务可用,即使是有损的。
比如推荐服务中,很多都是个性化的需求,假如个性化需求不能提供服务了,可以降级补充热点数据,不至于造成前端页面是个大空白。
在进行降级之前要对系统进行梳理,比如:哪些业务是核心(必须保证),哪些业务可以容许暂时不提供服务(利用静态页面替换)等,以及配合服务器核心指标,来后设置整体预案,比如:

(1)一般:比如有些服务偶尔因为网络抖动或者服务正在上线而超时,可以自动降级;
(2)警告:有些服务在一段时间内成功率有波动(如在95~100%之间),可以自动降级或人工降级,并发送告警;
(3)错误:比如可用率低于90%,或者数据库连接池被打爆了,或者访问量突然猛增到系统能承受的最大阀值,此时可以根据情况自动降级或者人工降级;
(4)严重错误:比如因为特殊原因数据错误了,此时需要紧急人工降级。

3.Redis备份和快速预热

1)Redis数据备份和恢复;
2)快速缓存预热;

4.提前演练

最后,建议还是在项目上线前,演练缓存层宕掉后,应用以及后端的负载情况以及可能出现的问题,对高可用提前预演,提前发现问题。

二、缓存穿透
缓存穿透是指查询一个一不存在的数据。例如:从缓存redis没有命中,需要从mysql数据库查询,查不到数据则不写入缓存,这将导致这个不存在的数据每次请求都要到数据库去查询,造成缓存穿透。

解决思路:
如果查询数据库也为空,直接设置一个默认值存放到缓存,这样第二次到缓冲中获取就有值了,而不会继续访问数据库。设置一个过期时间或者当有值的时候将缓存中的值替换掉即可。
可以给key设置一些格式规则,然后查询之前先过滤掉不符合规则的Key。

三、缓存并发
这里的并发指的是多个redis的client同时set key引起的并发问题。其实redis自身就是单线程操作,多个client并发操作,按照先到先执行的原则,先到的先执行,其余的阻塞。当然,另外的解决方案是把redis.set操作放在队列中使其串行化,必须的一个一个执行。

四、缓存预热
缓存预热就是系统上线后,将相关的缓存数据直接加载到缓存系统。

这样就可以避免在用户请求的时候,先查询数据库,然后再将数据缓存的问题!用户直接查询事先被预热的缓存数据!

解决思路:
1、直接写个缓存刷新页面,上线时手工操作下;
2、数据量不大,可以在项目启动的时候自动进行加载;

目的就是在系统上线前,将数据加载到缓存中。
以上就是缓存雪崩、预热、降级等的介绍,更多整体从服务器雪崩的角度,参考文章:阿里P8架构师谈:什么是缓存雪崩?服务器雪崩的场景与解决方案。

我是mike,曾任职一线大厂架构师,每日分享bat架构+面试+技术干货!坚持原创不易,觉得不错点赞支持,送你【BAT架构80期学习资料合集】,加我QQ 649449578领取资料、与我深度交流,验证通关暗号【架构】。
分享到:
评论

相关推荐

    什么是redis缓存穿透 雪崩 ,如何应对解决 redis缓存穿透 雪崩 的解决办法

    在IT行业中,尤其是当我们处理高并发和大数据量的应用时,Redis作为一个高效的数据缓存工具,常常被用来缓解数据库的压力。然而,如果使用不当,可能会遇到两种常见问题:缓存穿透和缓存雪崩。这两者都会对系统的...

    如何应对redis缓存雪崩,redis缓存穿透,redis缓存击穿,redis应对高并发的解决方案

    redis缓存雪崩,redis缓存穿透,redis缓存击穿 redis应对高并发造成的雪崩、穿透、击穿

    如何解决Redis缓存雪崩、缓存穿透、缓存并发等5大难题.pdf

    提供了解redis实践开过程中,所面对缓存雪崩 缓存穿透 缓存并发的处理方案,同时这些个问题也是面试的经典问题,有助提升开发者的知识视野

    Redis使用-缓存穿透,雪崩,击穿以及解决方案分析.docx

    Redis 使用-缓存穿透、雪崩、击穿以及解决方案分析 一、缓存穿透 缓存穿透是指查询一个一定不存在的数据,由于缓存是不命中时被动写的,并且出于容错考虑,如果从存储层查不到数据则不写入缓存,这将导致这个不...

    Redis系统学习之缓存穿透,缓存击穿,缓存雪崩的概念及其解决方案.docx

    ### Redis系统学习之缓存穿透、缓存击穿与缓存雪崩的概念及其解决方案 #### 缓存穿透 **概念**: 缓存穿透是指在高并发场景下,大量的请求访问了一个既不在缓存中也不在数据库中的数据。这种情况通常发生在非法...

    redis百万并发访问数据库测试

    9. **Redis Cluster**:对于大规模部署,Redis Cluster提供了一种分布式解决方案,自动分片数据,允许在多个节点间进行负载均衡,支持更高的并发和更大的数据量。 10. **优化策略**:为了提升Redis的性能,可以从多...

    Java架构技术揭秘:Redis+Nginx+Dubbo+面试题+视频.docx

    - **缓存雪崩**:通过设置不同的过期时间或者使用缓存预热等策略来避免大量缓存同时失效的情况。 - **缓存穿透**:采用布隆过滤器等技术预先判断数据是否存在,减少对后端数据库的无效访问。 - **缓存并发**:利用...

    Java面试之Redis的雪崩和穿透1

    首先,Redis的雪崩现象指的是当Redis服务器因某种原因(如内存耗尽、网络故障等)导致大量请求无法正常处理时,这些请求会回流到后端数据库,瞬间造成数据库压力过大,从而引发整个系统的崩溃。为了解决这个问题,...

    Redis面试指南:Redis面试宝典实用技巧分享

    Redis是目前广泛应用于Web开发领域的高性能键值存储系统,尤其在缓存管理方面表现出色。在求职面试中,深入理解Redis及其应用场景对于成功获得技术岗位至关重要。以下是对Redis面试相关知识点的详细阐述: 1. Redis...

    聊聊高并发高可用那些事(Kafka、Redis、MySQL)

    以上内容涵盖了Kafka、Redis和MySQL在处理高并发和高可用性时的关键知识点,包括它们的基本原理、操作方法、优化策略和常见问题的解决方案。学习和掌握这些知识点,有助于构建稳定、高效的数据处理系统。

    Redis面试题深度解析:技术要点与实战应用.zip

    - 缓存策略:掌握缓存穿透、缓存雪崩和缓存击穿的解决方案,如布隆过滤器、预热策略等。 3. Redis高级特性: - Pub/Sub:发布订阅模式用于实时消息传递,适用于消息通知和异步任务。 - Lua脚本:通过内嵌的Lua...

    Redis缓存穿透缓存雪崩缓存击穿的原因和解决方案.docx

    Redis缓存穿透、缓存雪崩、缓存击穿的原因和解决方案 Redis缓存穿透、缓存雪崩、缓存击穿是 Redis 缓存中常见的问题,它们可能会导致数据库的负载加大,影响系统的性能。本文将详细讨论这些问题的原因和解决方案。 ...

    Redis缓存穿透,缓存击穿,缓存雪崩面试题解析

    Redis缓存穿透、缓存击穿、缓存雪崩面试题解析 Redis缓存穿透、缓存击穿、缓存雪崩是Redis中的三个重要概念,它们都是Redis缓存机制中可能出现的错误或问题。下面我们将详细解析这三个概念,并提供相应的解决方案。...

    Redis缓存穿透,缓存击穿和缓存雪崩

    在IT行业中,Redis作为一种高...以上是针对Redis缓存系统中可能出现的缓存穿透、缓存击穿和缓存雪崩问题的解决方案。在设计缓存系统时,应当充分考虑这些潜在风险,采取适当的预防措施,以确保系统的稳定性和高可用性。

    基于redis实现高并发异步秒杀点评项目

    本项目“基于Redis实现高并发异步秒杀点评项目”旨在提供一个实际的秒杀系统解决方案,结合了Redis的强大功能和高并发处理策略,确保在点评网站的大规模用户参与下仍能保持系统性能和稳定性。通过学习和实践这个项目...

    redis之缓存雪崩,穿透,击穿1

    总结,理解和预防Redis缓存的这些潜在问题至关重要,能够保证系统在高并发场景下的稳定性和效率。通过合理的策略和设计,可以有效避免缓存穿透、雪崩和击穿带来的负面影响。在实际应用中,应结合业务需求和系统特性...

    Redis经典面试题:redis是单线程架构还是多线程架构

    Redis,作为一种高性能的键值存储系统,以其独特的单线程模型和高效的内存操作而闻名。在Redis中,大部分操作都是基于内存的,这使得它在处理读取和写入操作时速度极快。Redis的数据结构设计也非常巧妙,包括简单...

    java并发编程与高并发解决方案

    - 缓存穿透、缓存雪崩等问题的解决策略。 3. **分布式锁**: - 在分布式环境中实现资源的互斥访问,保证数据一致性。 - 实现方式:基于Zookeeper、Redis等中间件。 4. **消息队列**: - 用于解耦系统组件,...

    redis之相关理解分析以及面试问题总结

    Redis是一种高性能的键值对数据存储系统,常用于缓存、消息队列、计数器等场景。本文将深入探讨Redis的基本概念、工作原理、存储机制,并总结一些常见的面试问题。 1. Redis基本概念: - 数据类型:Redis支持五大...

    分布式数据库面试专题系列:Memcached+Redis+MongoDB.zip

    7. 熟悉实际项目中可能遇到的问题和解决方案,如缓存穿透、缓存雪崩、写入延迟等。 通过深入研究这三个分布式数据库系统,你可以为面试做好充分准备,同时也能在实际工作中更好地应对各种挑战。无论是开发、运维...

Global site tag (gtag.js) - Google Analytics