首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >一旦达到配置的条目数/大小,无法刷新haselcast缓存

一旦达到配置的条目数/大小,无法刷新haselcast缓存
EN

Stack Overflow用户
提问于 2015-11-17 20:01:45
回答 1查看 137关注 0票数 0

想要清除hazelcast缓存。因此,一旦缓存达到最大条目数或最大堆大小,就将其刷新到文件中。

hazelcast.xml中的配置

代码语言:javascript
复制
<map name="TEST_CACHE">
    <max-size policy="PER_NODE">3</max-size>
    <eviction-policy>LFU</eviction-policy> 
</map>

测试代码

代码语言:javascript
复制
public class Test implements EntryEvictedListener , Serializable{

    private static final long serialVersionUID = -1927328346902661527L;
    private static HazelcastInstance hazelcastInstance = HazelCacheUtil
            .getHazelCacheInstance();
    private static volatile IMap<Object, Object> hazel_cache = hazelcastInstance
            .getMap("TEST_CACHE");

    public static void main(String[] args) throws Exception {
        hazel_cache.addEntryListener(new Test(),true);

        for (int i = 0; i < 3; i++) {
            hazel_cache.put(i+1, new Test());
        }
        System.out.println(hazel_cache);

        System.out.println("");
        for (Entry e : hazel_cache.entrySet()) {
            System.out.println(e.getKey() + " : " + e.getValue());
        }
    }

    @Override
    public void entryEvicted(EntryEvent e) {
        System.out.println(e.getKey()+" : "+e.getOldValue()+"\n");
    }
}

而在entryEvicted中,我只获得了第三个entry对象

代码语言:javascript
复制
 Entry EVICTED :: 1
3 : com.test.CAO.Test@5a6b6126

有没有办法在达到max-size后将缓存内容刷新到文件/db中?

EN

回答 1

Stack Overflow用户

发布于 2015-11-18 17:51:21

map配置中有一个evictionPercentage。当达到最大大小时,此百分比的条目将被逐出。

还请注意,hazelcast是为大量条目而设计的,每个分区都会执行逐出操作。因此,我建议您使用1000+条目进行测试,以查看预期的结果。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/33756420

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档