美文网首页
缓存设计思想

缓存设计思想

作者: 蜗牛写java | 来源:发表于2019-03-11 22:15 被阅读0次

缓存设计思想

概念思想

  • 缓存就是将频繁使用的资源或者数据放入到内存中,每次操作的时候,先到内存中获取,获取不到,再直接操作资源或者数据,然后再将操作的资源或者数据放入内存中,以便下次使用

  • 缓存是一种典型的空间换时间的方案(热点数据会存有两份)

  • 常见的实现缓存的方式是map

  • 设计模式中缓存体现:单例模式和享元模式等

    享元模式:重点在于分离变与不变,把一个对象的状态分成内部状态和外部状态,内部状态是不变的,而外部状态是可变的,然后通过共享不变的部分,达到减少对象数量并节约内存的目的,还有一点就是,在享元需要的时候,可以从外部传入外部状态给共享的对象,共享对象在功能的处理的时候,使用自己的内部状态和外部状态。

缓存设计图

  • 查询缓存

    1. 确定存放缓存数据的容器(可以自己实现,也可使用第三方缓存)
    2. 首先判断缓存是否有值
    3. 如果有,则取出返回;
    4. 如果没有去获取相应的数据,将相应数据放入缓存中;以便下次查询使用
    查询缓存时序图.png
  • 更新数据

    1. 发送更新请求到对应的数据库
    2. 更新相应的数据
    3. 将缓存中对应的数据设置无效(无效后,下次查询到该数据,又会重新放入缓存中)
    更新数据时序图.png

缓存思考的问题

  • 缓存存放时间的问题
  • 数据与数据库一致性问题
  • 缓存线程问题(有取数据,添加数据,清除失效数据)

缓存解决的问题

本质:提高性能
如:

  1. 缓解数据库压力
  2. 分布式系统中远程调用也会耗性能,因为网络开销,会导致整体的相应时间下降。为了换就这样的性能开销,在业务允许的情况下,使用缓存也是非常必要的。

相关文章

  • 缓存设计思想

    缓存设计思想 概念思想 缓存就是将频繁使用的资源或者数据放入到内存中,每次操作的时候,先到内存中获取,获取不到,再...

  • mybatis缓存设计思想

    MyBatis将数据缓存设计成两级结构,分为一级缓存、二级缓存: 一级缓存是Session会话级别的缓存,位于表示...

  • 缓存原理和设计

    缓存原理和设计 缓存的基本思想 什么是缓存? 缓存原指CPU上的一种高速存储器,它先于内存与CPU交换数据,速度很...

  • page cache页面缓存

    为什么设计缓存? 如何设计缓存? 页面缓存都缓存什么?

  • 缓存设计

    目录 缓存设计需要考虑的地方 项目代码编写 mybaits缓存设计原理 guava缓存设计原理 本地缓存设计需要考...

  • SDWebImage源码解读之SDWebImageCache(上

    第五篇 前言 本篇主要讲解图片缓存类的知识,虽然只涉及了图片方面的缓存的设计,但思想同样适用于别的方面的设计。在架...

  • 缓存思想

    [toc] 图来自:https://xie.infoq.cn/article/49947a60376964f1c1...

  • iOS架构设计-URL缓存(上)

    iOS架构设计-URL缓存(上) iOS架构设计-URL缓存(上)

  • iOS架构设计-URL缓存(下)

    iOS架构设计-URL缓存(下) iOS架构设计-URL缓存(下)

  • 设计 | 基于 Redis 谈一谈缓存设计思想

    王奇 顾问软件工程师目前从事 PaaS 中间件服务(Redis/MongoDB/ELK 等)开发工作,对 NoSQ...

网友评论

      本文标题:缓存设计思想

      本文链接:https://www.haomeiwen.com/subject/hqnipqtx.html