码迷,mamicode.com
首页 > 其他好文 > 详细

软件设计之缓存使用

时间:2015-07-15 17:06:51      阅读:83      评论:0      收藏:0      [点我收藏+]

标签:architecture   缓存   软件设计   

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

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

缓存的作用

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

缓存的原理

局部性原理

缓存的实现方式

查询算法

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

存储

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

缓存资源回收

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

缓存的存储介质

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

缓存设计注意的问题

资源的一致性,Cache coherence

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

系统的鲁棒性

空间换时间

多级缓存


版权声明:本文为博主原创文章,未经博主允许不得转载。

软件设计之缓存使用

标签:architecture   缓存   软件设计   

原文地址:http://blog.csdn.net/zuocheng_liu/article/details/46894289

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!