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

软件设计之缓存使用

时间:2017-07-10 10:15:26      阅读:188      评论:0      收藏:0      [点我收藏+]

标签:style   tar   ati   height   data-   ack   base   add   baseline   

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

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

缓存的作用

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

缓存的原理

局部性原理

缓存的实现方式

查询算法

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

存储

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

缓存资源回收

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

缓存的存储介质

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

缓存设计注意的问题

资源的一致性。Cache coherence

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

系统的鲁棒性

空间换时间

多级缓存


软件设计之缓存使用

标签:style   tar   ati   height   data-   ack   base   add   baseline   

原文地址:http://www.cnblogs.com/llguanli/p/7144115.html

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