14、数据库缓存策略全面解析

数据库缓存策略全面解析

1. 缓存层级与架构

缓存可以在多个层级实现,包括客户端、API 网关以及各个服务。在 API 网关进行缓存,该缓存能够独立于服务进行扩展,以应对任意时刻的流量。

1.1 缓存架构示例

graph LR
    classDef process fill:#E5F6FF,stroke:#73A6FF,stroke-width:2px

    A(Client):::process --> B(API Gateway):::process
    B --> C(Service 1):::process
    B --> D(Service 2):::process
    B --> E(Service 3):::process
    B --> F(Cache):::process

2. 读取策略

读取策略旨在实现快速读取,主要有以下两种:

2.1 旁路缓存(Cache-aside)

旁路缓存是指缓存位于数据库“旁边”。在读取请求时,应用程序首先向缓存发出读取请求。若缓存命中,则返回数据;若缓存未命中,应用程序会向数据库发出读取请求,然后将数据写入缓存,以便后续对该数据的请求能够命中缓存。这种方式属于懒加载,即数据仅在首次读取时加载。

2.1.1 优点
  • 减少读取请求数量和资源消耗。为进一步减少请求,应用程序可以将多个数据库请求的结果存储为单个缓存值。
  • 仅将请求的数据写
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值