Redis 缓存设计

本文涉及的产品
云原生内存数据库 Tair,内存型 2GB
云数据库 Redis 版,社区版 2GB
推荐场景:
搭建游戏排行榜
云数据库 Redis 版,经济版 1GB 1个月
简介: 本文介绍Redis 缓存设计:穿透优化、无底洞优化、雪崩优化、热点key 重建优化

一 穿透优化


缓存空对象和布隆过滤器方案对比


解决缓存穿透

适用场景

维护成本

缓存空对象

  • 数据命中不高
  • 数据频繁变化实时性高
  • 代码维护简单
  • 需要过多的缓存空间
  • 数据不一致

布隆过滤器

  • 数据命中不高
  • 数据相对固定实时性低
  • 代码维护复杂
  • 缓存空间占用少


二 无底洞优化


四种批量操作解决方案对比


方案

优点

缺点

网络IO

串行命令

  1. 编程简单
  2. 如果少量keys,性能可以满足要求

大量keys请求延迟严重

O(keys)

串行IO

  1. 编程简单
  2. 少量节点,性能满足要求

大量node 延迟严重

O(nodes)

并行IO

利用并行特性,延迟取决于最慢的节点

  1. 编程复杂
  2. 由于多线程,问题定位可能较难

O(max_slow(nodes))

hash_tag

性能最高

  1. 业务维护成本较高
  2. 容易出现数据倾斜

O(1)


三 雪崩优化


  • 保证缓存层服务高可用性
  • 依赖隔离组件为后端限流并降级
  • 提前演练

四 热点key 重建优化


两种热点key 的解决方法

解决方案

优点

缺点

简单分布式锁

  • 思路简单
  • 保证一致性
  • 代码复杂度增大
  • 存在死锁的风险
  • 存在线程池阻塞的风险

永远不过期

基本杜绝热点key 问题

  • 不保证一致性
  • 逻辑过期时间增加代码维护成本和内存成本


相关实践学习
基于Redis实现在线游戏积分排行榜
本场景将介绍如何基于Redis数据库实现在线游戏中的游戏玩家积分排行榜功能。
云数据库 Redis 版使用教程
云数据库Redis版是兼容Redis协议标准的、提供持久化的内存数据库服务,基于高可靠双机热备架构及可无缝扩展的集群架构,满足高读写性能场景及容量需弹性变配的业务需求。 产品详情:https://www.aliyun.com/product/kvstore     ------------------------------------------------------------------------- 阿里云数据库体验:数据库上云实战 开发者云会免费提供一台带自建MySQL的源数据库 ECS 实例和一台目标数据库 RDS实例。跟着指引,您可以一步步实现将ECS自建数据库迁移到目标数据库RDS。 点击下方链接,领取免费ECS&RDS资源,30分钟完成数据库上云实战!https://developer.aliyun.com/adc/scenario/51eefbd1894e42f6bb9acacadd3f9121?spm=a2c6h.13788135.J_3257954370.9.4ba85f24utseFl
相关文章
|
6天前
|
缓存 NoSQL Java
在 Spring Boot 应用中使用 Spring Cache 和 Redis 实现数据查询的缓存功能
在 Spring Boot 应用中使用 Spring Cache 和 Redis 实现数据查询的缓存功能
25 0
|
2天前
|
存储 缓存 NoSQL
SpringBoot配置第三方专业缓存技术Redis
SpringBoot配置第三方专业缓存技术Redis
10 4
|
5天前
|
存储 缓存 NoSQL
springboot redis-cache 自动刷新缓存
springboot redis-cache 自动刷新缓存
|
8天前
|
缓存 NoSQL Java
在 SSM 架构(Spring + SpringMVC + MyBatis)中,可以通过 Spring 的注解式缓存来实现 Redis 缓存功能
【6月更文挑战第18天】在SSM(Spring+SpringMVC+MyBatis)中集成Redis缓存,涉及以下步骤:添加Spring Boot的`spring-boot-starter-data-redis`依赖;配置Redis连接池(如JedisPoolConfig)和连接工厂;在Service层使用`@Cacheable`注解标记缓存方法,指定缓存名和键生成策略;最后,在主配置类启用缓存注解。通过这些步骤,可以利用Spring的注解实现Redis缓存。
27 2
|
8天前
|
存储 缓存 NoSQL
Redis 缓存失效策略及其应用场景
Redis 缓存失效策略及其应用场景
16 1
|
1天前
|
存储 缓存 NoSQL
redis缓存优化
采用获取一次缓存,如果为空的情况,获取分布式锁,让一个线程去重建缓存,另外的线程未获取到锁的情况,休眠短时间,然后再自旋获取缓存。
9 0
|
2天前
|
缓存 NoSQL Redis
SpringBoot2.4.5使用redis缓存
SpringBoot2.4.5使用redis缓存
8 0
|
12天前
|
存储 缓存 NoSQL
Redis缓存的运用
缓存预热就是系统上线后,将相关的缓存数据直接加载到缓存系统。这样就可以避免在用户请 求的时候,先查询数据库,然后再将数据缓存的问题!用户直接查询事先被预热的缓存数据!
16 1
|
26天前
|
缓存 监控 NoSQL
redis 缓存穿透 击穿 雪崩 的原因及解决方法
redis 缓存穿透 击穿 雪崩 的原因及解决方法
|
8天前
|
存储 缓存 NoSQL
Redis是一种高性能的内存数据库,常用于高并发环境下的缓存解决方案
【6月更文挑战第18天】**Redis摘要:** 高性能内存数据库,擅长高并发缓存。数据存内存,访问迅速;支持字符串、列表等多元数据类型;具备持久化防止数据丢失;丰富命令集便于操作;通过节点集群实现数据分片与负载均衡,增强可用性和扩展性。理想的缓存解决方案。
22 1