我尝试了 Ignite 2.0 和 2.3 来验证简单的缓存驱逐。但观察到它坏了,但如果我恢复到 1.9,它就可以正常工作。
这是我在 2.x 中的代码
CacheConfiguration cc = new CacheConfiguration();
cc.setName("mycache");
cc.setCacheMode(CacheMode.PARTITIONED);
cc.setOnheapCacheEnabled(true);
cc.setEvictionPolicy(new LruEvictionPolicy(5));
IgniteConfiguration cfg = new IgniteConfiguration();
cfg.setCacheConfiguration(cc);
Ignite ignite = Ignition.start(cfg);
IgniteCache<String,String> cache = ignite.getOrCreateCache(cc);
for(int i=0;i<10;i++){
cache.put("k"+i,"val-"+i);
}
Thread.sleep(1000);
for(int i=0;i<10;i++) {
System.out.println(cache.get("k"+i));
}
System.out.println("============================== " + cache.metrics().getSize());
输出打印所有 10 个缓存条目,但它应该只打印从缓存键 key5 到 k10 的值。因为我的 LRU 最大大小=5。但如果我将 ignite 版本更改为 1.9,一切都会按预期工作。
这是一个已知问题吗?还是我做错了什么。
最佳答案
自 2.0 版本起,Ignite 使用堆外内存。它按页分配内存,当可用空间耗尽时,它们可能会被驱逐。您可以在这里找到此机制的描述:https://apacheignite.readme.io/docs/evictions#section-off-heap-memory
因此,当 90% 的内存被占用时,您可以告诉 Ignite 开始从某个特定数据区域逐出页面。
您启用了不同类型的逐出策略,即从 Java 堆逐出。它不会影响存储在堆外空间中的数据。堆空间不是替代方案,它只是堆外内存之上的附加数据层。以下是有关 Java 堆逐出策略的文档:https://apacheignite.readme.io/docs/evictions#section-java-heap-cache
关于java - Apache Ignite Eviction 在 2.x 中被破坏,但在 1.9 中工作正常,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48314340/