当前位置: 首页 > news >正文

【缓存策略】你知道 Write Through(直写)这个缓存策略吗?

👉博主介绍: 博主从事应用安全和大数据领域,有8年研发经验,5年面试官经验,Java技术专家,WEB架构师,阿里云专家博主,华为云云享专家,51CTO 专家博主

⛪️ 个人社区:个人社区
💞 个人主页:个人主页
🙉 专栏地址: ✅ Java 中级
🙉八股文专题:剑指大厂,手撕 Java 八股文

在这里插入图片描述

文章目录

      • 1. 缓存策略 Write Through 是什么?
      • 2. 缓存策略 Write Through 的应用场景
      • 3. 缓存策略 Write Through 的优缺点
      • 4. 用 Java 模拟使用 Write Through 策略
        • 1. 创建缓存接口
        • 2. 创建内存缓存实现
        • 3. 创建后端存储接口
        • 4. 创建后端存储实现
        • 5. 创建 Write Through 缓存实现
        • 6. 测试 Write Through 缓存

1. 缓存策略 Write Through 是什么?

Write Through 是一种缓存策略,当数据被写入缓存时,同时也会被写入后端存储(如数据库)。这种策略确保了缓存和后端存储的数据一致性。

工作原理:

  1. 写操作
    • 当客户端向缓存写入数据时,缓存会立即将数据写入后端存储。
    • 写操作只有在后端存储成功写入后才会返回成功。
  2. 读操作
    • 当客户端从缓存读取数据时,如果数据存在于缓存中,则直接返回缓存中的数据。
    • 如果数据不存在于缓存中,则从后端存储中读取数据,然后将其写入缓存,最后返回给客户端。

2. 缓存策略 Write Through 的应用场景

Write Through 适用于以下场景:

  1. 数据一致性要求高
    • 需要确保缓存和后端存储的数据始终保持一致。
  2. 写操作较少
    • 写操作相对于读操作较少,这样可以减少写操作的性能开销。
  3. 系统容错性要求高
    • 即使缓存失效,数据仍然存在于后端存储中,不会导致数据丢失。

3. 缓存策略 Write Through 的优缺点

优点:

  1. 数据一致性
    • 保证缓存和后端存储的数据一致性,避免数据不一致的问题。
  2. 容错性
    • 即使缓存失效,数据仍然存在于后端存储中,不会导致数据丢失。
  3. 简化系统设计
    • 不需要额外的机制来同步缓存和后端存储的数据。

缺点:

  1. 写操作性能开销大
    • 每次写操作都需要同时写入缓存和后端存储,增加了写操作的延迟。
  2. 写放大
    • 写操作会被放大,因为每次写操作都需要两次写入操作。
  3. 不适合写密集型应用
    • 对于写操作频繁的应用,Write Through 可能会导致性能瓶颈。

4. 用 Java 模拟使用 Write Through 策略

下面是一个简单的 Java 示例,模拟使用 Write Through 策略的缓存系统。

