inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

스프링 DB 1편 - 데이터 접근 핵심 원리

DataSource 예제2 - 커넥션 풀

한 번에 많은 양의 커넥션이 필요할 경우

해결된 질문

458

개발하는쿼카

작성한 질문수 43

0

안녕하세요. 영한님!

 

커넥션 풀을 이용해서 애플리케이션 실행 시점에 DB와 커넥션을 미리 생성하고, 커넥션이 다 사용되고 나면 커넥션 풀로 반환하는 것으로 이해했습니다.

 

그런데 만약에 커넥션 풀 보다 많은 요청이 들어오면 어떻게 해야하는 걸까요?
(테스트한 결과 커넥션 풀에 커넥션이 없으면 새로 커넥션을 만들지는 않는 것 같더라구요.)

제가 고민한 결과 2가지 방법이 있을것 같은데요.

  1. 커넥션 풀 사이즈를 늘린다.

    1. 리소스가 많이 소모된다.

  2. 커넥션이 커넥션 풀로 반환할 때 까지 기다리는 대기시간을 늘린다.

    1. 애플리케이션 속도에 영향을 준다.

 

제가 생각하는 것 외 더 좋은 방법이 있을까요?

감사합니다.

spring

답변 1

1

David

안녕하세요. 개발하는쿼카님, 공식 서포터즈 David입니다.

말씀하신 것들을 포함해서 4가지 방법이 있습니다.

해당 애플리케이션의 특성에 따라 적절한 방법을 선택하시면 됩니다.

비동기의 경우 R2DBC 같은 것도 참고해 보시면 좋을 것 같습니다.

  1. 블로킹(Blocking): 새로운 커넥션 요청이 들어왔을 때, 풀에 사용 가능한 커넥션이 나타날 때까지 요청을 대기 상태로 만들 수 있습니다. 이 방식은 사용 가능한 커넥션이 나올 때까지 클라이언트가 대기하게 만드므로, 클라이언트가 과도한 대기 시간을 갖게 할 수 있습니다.

  2. 타임아웃(Timeout): 클라이언트가 일정 시간 동안 대기한 후에도 여전히 사용 가능한 커넥션이 없으면, 커넥션 요청을 실패로 처리하도록 설정할 수 있습니다. 이 방식은 클라이언트의 대기 시간을 제한하지만, 너무 많은 요청이 있을 경우 요청 실패율이 증가할 수 있습니다.

  3. 커넥션 풀의 크기 조정: 예상되는 요청 수를 고려하여 커넥션 풀의 크기를 늘리는 방법도 있습니다. 이렇게 하면 한번에 처리할 수 있는 요청 수가 증가하지만, 커넥션을 많이 생성하면 메모리 사용량이 증가하고, 데이터베이스에 과도한 부하를 주게 될 수 있습니다.

  4. 비동기 처리: 동시에 처리해야 할 작업이 많을 경우, 비동기 방식으로 작업을 처리할 수 있습니다. 이 방식은 요청을 대기 상태로 만들지 않고, 처리 가능한 작업들을 먼저 실행하여 효율을 높입니다.

감사합니다.


spring initialiser 어떤걸 선택해야될지 모르겠어요

0

38

2

트랜잭션 템플릿이 체크예외는 커밋하는 이유가 궁금합니다.

0

51

1

jdbc 학습하다 궁금해서 질문드려요

0

85

1

정상이체와 이체중 예외발생 차이

0

70

2

이번 강의부터가 JDBC 직접 사용 맞나요?

0

89

1

순수한 서비스 계층에 대한 의문???

0

83

2

3_4test, 4test 자동 리소스 안됨

0

60

2

데이터베이스 선택 관련 질문.

0

71

2

after 메서드 사용 유무

0

60

2

데이터베이스 접근 및 DB 락

0

57

1

@SpingBootTest, @TestConfiguration

0

58

1

Read Committed 격리 수준 사용 관련 질문

0

51

1

AopCheck Test 부분의 EnhancerBySpring 확인 법??

0

69

2

커리큘럼 관련 질문

0

78

1

서비서 계층 스프링 프레임워크 사용

0

89

1

validation(toMember)의 위치

0

84

2

데이터 계층에서 서비스 로직의 datasource를 인식하는 방법

0

166

2

member 상수 질문

0

124

2

ctrl + F6 이후로 con 인식이 안 됩니다

0

154

2

DrivenManager 와 Connection 반환에 대한 질문입니다!

0

110

1

섹션5 트랜잭션 템플릿관련 질문(이기종 DB)

0

116

1

세션1 테이블 조회결과 그림은 Redo 로그에 속하나요?

0

103

1

트랜잭션이 필요하지 않은 경우 DB 대신 파일 시스템을 사용하는 것이 더 효율적인가?

0

98

1

강의 14분쯤 Exception 질문

0

116

2