分布式缓存与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池或分层处理。
  • 命中率:持续监控和故障处理。
  • 过期策略:设置合理过期时间或使用时间戳。

相关内容

热门资讯

5分钟透视!wepOKer作弊... 5分钟透视!wepOKer作弊开挂方法--原来有挂(透视作弊)wepOKer原来是有猫腻的(有挂指南...
重大科普!微扑克ai代打(有辅... 重大科普!微扑克ai代打(有辅助挂)喜扣打筒子真的有挂的(有挂启发)准备好在微扑克的高塔上攀登,扮演...
十分钟透视!WePoKer辅助... 十分钟透视!WePoKer辅助器是真的的(透视挂)WePoKer果然真的有挂的(有挂指示);超受欢迎...
分享实测!wpk被系统针对(辅... 分享实测!wpk被系统针对(辅助)雀友游戏辅助(有挂教导)科技教程也叫必备教程,这是一款功能强大的w...
一分钟辅助!微扑克俱乐部打法技... 1、完成微扑克的残局,帮助玩家取得所有比赛的胜利,直登高塔的教程。2、多达1000个不同的游戏攻略,...
玩家攻略!wpk辅助器小程序(... 玩家攻略!wpk辅助器小程序(有挂的)微信天酷棋牌有挂的(有挂指示);AI智能教程细节普及德州是一种...
五分钟秒懂!wepoker俱乐... 1、让任何用户在无需AI插件第三方神器的情况下就能够完成在wepoker系统规律下的调试。2、直接的...
3分钟了解!wpk插件数据透视... 3分钟了解!wpk插件数据透视(透明挂软件)掌酷十三张系统规律(有挂点拨);wpk是一种具有地方特色...
2024版科技!wepoke ... 一、2024版科技!wepoke 插件(有挂的)钱塘十三水外挂可靠的(有挂办法)是的,亲,有的,关于...
3分钟透视!aapoker辅助... 3分钟透视!aapoker辅助作弊透视方法(透视挂)aapoker确实真的有挂的(有挂途径);人气非...