사용자 도구

사이트 도구


java:caffeine

차이

문서의 선택한 두 판 사이의 차이를 보여줍니다.

차이 보기로 링크

다음 판
이전 판
java:caffeine [2016/03/14 20:39]
kwon37xi 만듦
java:caffeine [2024/02/08 09:08] (현재)
kwon37xi
줄 1: 줄 1:
 ====== Caffeine - java cache ====== ====== Caffeine - java cache ======
   * [[https://github.com/ben-manes/caffeine|Caffeine]] [[java:guava|Guava]]의 Cache를 대체하는 Java 8 용 캐시   * [[https://github.com/ben-manes/caffeine|Caffeine]] [[java:guava|Guava]]의 Cache를 대체하는 Java 8 용 캐시
 +  * [[https://www.baeldung.com/java-caching-caffeine|Introduction to Caffeine | Baeldung]]
  
 +
 +===== Eviction =====
 +  * [[https://github.com/ben-manes/caffeine/wiki/Eviction|Eviction · ben-manes/caffeine Wiki]]
 +==== weakKeys() / weakValues() ====
 +  * ''weakKeys()'' / ''weakValues()''  설정을 사용하면 캐시 Key와 value가 ''Weak Reference''로 저장되고, 객체 reference가 없으면 JVM GC 대상으로 지정되게 된다.
 +  * 이 경우 key 와 value 모두가 GC 대상이다.
 +  * 그러나 **Key 를 비교할 때 ''equals()'' 메소드가 아니고 identity 비교(''=='')를 하게 된다.**
 +  * 이는 Key 역할을 하는 객체가 값이 같아도 reference 가 다르면 다른것으로 인식하게 되어 cache hit 가 안됨을 뜻한다.
 +  * ''AsyncCache'' 에서 **사용불가**
 +
 +<code java>
 +LoadingCache<Key, Graph> graphs = Caffeine.newBuilder()
 +    .weakKeys()
 +    .weakValues()
 +    .build(key -> createExpensiveGraph(key));
 +</code>
 +
 +<note warning>
 +''weakKeys()''를 사용하려면 **Key 역할을 하는 객체의 레퍼런스도 캐시하던지 정적 상수로 만들던지 하는 식**으로 key 의 값이 동일하면 그 reference도 동일하게 처리해야만한다.
 +</note>
 +
 +==== softValues() ====
 +<code java>
 +LoadingCache<Key, Graph> graphs = Caffeine.newBuilder()
 +    .softValues()
 +    .build(key -> createExpensiveGraph(key));
 +</code>
 +
 +  * 캐시의 value ''SoftReference''로 GC 대상이 된다.
 +  * 값의 비교도 identity 비교(''=='') 를 사용한다.
 +  * 단, 문서에서는 ''SoftReference'' 가 JVM에서 메모리 상황에 따라 least-recently-used 방식으로 GC 대상으로 지정된다. ''SoftReference''는 성능에 영향을 줄 수 있어서 명시적으로 캐시 사이즈를 지정하는 것을 권장한다.
 +  * ''AsyncCache'' 에서 **사용불가**
java/caffeine.txt · 마지막으로 수정됨: 2024/02/08 09:08 저자 kwon37xi