软件设计之缓存使用

Posted llguanli

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了软件设计之缓存使用相关的知识,希望对你有一定的参考价值。

原网址将会不断更新 :   作程的技术博客  《软件设计之缓存的使用 - 总结》  it.zuocheng.net 

本文主要讨论分布式环境下,缓存怎样在软件设计作用、原理、实现方式及注意问题。

缓存的作用

  • 减小原始数据訪问压力
  • 提高资源利用率

缓存的原理

局部性原理

缓存的实现方式

查询算法

  • 散列算法,Hash 、 MD5 等
  • B数、二叉树、有序二分查找等

存储

  • 仅仅将訪问量最高的部分数据放入缓存
  • 将数据放到比原始IO速率更高的存储介质中

缓存资源回收

  • RUL 算法
  • 定时清理
  • 设置资源有效时间

缓存的存储介质

  • CPU 寄存器
  • 内存
  • 本地文件
  • 分布式系统(Memcache 、 Redis)
  • 数据库缓存数据表

缓存设计注意的问题

资源的一致性。Cache coherence

  • 避免数据脏读
  • 多级缓存的一致性协议

系统的鲁棒性

空间换时间

多级缓存


以上是关于软件设计之缓存使用的主要内容,如果未能解决你的问题,请参考以下文章

两周速成系统设计系列之七 缓存鼻祖Memcached

JavaEE 之 RESTful

C#软件设计——小话设计模式原则之:开闭原则OCP

软件project之软件设计

揭秘设计模式之享元模式

设计模式之软件设计原则