xcache本地缓存的设计(一)

本文介绍了xcache缓存系统的架构设计,包括存储器、缓存元素及缓存的实现方式,并探讨了如何通过定时任务维护缓存的有效性和统计信息。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一、 存储器
需要缓存的对象是放在存储器中的,最常用就是把这些对象放在内存中。存储器是缓存的基础,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:缓存管理器,负责缓存初始化,管理多套缓存。

 

未完待续~!

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值