fetch join을 했을 경우 1차 캐시에 많은 데이터가 담기면 어떻게 되나요?
392
6 asked
안녕하세요.
강의 듣는 중 질문이 있어 남깁니다.
만약 team의 개수가 수, 수십만개의 데이터가 나오는 경우라면 모두 1차캐시로 들어가는 건가요?
만약 그럴 경우 생기는 문제는 없는건가요?
영속성 컨텍스트의 1차캐시가 감당할 수 있는 데이터의 양은 얼마나 되는건가요?
좋은 강의 감사합니다~^^
Answer 2
1
안녕하세요. jung4102님 좋은 질문입니다.
만약 team을 데이터베이스에서 조회할 때 한번에 수십만개를 조회하게 되면 모두 1차 캐시로 들어갑니다.
그럴 경우 Out of Memory가 발생할 수 있습니다.
1차 캐시가 감당할 수 있는 데이터 양은 객체 하나당 얼마의 메모리를 먹는지 계산을 하고, JVM의 최대 힙 사이즈를 넘지 않으면 됩니다.
하지만 이 부분은 크게 걱정은 안하셔도 되는 것이, 대부분의 웹 애플리케이션은 데이터베이스에서 엔티티를 조회할 때 한번에 10개에서 1000개 정도로 페이징 처리를 해서 조회하게 됩니다. 그리고 그 결과가 응답 되고 나면 1차 캐시가 사라지기 때문에 해당 객체들도 GC의 대상이 됩니다.
추가로 1차캐시에 엔티티 스냅샷을 보관하지 않고, 메모리를 절약하는 방법도 있습니다. 자세한 내용은 JPA 책 15.4.2 읽기 전용 쿼리의 성능 최적화를 참고해주세요^^
감사합니다.
벌크연산에서 member.getAge 호출 시 영속성 컨텍스트에서 데이터를 가져오는건가요?
0
40
2
inheritance startegy 선택시 고려사항
0
27
1
Entity 동등성 비교
0
27
1
실무 조언 관련 질문입니다.
0
53
1
H2데이터베이스 파일 생성
0
61
2
서브쿼리 강의에서 ALL 예시 관련 질문드립니다.
0
59
2
수정또는 삭제시 영속성 엔티티에 값이 무조건 있어야 하나요?
0
58
1
JPQL 메소드와 락
0
57
1
Delivery @OneToOne
0
64
1
17강 4~5분대 테이블 값 조회가 안됩니다.
0
98
2
UnsupportedOperationException 발생
0
89
3
H2 Database 연결이 안됩니다.
0
98
2
연관관계 매핑 질문드립니다.
0
88
2
h2데이터베이스 실행오류
0
110
2
persistence.xml
0
113
2
양방향 연관관계에서 연관관계의 주인(mappedBy)을 왜 꼭 정해야 하나요?
0
84
1
영속성 컨텍스트
0
70
1
JPA 프록시
0
100
1
Native Query와 MyBatis
0
74
1
영속성 컨텍스트는 어떤 메모리에 저장되는건가요?
0
95
1
임베디드 타입 예시 코드 관련 질문
0
121
3
명시적 조인에서 별칭을 주면 왜 객체에 접근할 수 있나요
0
97
3
인텔리제이 패키지 커서 단축키 질문
0
110
2
혹시 현재는 ID 데이터 타입이 String이면 안되나요?
0
149
1

