分布式缓存与Redis
创始人
2024-11-17 19:32:33
0

缓存定义与意义

  • 狭义缓存:加速CPU数据交换的存储器。
  • 广义缓存:所有用于数据高速交换的存储介质,包括硬件和软件。
  • 缓存目的:通过数据交换缓冲区减少原始数据获取代价,提高读写性能。

缓存思想与性能

  • 时间局限性原理:数据一旦被获取,未来可能被多次引用。
  • 以空间换时间:使用高速独立空间来提供数据的高效访问。
  • 性能成本权衡:访问延迟越低,性能越高,成本也越大。

缓存的优势与代价

  • 优势
    • 提升访问性能。
    • 降低网络拥堵。
    • 减轻服务负载。
    • 增强可扩展性。
  • 代价
    • 增加系统复杂度。
    • 增加部署和运行成本。
    • 存在数据一致性问题。

缓存读写模式

  1. Cache Aside(旁路缓存)
    • 写操作:更新数据库后删除缓存中的key。
    • 读操作:先读缓存,未命中则读数据库并回写缓存。
  2. Read/Write Through(读写穿透)
    • 业务应用通过存储服务与缓存和数据库交互。
    • 存储服务代理处理缓存和数据库的读写操作。
  3. Write Behind Caching(异步缓存写入)
    • 先更新缓存,异步批量更新数据库。
    • 写性能高,但可能数据一致性差,存在数据丢失风险。

缓存问题解决方案

  1. 缓存穿透
    • 频繁查询不存在的数据。
    • 解决方案:接口校验、缓存空对象、布隆过滤器。
  2. 缓存击穿
    • 热点Key过期导致大量请求访问数据库。
    • 解决方案:永不过期、逻辑过期、使用互斥锁。
  3. 缓存雪崩
    • 大量缓存key同时失效或服务宕机。
    • 解决方案:随机过期时间、集群部署、多级缓存、降级限流。

缓存数据不一致和并发竞争

  • 数据不一致
    • 原因:更新数据库后缓存更新失败。
    • 解决方案:重试更新、使用队列服务、缓存分层策略。
  • 数据并发竞争
    • 原因:缓存miss导致大量请求并发查询数据库。
    • 解决方案:全局锁、多个缓存备份。

Hot Key和Big Key问题

  • Hot Key
    • 原因:突发热门事件导致大量请求。
    • 解决方案:识别热key、分散缓存节点、多副本架构、监控SLA、本地缓存。
  • Big Key
    • 原因:缓存Value过大导致读写超时。
    • 解决方案:启用压缩、预先分配足够空间、序列化构建、分拆大key。

Redis网络模型

  • 用户空间与内核空间
    • 用户空间通过内核接口访问资源。
    • 内核空间直接调用系统资源。
  • Linux缓冲区
    • 用户空间和内核空间都加入缓冲区提高IO效率。
  • 网络模型
    • 阻塞IO:两个阶段都阻塞。
    • 非阻塞IO:第一阶段不阻塞,第二阶段阻塞。
    • IO多路复用:单个线程监听多个FD。
    • 信号驱动IO:通过信号通知用户进程FD就绪。
    • 异步IO:内核完成数据处理后写入用户态。

Redis多线程支持

  • Redis v4.0:引入多线程处理耗时任务。
  • Redis v6.0:在核心网络模型中引入多线程。

缓存设计架构考量点

  • 读写方式:整体读写或部分读写。
  • KV size:根据业务数据大小分拆或合并KV。
  • key数量:全量数据或只保留热数据。
  • 读写峰值:独立Cache池或分层处理。
  • 命中率:持续监控和故障处理。
  • 过期策略:设置合理过期时间或使用时间戳。

相关内容

热门资讯

今日公布“潮汕激k脚本”其实存... 今日公布“潮汕激k脚本”其实存在有挂(辅助挂)详细辅助透明教程;1、任何ai辅助神器的玩家都可以机会...
揭秘真相“土豪联盟辅助器”原来... 揭秘真相“土豪联盟辅助器”原来存在有挂(辅助挂)详细辅助安装教程1、每一步都需要思考,不同水平的挑战...
实测交流“微信小程序多乐跑作弊... 实测交流“微信小程序多乐跑作弊”竟然是真的有挂(辅助挂)详细辅助靠谱教程一、AI软件牌型概率发牌机制...
玩家亲测“科乐天天踢填大坑辅助... 玩家亲测“科乐天天踢填大坑辅助”其实是真的有挂(辅助挂)详细辅助解密教程;所有人都在同一条线上,像星...
专业讨论“阿当比鸡有透视吗”真... 专业讨论“阿当比鸡有透视吗”真是存在有挂(辅助挂)详细辅助我来教教你1)辅助挂:进一步探索辅助透视大...
今日重大通报“赣牌圈小程序破解... 今日重大通报“赣牌圈小程序破解版”都是是有挂(辅助挂)详细辅助2025新版总结;1、操作简单,无需注...
发现一款“土豪联盟辅助”都是是... 发现一款“土豪联盟辅助”都是是有挂(辅助挂)详细辅助解密教程一、AI软件牌型概率发牌机制”必胜“技巧...
实测揭晓“潮汕馆透视牌”果然真... 实测揭晓“潮汕馆透视牌”果然真的有挂(辅助挂)详细辅助AI教程在进入辅助挂后,参与本局比赛的八名玩家...
每日必看推荐“八仙竞技辅助”其... 每日必看推荐“八仙竞技辅助”其实有挂(辅助挂)详细辅助专业教程1、下载好辅助软件之后点击打开,先需要...
我来向大家传授“邳州友友辅助软... 我来向大家传授“邳州友友辅助软件”都是真的是有挂(辅助挂)详细辅助新2025版一、软件透明挂的定义与...