1. 创建缓存接口
public interface Cache<K, V> {V get(K key);void put(K key, V value);void remove(K key);
}
2. 创建内存缓存实现
import java.util.HashMap;
import java.util.Map;public class InMemoryCache<K, V> implements Cache<K, V> {private final Map<K, V> cache = new HashMap<>();@Overridepublic V get(K key) {return cache.get(key);}@Overridepublic void put(K key, V value) {cache.put(key, value);}@Overridepublic void remove(K key) {cache.remove(key);}
}
3. 创建后端存储接口
public interface BackendStorage<K, V> {V get(K key);void put(K key, V value);void remove(K key);
}
4. 创建后端存储实现
import java.util.HashMap;
import java.util.Map;public class InMemoryBackendStorage<K, V> implements BackendStorage<K, V> {private final Map<K, V> storage = new HashMap<>();@Overridepublic V get(K key) {return storage.get(key);}@Overridepublic void put(K key, V value) {storage.put(key, value);}@Overridepublic void remove(K key) {storage.remove(key);}
}
5. 创建 Write Through 缓存实现
public class WriteThroughCache<K, V> implements Cache<K, V> {private final Cache<K, V> cache;private final BackendStorage<K, V> backendStorage;public WriteThroughCache(Cache<K, V> cache, BackendStorage<K, V> backendStorage) {this.cache = cache;this.backendStorage = backendStorage;}@Overridepublic V get(K key) {V value = cache.get(key);if (value == null) {value = backendStorage.get(key);if (value != null) {cache.put(key, value);}}return value;}@Overridepublic void put(K key, V value) {cache.put(key, value);backendStorage.put(key, value);}@Overridepublic void remove(K key) {cache.remove(key);backendStorage.remove(key);}
}
6. 测试 Write Through 缓存
public class Main {public static void main(String[] args) {Cache<String, String> inMemoryCache = new InMemoryCache<>();BackendStorage<String, String> inMemoryBackendStorage = new InMemoryBackendStorage<>();Cache<String, String> writeThroughCache = new WriteThroughCache<>(inMemoryCache, inMemoryBackendStorage);// 测试写操作writeThroughCache.put("key1", "value1");System.out.println("Cache: " + inMemoryCache.get("key1")); // 输出: value1System.out.println("Backend Storage: " + inMemoryBackendStorage.get("key1")); // 输出: value1// 测试读操作System.out.println("Cache Read: " + writeThroughCache.get("key1")); // 输出: value1// 测试读取未缓存的数据inMemoryBackendStorage.put("key2", "value2");System.out.println("Cache Read: " + writeThroughCache.get("key2")); // 输出: value2System.out.println("Cache: " + inMemoryCache.get("key2")); // 输出: value2// 测试删除操作writeThroughCache.remove("key1");System.out.println("Cache: " + inMemoryCache.get("key1")); // 输出: nullSystem.out.println("Backend Storage: " + inMemoryBackendStorage.get("key1")); // 输出: null}
}
  • Write Through 是一种缓存策略,确保数据在写入缓存的同时也写入后端存储,保证数据一致性。
  • 应用场景:适用于数据一致性要求高、写操作较少、系统容错性要求高的场景。
  • 优缺点:优点是数据一致性高、容错性好、系统设计简单;缺点是写操作性能开销大、写放大、不适合写密集型应用。
  • Java 模拟:通过实现 Cache 接口和 BackendStorage 接口,创建 WriteThroughCache 类来模拟 Write Through 缓存策略。

精彩专栏推荐订阅:在下方专栏👇🏻
✅ 2023年华为OD机试真题(A卷&B卷)+ 面试指导
✅ 精选100套 Java 项目案例
✅ 面试需要避开的坑(活动)
✅ 你找不到的核心代码
✅ 带你手撕 Spring
✅ Java 初阶

在这里插入图片描述


http://www.mrgr.cn/news/71193.html

相关文章:

  • Redis和MongoDB的区别
  • C# winodw TableLayoutPanel 料盒生产状态UI自动生成
  • 深入理解 Python 的装饰器
  • rtthread学习笔记系列--18 信号 SIGNAL
  • 基于Python机器学习、深度学习技术提升气象、海洋、水文领域实践应用-以ENSO预测为例讲解
  • 标准Android开发jdk和gradle和gradle AGP和AndroidStudio对应版本
  • 1.vue环境搭建
  • 如何快速查看在 GitHub 上的所有PR提交记录
  • 微信机器人接入聊天模块
  • fastapi 查询参数支持 Pydantic Model:参数校验与配置技巧
  • IntelliJ+SpringBoot项目实战(四)--快速上手数据库开发
  • 【Python进阶】Python中的数据库交互:使用SQLite进行本地数据存储
  • 【蓝桥等考C++真题】蓝桥杯等级考试C++组第13级L13真题原题(含答案)-小蓝的目标
  • 国标GB28181-2022平台EasyGBS国标GB28181软件在GB/T28181协议中的加密措施
  • 2024要如何对公司CAD图纸进行加密?十种方法加密保护图纸!
  • GitHub4.2k Java开源神器一个免费的基于JNA的Java操作系统和硬件信息库
  • 重磅!Pubmed停止更新了?
  • 反沙箱 反虚拟机的一些笔记
  • 【Linux实践2】实验三:死锁的避免
  • 系统架构师-考点梳理
  • uniapp vuex的使用
  • Transformer(三):论文 Attention Is All You Need
  • 【2024最新】渗透测试工具大全(超详细),收藏这一篇就够了!
  • 【comfyui教程】comfyui攻略:故障报错应对指南!
  • 神经网络算法
  • 基于51单片机俄罗斯方块游戏—可暂停