인프런 영문 브랜드 로고
인프런 영문 브랜드 로고

인프런 커뮤니티 질문&답변

ajdsasld님의 프로필 이미지

작성한 질문수

자바 ORM 표준 JPA 프로그래밍 - 기본편

영속성 컨텍스트 2

영속성 컨텍스트 2 강의에서 질문있습니다~

해결된 질문

작성

·

39

0

학습하는 분들께 도움이 되고, 더 좋은 답변을 드릴 수 있도록 질문전에 다음을 꼭 확인해주세요.

1. 강의 내용과 관련된 질문을 남겨주세요.
2. 인프런의 질문 게시판과 자주 하는 질문(링크)을 먼저 확인해주세요.
(자주 하는 질문 링크: https://bit.ly/3fX6ygx)
3. 질문 잘하기 메뉴얼(링크)을 먼저 읽어주세요.
(질문 잘하기 메뉴얼 링크: https://bit.ly/2UfeqCG)

질문 시에는 위 내용은 삭제하고 다음 내용을 남겨주세요.
=========================================
[질문 템플릿]
1. 강의 내용과 관련된 질문인가요? (예/아니오)
2. 인프런의 질문 게시판과 자주 하는 질문에 없는 내용인가요? (예/아니오)
3. 질문 잘하기 메뉴얼을 읽어보셨나요? (예/아니오)

[질문 내용]
여기에 질문 내용을 남겨주세요.

 

만약 JPA에서 batch_size 기능을 사용하지 않는다면, 그리고 영속성 컨텍스트의 쓰기 지연 SQL 저장소에 쿼리 2개가 모여있는 상태라면, 

커밋되기 전에 각각 다른 네트워크로 즉, 애플리케이션에서 DB로 요청이 2번 진행되서 쿼리가 날라가는 건가요?

 

그래서 batch_size 옵션으로 = 2가 되면 하나의 네트워크로 2개의 쿼리가 동시에 반영이 되는 건가요?

 

그래서 batch_size 옵션을 사용하면 API 속도 개선에 사용할 수 있는건가요??

근데, 그렇다면 사실 무조건 batch_size 옵션을 최대한 크게 설정하면 좋은 거 아닌가요? 이것도 한꺼번에 너무 많은 쿼리들을 보내면 또 문제가 있으려나요??

 

답변 1

1

인프런 AI 인턴님의 프로필 이미지

안녕하세요, 인프런 AI 인턴입니다. ajdsasld님.

JPA에서 batch_size 옵션을 사용하면 효율적인 네트워크 트래픽 관리를 통해 성능을 극대화할 수 있는 중요한 기술이 있습니다. 이 옵션이 설정되지 않으면, 영속성 컨텍스트의 쓰기 지연 SQL 저장소에 있는 각 쿼리가 개별적으로 DB로 전송됩니다. 이는 네트워크 요청이 증가하게 되어 성능 저하의 원인이 될 수 있습니다. 하지만 batch_size를 설정하면 지정된 갯수만큼 쿼리를 묶어 한 번에 DB로 전송하기 때문에 네트워크 오버헤드를 줄일 수 있습니다.

batch_size=2로 설정하면 두 개의 쿼리가 모였을 때 한 번의 네트워크 호출로 처리되어 성능이 향상될 수 있으며, 이는 API 호출 속도 개선에도 기여할 수 있습니다. 그러나 너무 큰 batch_size를 설정하는 경우, 메모리 사용량이 증가할 수 있고, 한 번에 너무 많은 쿼리를 처리하려다 오히려 성능이 저하될 수도 있습니다. 따라서 시스템의 메모리와 트래픽 상태를 고려하여 적절한 값을 설정하는 것이 중요합니다.

유사한 질문과 답변 내용을 여기에서 확인하시기 바랍니다.

저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다. 현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏 추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.

ajdsasld님의 프로필 이미지

작성한 질문수

질문하기