작성
·
312
답변 2
1
안녕하세요. jung4102님 좋은 질문입니다.
만약 team을 데이터베이스에서 조회할 때 한번에 수십만개를 조회하게 되면 모두 1차 캐시로 들어갑니다.
그럴 경우 Out of Memory가 발생할 수 있습니다.
1차 캐시가 감당할 수 있는 데이터 양은 객체 하나당 얼마의 메모리를 먹는지 계산을 하고, JVM의 최대 힙 사이즈를 넘지 않으면 됩니다.
하지만 이 부분은 크게 걱정은 안하셔도 되는 것이, 대부분의 웹 애플리케이션은 데이터베이스에서 엔티티를 조회할 때 한번에 10개에서 1000개 정도로 페이징 처리를 해서 조회하게 됩니다. 그리고 그 결과가 응답 되고 나면 1차 캐시가 사라지기 때문에 해당 객체들도 GC의 대상이 됩니다.
추가로 1차캐시에 엔티티 스냅샷을 보관하지 않고, 메모리를 절약하는 방법도 있습니다. 자세한 내용은 JPA 책 15.4.2 읽기 전용 쿼리의 성능 최적화를 참고해주세요^^
감사합니다.
0