3

我正在尝试使用 JCS 1.3 创建一个永久磁盘缓存。我希望缓存能够关闭,然后在我下次使用它时从磁盘重新加载。我有很多数据要从需要很长时间才能运行的数据库中填充,如果缓存只是从磁盘重新加载,它会快得多。我已经尝试通读 JCS 文档并使用他们的配置示例开始工作,但到目前为止还没有成功。这是我正在使用的配置

##############################################################
##### Default Region Configuration
jcs.default=DC
jcs.default.cacheattributes=org.apache.jcs.engine.CompositeCacheAttributes
jcs.default.cacheattributes.MaxObjects=100
jcs.default.cacheattributes.MemoryCacheName=org.apache.jcs.engine.memory.lru.LRUMemoryCache
jcs.default.cacheattributes.DiskUsagePatternName=UPDATE

##############################################################
##### CACHE REGIONS
jcs.region.myRegion1=DC
jcs.region.myRegion1.cacheattributes=org.apache.jcs.engine.CompositeCacheAttributes
jcs.region.myRegion1.cacheattributes.MaxObjects=1000
jcs.region.myRegion1.cacheattributes.DiskUsagePatternName=UPDATE
jcs.region.myRegion1.cacheattributes.MemoryCacheName=org.apache.jcs.engine.memory.lru.LRUMemoryCache
jcs.region.myRegion1.elementattributes.IsEternal=true

##############################################################
##### AUXILIARY CACHES
# Indexed Disk Cache
jcs.auxiliary.DC=org.apache.jcs.auxiliary.disk.indexed.IndexedDiskCacheFactory
jcs.auxiliary.DC.attributes=org.apache.jcs.auxiliary.disk.indexed.IndexedDiskCacheAttributes
jcs.auxiliary.DC.attributes.DiskPath=f:/eh cache
jcs.auxiliary.DC.attributes.MaxPurgatorySize=10000
jcs.auxiliary.DC.attributes.MaxKeySize=10000
jcs.auxiliary.DC.attributes.OptimizeAtRemoveCount=300000
jcs.auxiliary.DC.attributes.OptimizeOnShutdown=true
jcs.auxiliary.DC.attributes.MaxRecycleBinSize=7500

这是我正在运行的一个非常简单的测试,以确保我的配置正确。

JCS 缓存 = JCS.getInstance("myRegion1"); cache.put("key", "我的价值");

 System.out.println("Value In Cache After Put [" + cache.get("key") + "]");

 Thread.sleep(5000);

 CompositeCacheManager.getInstance().shutDown();
 cache = JCS.getInstance("myRegion1");
System.out.println("Value In Cache After Reload [" + cache.get("key") + "]");

这是我在输出中得到的:

Value In Cache After Put [my value]
Value In Cache After Reload [null]

有人能指出我正确的方向吗?不确定这是否是我的配置中的问题,或者需要在代码中执行某些操作以告诉它从磁盘刷新。

4

2 回答 2

0

我知道这个问题很老,原始海报已经找到了替代方案,但无论如何,这些都是我在经历了同样的问题后的发现。

CompositeCacheManager.getInstance()

CompositeCacheManager 保持为单例。此实例不准备在关闭后“重新武装”,因为有些对象仅在其构造函数中加载。并且单例实例永远不会被清除或重新分配。

关闭后,CompositeCacheManager实例仍然能够创建缓存对象,但它们不是完全可操作的:它们可以工作,使用基本的基于内存的缓存,但永远不会再次创建所有辅助资源(例如文件系统存储)。

对我来说,它看起来像是一个损坏的实现,但我不确定这种行为是设计使然还是错误的结果。

解决方法

如果您处于需要取消部署/部署缓存的场景中,您将不得不跳过这些getInstance()方法并管理您自己的 CompositeCacheManager 实例。

initialize()由于受保护的构造函数+受保护的方法,无法直接实例化它。创建一个子类以公开这些元素,并创建一个模仿CompositeCacheManager.getInstance()行为但没有保持永恒单一引用的部分的工厂方法。

于 2019-10-02T22:09:45.920 回答
-1

关闭调用将处理缓存。我不了解您的架构,但我没有在 JCS 上调用关闭,因为我确保在关闭 JCS 时不会调用它。这使它写入磁盘。默认情况下,它也会从磁盘加载,所以你不必在那里做任何事情。

于 2016-03-10T09:23:37.640 回答