xcache本地缓存的设计(一)
来源:互联网 发布:直销软件开发xazxrj 编辑:程序博客网 时间:2024/06/08 00:10
一、 存储器
需要缓存的对象是放在存储器中的,最常用就是把这些对象放在内存中。存储器是缓存的基础,xcache现在支持内存,未来可能支持更多的存储媒介。在这部分设计中,采用一个存储器工厂,根据不同的存储媒介生产不同的存储器实现。见下图。
StoreFactory:存储器工厂,它负责生产不同的存储器实现。
Store:存储器接口,定义了存储相关的操作。见下代码。
MemoryStore:使用内存的存储器实现。为了实现高并发的储存,使用jdk1.5提供的ConcurrentHashMap进行储存。
二、 缓存元素
在Store接口代码中,我们看到了Element类,Element就是缓存元素。Element成员见下代码。
key用来唯一标识一个缓存元素,object就是我们要缓存的对象。
createdTime、lastAccessTime、lastUpdateTime、accessTimes、updateTimes都是对缓存元素操作的统计。这些在判断元素是否过期、是否需要退出的算法中有用。我们后面会讲到。
liveTime、idleTime是控制缓存元素生命周期的。判断元素是否过期见下代码。
三、 缓存
在上一篇《xcache本地缓存的分析》中,我们讲到了一个本地缓存所具有的基本功能。缓存封装了对存储器的操作,还有两个定时任务,我们把缓存和定时任务组合起来形成一套缓存,这是有别于其他开源缓存的地方。通过一个缓存工厂来生产一套定制的缓存。为了实现缓存分区,通过一个管理器来管理多套缓存,该管理器还承担了缓存初始化工作。外部系统只要通过该管理器可以获取缓存。见下图。
Cache:缓存接口,定义了缓存的操作。见下代码。
Xcache:缓存实现类。
CacheStat:记录缓存统计信息的类。缓存操作的统计信息都在这里。
CacheSuite:一套缓存。其成员见下代码。
AbstractTask:抽象任务,定义任务的执行模式。见下代码。
DeleteExpireElementTask:删除过期缓存元素任务。
LogCacheStatTask:记录缓存统计信息任务。
CacheFactory:缓存工厂,它负责生产一套定制的缓存。
CacheManager:缓存管理器,负责缓存初始化,管理多套缓存。
未完待续~!
- xcache本地缓存的设计(一)
- xcache本地缓存的设计(二)
- xcache本地缓存的分析
- Xcache ,opcode缓存扩展
- PHP缓存Xcache安装
- php opcode缓存的扩展xcache的使用
- iOS应用的本地缓存机制设计
- iOS应用的本地缓存机制设计
- 知识库--本地缓存设计(128)
- PHP缓存Xcache安装笔记
- PHP缓存Xcache安装笔记
- PHP之XCache缓存使用
- PHP XCache缓存安装使用
- php op code 缓存 xcache
- 设计一个移动应用的本地缓存机制
- 设计一个移动应用的本地缓存机制
- 设计一个iOS应用的本地缓存机制
- 设计一个移动应用的本地缓存机制
- 如何移动一个带有lob字段的表到另外一个表空间
- 一个简单而又灵活的IOCP模块——完成端口通讯服务器(IOCP Socket Server)设计(四)
- Java多线程初学者指南(3):使用Runnable接口创建线程
- getDefinitionByName动态创建类。
- 【CEO来信】李开复:创新工场--我的新公司
- xcache本地缓存的设计(一)
- VS2008平台下,MFC操作EXCEL简单示例
- Java多线程初学者指南(4):线程的生命周期
- ASP如何计算中英文混合字符串长度和截取字符串
- CoProc.au3
- 大胆的投资自我
- 李开复:再见,谷歌
- 工作日志——2009-09-07
- ANT_Xdoclet