inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

스프링 핵심 원리 - 기본편

싱글톤 방식의 주의점

스프링 빈은 항상 stateless로 설계해야 한다는 말에 대해 궁금증이 있습니다.

671

sprout3082

작성한 질문수 1

0

만약 스프링 특정 빈에 아래와 같이 캐시를 저장하고 있다면

Map<String,Article> articleCache

캐시로 동작하는 Map 객체는 stateful이라고 생각됩니다. 근데 이게 싱글톤으로 동작하지 않고, 매번 객체를 새로 생성한다면 캐시의 의미가 사라지지 않나요?
그래서 '스프링 빈은 항상 stateless'로 설계해야 한다가 과연 늘 옳은 말인지 궁금합니다.

spring 객체지향

답변 1

0

y2gcoder

안녕하세요. sprout3082님, 공식 서포터즈 y2gcoder입니다.

스프링의 싱글톤 빈은 여러 쓰레드에서 동시에 접근할 수 있는 구조이기 때문입니다.

예시로 주신 Map<String,Article> articleCache의 경우, 이것이 싱글톤 빈 안에 있으면 여러 쓰레드에서 동시에 접근하게 될 가능성이 높습니다. 만약 이 Map 객체가 Thread-Safe 하지 않다면, 동시성 문제가 발생할 수 있습니다.

사용자의 요청 하나당 하나의 쓰레드가 할당된다고 가정하면, 여러 사용자가 동시에 접근하게 되는 상황에서는 캐시의 동작이 예측하기 어렵습니다. 예를 들면, 사용자 A와 사용자 B가 각각 다른 쓰레드에서 동시에 캐시에 접근하게 되면 예기치 않은 상황이 발생할 수 있습니다.

이런 이유로, 스프링 빈 내부에 상태 정보를 가지고 있을 때는 그 상태 정보가 Thread-Safe하게 관리되어야 합니다. 만약 stateful한 빈을 사용하려면, 그 빈이 Thread-Safe하게 설계되어야 하며, 동시에 여러 쓰레드에서 안전하게 사용될 수 있도록 주의를 기울여야 합니다.

감사합니다.

코드 자료

0

50

2

구현체가 동적으로 정해질 때, 팩토리 기법을 사용하나요?

0

56

2

MemberService의 인터페이스를 왜 사용하는지 궁금합니다.

0

78

1

롬복 @Setter를 써야 하는 상황이 있는건가요?

0

92

1

빈 등록 메서드의 파라미터가 빈이 아니어도 되나요?

0

81

1

테스트 속도가 나중에 영향이 있을까요?

0

77

1

gradle 설정 안떠서 질문 남깁니다!

0

122

2

build.gradle로 프로젝트를 여는 이유

0

87

1

provider 사용하는 이유

0

90

1

다음 강의 뭘 들어야 할까요

0

126

2

프로토타입 빈, 직접 destroy 호출 안 할 경우

0

66

1

beanB

0

82

2

퀴즈다시풀기

0

69

1

Gradle로 바꿔도 오류가 똑같이 발생하네요 ㅠㅠ

0

92

2

"중복 등록과 충돌" 강의에서 강사님과 다른 에러가 발생합니다.

0

67

3

run 실행했는데 결과창이 이렇게 뜨네요 왜 그런건가요>

0

106

2

도메인의 정의?

0

59

1

ApplicationContext 질문입니다.

0

63

1

@Scope의 proxyMode를 사용할때 단위 테스트 방법

0

90

2

ai api 선정하기 관련 질문

0

118

2

생성자 자동주입 관련해서

0

66

1

생성자 직접 호출 vs 팩토리 메서드 패턴

0

97

2

Spring에서 SessionScope와 RequestScope는 함께 사용되나요?

1

66

1

12:25

0

79

2