inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

기본 키 매핑

시퀀스 최적화의 이점에 대해 질문드립니다.

339

맥스

작성한 질문수 51

0

처음에 실습 전에 강의에서 들은바로는 call을 통해 가져오면 네트워크를 타기 때문에 성능 문제가 생길 수 있어서 미리 일정량의 사이즈를 DB에 올려놓고 메모리에서 그 갯수만큼 쓰는 방식을 통해 최적화할 수 있다고 이해했습니다.

그런데 실습을 따라하면서 main()을 재실행할때마다

image.pngimage.png

이렇게 50개씩 확보를 해버리는데 그럼 main을 한 번 실행할 때 50개의 persist 가 나가야 성능이 최적화될 수 있는걸까요? 스프링이 아닌 자바로 실행해서 서버가 그냥 내려가니까 생기는 문제일까요?

정리하면, 실제 웹 어플리케이션 서버 구동 상황에서는 실습처럼 서버가 바로 내려가는게 아니라 작동된 상태로 유지되고 그 텀 안에서 50개의 메모리를 최적화해서 쓸 수 있는게 맞을까요?

java jpa

답변 2

0

OMG

안녕하세요. 초보개발자님, 공식 서포터즈 OMG입니다.

이해하신게 맞습니다 😀

시퀀스 조회를 위해 DB와의 통신 횟수를 최적화하여 미리 사용할 시퀀스를 한번에 퍼올리기 위함인데, 강의에서는 강의 특성상 JVM을 종료하고 실행을 할 수 밖에 없는 상황이다보니 퍼올린 갯수만큼의 시퀀스를 사용하지 못하게 됩니다 😀

감사합니다.

0

인프런 AI 인턴

안녕하세요, 인프런 AI 인턴입니다. 초보개발자님의 질문에 관하여 “시퀀스 최적화”와 관련된 명확한 해설을 드리겠습니다.

시퀀스 최적화의 핵심은 데이터베이스에 대한 연속적인 네트워크 요청을 줄여 성능을 향상시키기 위해 사용됩니다. 즉, 데이터베이스 시퀀스의 값은 일정량(예: 50개)을 한번에 메모리로 가져와서 필요할 때마다 메모리에서 하나씩 사용합니다. 이 방식은 매번 데이터베이스에 시퀀스 값을 요청하지 않아도 되므로 트랜잭션 처리 시간을 단축할 수 있습니다.

귀하께서 언급한 “main()을 재실행할 때마다 시퀀스 값이 50개씩 증가하는 현상”은 실제로 자바 어플리케이션(스프링 프레임워크를 사용하지 않는 경우 포함)이 재시작될 때마다 발생합니다. 이는 서버가 종료되면서 메모리에 저장된 시퀀스 범위가 초기화되기 때문입니다. 재시작할 때마다 데이터베이스에서 새로운 시퀀스 범위를 가져오기 때문에, 사용되지 않은 시퀀스 번호들은 “소실”될 수 있습니다.

웹 애플리케이션 서버 환경에서는 서버가 계속해서 실행 상태를 유지하며, 이를 통해 메모리에 미리 로드된 시퀀스 번호들을 효율적으로 사용할 수 있습니다. 애플리케이션이 오랜 시간 동안 실행될 경우, 처음에 불러온 시퀀스 번호들은 순차적으로 소비되며, 필요 시 다음 범위의 시퀀스를 데이터베이스로부터 메모리로 가져올 수 있습니다. 따라서, 실제 웹 어플리케이션 상황에서는 시퀀스 값을 효율적으로 관리할 수 있습니다.

해당 주제와 관련하여 Kim Young-han 강사님이 직접 답변한 유사 질문들을 추천해 드리겠습니다.
- “시퀀스 방식에 대해서 질문을 드립니다.“에서는 시퀀스 최적화의 작동 방식에 대해 간략하게 설명합니다.
- “SEQUENCE 전략 초기값과 호출 횟수 문의드립니다.”에서는 시퀀스 전략 및 초기값 설정에 대한 깊이 있는 설명을 제공합니다.

이 질문들은 시퀀스를 사용함에 있어 흔히 발생할 수 있는 혼란을 해소하고, 메모리에서 시퀀스 번호를 관리하는 방법에 대한 이해를 돕습니다. 특히 백엔드 시스템에서 데이터의 일관성과 성능 최적화를 추구하는 상황에 매우 유익합니다.

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

벌크연산에서 member.getAge 호출 시 영속성 컨텍스트에서 데이터를 가져오는건가요?

0

33

2

inheritance startegy 선택시 고려사항

0

24

1

Entity 동등성 비교

0

25

1

실무 조언 관련 질문입니다.

0

48

1

H2데이터베이스 파일 생성

0

60

2

서브쿼리 강의에서 ALL 예시 관련 질문드립니다.

0

57

2

수정또는 삭제시 영속성 엔티티에 값이 무조건 있어야 하나요?

0

58

1

JPQL 메소드와 락

0

56

1

Delivery @OneToOne

0

63

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

112

2

양방향 연관관계에서 연관관계의 주인(mappedBy)을 왜 꼭 정해야 하나요?

0

83

1

영속성 컨텍스트

0

70

1

JPA 프록시

0

100

1

Native Query와 MyBatis

0

74

1

영속성 컨텍스트는 어떤 메모리에 저장되는건가요?

0

93

1

임베디드 타입 예시 코드 관련 질문

0

121

3

명시적 조인에서 별칭을 주면 왜 객체에 접근할 수 있나요

0

97

3

인텔리제이 패키지 커서 단축키 질문

0

109

2

혹시 현재는 ID 데이터 타입이 String이면 안되나요?

0

149

1