Redis缓存处理技巧:雪崩、穿透、击穿及内存优化解析

创始人
2024-12-29 09:55:52
0 次浏览
0 评论

面试58同城!面试官问我redis雪崩、穿透、击穿怎么处理?

1、Redis缓存雪崩缓存雪崩现象是指大量数据同时失效,导致数据库压力过大,可能导致系统崩溃。
该问题通常由以下原因引起:1、短时间内大量磁盘同时故障。
2、聚合过期等缓存更新策略不当。
解决方案包括:1、采用分布式故障策略,避免多个数据同时故障。
2、使用Redis的过期时间设置、失效通知等缓存系统过期策略。
2、Redis缓存穿透缓存穿透的现象是不良请求绕过缓存直接影响数据库,增加数据库的压力。
常见原因有:1.缓存中数据丢失。
2、缓存数据结构不完整。
解决策略包括以下内容:1.即使没有缓存,也存储数据库查询结果。
2.使用布隆过滤器预先过滤无效请求。
3、Redis缓存击穿缓存击穿的现象是热点数据缓存过期,同时有很多请求访问数据库,增加了数据库的压力。
常见原因有:1、热点数据更新频繁。
2、缓存更新策略过于频繁。
对策包括:1.设置较短的热点数据过期时间,减少缓存压力。
2、使用互斥锁来保护热点数据,避免并发访问。
4.回答面试问题的技巧在回答面试问题时,您应该重点关注:1.理解概念。
2、分析因素。
3.解决方案实施。
总结:Redis缓存崩溃;了解并解决渗透和退化问题对于提高系统性能和稳定性至关重要。
明智地使用追赶技巧和策略可以提高面试竞争力。

【面试官】有遇到Redis内存过高的线上问题吗?为什么Redis删除数据后也无效?

面试的时候,面试官曾经问我网上是否遇到过Redis内存占用高的问题以及解决策略。
我分享了一个经验,当时我在处理高并发临时活动时,将一些MySQL数据加载到Redis缓存中以减轻数据库的压力。
活动结束后,虽然Redis数据被删除了,但是内存使用量并没有明显下降,这让我认识到了内存碎片和内存分配策略的影响。
内存碎片问题与MySQL的删除操作类似。
即使删除数据,内存空间也可能不会立即释放,而是可能会产生间隙。
Redis内存分配,比如jemalloc,会根据key值的大小预先分配空间。
当数据大小发生变化时,可能会出现碎片。
例如键值k1原本占用3个字节,但更新后只占用2个字节,导致碎片。
删除或显着更改键值也会导致内存碎片。
Redis的内存分配策略包括使用jemalloc、libc或tcmalloc来划分和管理内存。
不同大小的内存块会导致内存浪费,尤其是当键值的大小变化频繁且不均匀时。
另外,Redis的String预分配内存机制(底层SDS实现)会在数据缩短时预留空间,导致内存碎片。
key的过期时间和内存处置机制也会影响内存的使用。
虽然key过期后会被回收,但并不会立即释放,所以内存使用量不会立即减少。
另外,可以通过INFOmemory命令查看内存碎片率,如果超过合理范围(超过1.5倍),则可能需要采取措施进行清理。
内存碎片的解决方案包括重启Redis来清除所有数据,但这在生产环境中是大忌。
Redis4.0-RC3之后,可以启用activedefrag设置来自动清理内存碎片并监控CPU和IO资源使用情况,以确保清理过程对性能的影响最小。
通过调整相关参数,可以在不影响正常查询的情况下逐步优化内存使用。
综上所述,Redis内存使用率高的问题源于内存碎片和分配策略。
通过适当的监控和调整,可以有效管理内存碎片并保证缓存性能。

一份热乎的字节面试真题!(附答案)

面试题如下:-01为什么Redis是基于内存存储:内存读写比磁盘快很多。
高效的数据结构:MySQL使用B+树来优化查询效率,逻辑数据结构可以加快应用程序/程序的速度。
逻辑数据编码:Redis支持多种数据类型,并根据数据类型选择最合适的编码。
合理的线程模型:使用多路I/O复用技术(如epoll),高效处理多个连接请求,减少网络I/O时间。
02Redis有几种数据结构,底层是如何存储常见的数据类型:字符串(string)、哈希(hash)、列表(list)、集合(set)和有序集合(zset)。
特殊数据类型:用于特定功能。
03Redis崩溃了怎么办?Redis有多种基于数据丢失的保留机制。
RDB和AOF提供持久化:快照方式保存RDB快照,保存AOF日志。
RDB优点:适合大数据检索,缺点:实时性能较差,新旧版本之间存在兼容性问题。
AOF优点:数据一致性高,缺点:文件大,恢复慢。
04多线程情况下如何保证线程安全?加锁(关注锁、“同步”)、乐观锁、分布式锁。
05你使用过变量吗?它如何保证可见性?可见性由内存屏障确保。
06MySQL索引结构,聚集索引和非聚集索引的区别,非聚集索引基于B+树,数据存储顺序不同。
07MySQL主从复制、主主部分同步、双节点、分布式协议、共享存储你用的是哪种?08FlashKill系统设计页面统计、按钮控制、服务责任、链路盐提取、限流、分锁、MQ、断路器下降。
09中间件支持分库分表解析,不停机运行,出现问题时不停机动作。
重复接口电势、防复制、限流、黑色优惠券10张他们封锁了记录。
11.独音的反馈系统在设计时考虑了性能和可扩展性,并注重点对点交互。
12设计短链接简要链接因素、原理、生成方法、分布式标识符。
13.使用快速排序和二分查找查找整数数组的最大值。
14最大函数实现二分查找图及算法步骤。
热门文章
1
Python代码实现:如何判断三角形的三... python三角形三条边长,判断能否构成三角形Python三角形的三个长边如下:...

2
高效掌握:CMD命令轻松启动、关闭及登录... 如何用cmd命令快速启动和关闭mysql数据库服务开发中经常使用MySQL数据库...

3
SQL字段默认值设置全攻略:轻松实现自动... sql如何设置字段默认值设置SQL中某个字段的默认值;需要遵循几个步骤。首先您需...

4
MySQL查询加速秘籍:PolarDB ... mysql中in大量数据导致查询速度慢怎么优化?在MySQL中处理大量数据时,查...

5
SQL2000数据库备份压缩技巧:优化空... 怎么将SQL2000中的较大的备份数据库压缩变小更改数据库属性-选项-恢复模型很...

6
SQL字符串处理技巧:单引号使用与转义标... SQL语句中,字符串类型的值均使用什么符号标明?单引号如果字符串内有单引号,请小...

7
Windows环境下Redis安装指南与... redis安装windowsredis基本简介与安装安装Redis首先需要获取安...

8
深度解析:Redis性能优势与局限性,助... redis有哪些优缺点?Redis的全称是RemoteDictionary.Se...

9
深入解析:MySQL数据库的特性与应用 mysql是什么MySQL是一个关系数据库管理系统。MySQL是一个开源关系数据...

10
MySQL自增主键重置攻略:解决用尽问题... MySQL让有数据的表主键从1开始连续自增当您需要MySQL中的数据表使用连续数...