在库中使用时创建Apache JCS缓存confilicts

时间:2016-07-25 14:34:08

标签: java apache caching jcs

长话短说,我创建了一个使用Apache JCS来管理自己对象的库。使用

CompositeCacheManager ccm CompositeCacheManager.getUnconfiguredInstance();
Properties props = new Properties();
props.load(fis);

ccm.configure(props);

CompositeCache<Serializable, Serializable> cache = ccm.getCache(CACHE_NAME);

上面,它从文件中读取配置并加载到缓存管理器,并且在使用测试应用程序测试库时一切正常。

但在我的实际应用程序中,我也使用JCS来管理与应用程序相关的对象,这就是问题发生的地方。

当应用程序启动时,它首先实例化应用程序缓存管理器,并成功加载所有配置并创建我想要的内容。

但对于库的缓存管理器,它根本不使用我的配置,并且听起来它实例化了一些默认的Cache实例。例如,在我的图书馆配置中,我有:

jcs.region.MYREGION=DCACHE
jcs.region.MYREGION.cacheattributes=org.apache.commons.jcs.engine.CompositeCacheAttributes
jcs.region.MYREGION.cacheattributes.MaxObjects=1200
jcs.region.MYREGION.cacheattributes.MemoryCacheName=org.apache.commons.jcs.engine.memory.lru.LRUMemoryCache
jcs.region.MYREGION.cacheattributes.DiskUsagePattern=UPDATE

DCHACHE辅助定义为:

jcs.auxiliary.DCACHE=org.apache.commons.jcs.auxiliary.disk.indexed.IndexedDiskCacheFactory
jcs.auxiliary.DCACHE.attributes=org.apache.commons.jcs.auxiliary.disk.indexed.IndexedDiskCacheAttributes
jcs.auxiliary.DCACHE.attributes.DiskPath=LIB_DATA_DIR
jcs.auxiliary.DCACHE.attributes.MaxPurgatorySize=10000
jcs.auxiliary.DCACHE.attributes.MaxKeySize=10000
jcs.auxiliary.DCACHE.attributes.OptimizeAtRemoveCount=300000
jcs.auxiliary.DCACHE.attributes.MaxRecycleBinSize=7500

证明它没有使用相关配置的证据是: 它使用SWAP创建了MYREGION的DiskUsagePattern(我也尝试过DiskUsagePatternName,但没有任何区别)。

它不使用LIB_DATA_DIR作为DisckPath。而是使用我已经为应用程序配置定义的那个。

如果我评论应用程序的JCS相关代码,它适用于图书馆的JCS。

我也尝试过JCS.getInstance(&#34; cache_name&#34;),但没有区别。

你们有什么想法吗?

1 个答案:

答案 0 :(得分:0)

经过几个小时的深入研究,我们发现JCS很难处理分离的配置文件。听起来JCS只能使用每个java虚拟机的配置文件配置一次。

所以我最终使用一个文件来配置JCS。这样,如果应用程序实例化JCS冷杉,它也会加载库的配置,稍后在库中,一切都运行良好。