inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

스프링 핵심 원리 - 기본편

싱글톤 방식의 주의점

안녕하세요. 아래 스윙님이 하신 질문과 동일한 질문입니다.

572

유진이

작성한 질문수 28

3

저도 해당 내용이 궁금해서 질문을 남기려다가 답변 내용을 보고 그렇구나 하고 넘어갔습니다. 하지만 뭔가 이상해서 질문 남깁니다. 

스윙님의 질문 내용은 왜 config 클래스에 @Configuration을 붙이지 않았는데 싱글톤으로 관리가 되느냐였습니다. 그 답변은 스프링 컨테이너로 직접 등록하면 싱글톤으로 관리가 된다였구요. 

그런데 다음강의의 ConfigurationSingletonTest 클래스의 configurationTest를 보고, 강의를 들으면 AppConfig에 @Configuration이 있기 때문에 싱글톤으로 관리가 되고 있다고 합니다. 또한 제거하면 유지가 되지 않는다고 하고있고요. 그 사실을 찍어서 객체 생성이 몇번 일어나는지, 객체가 동일한지로 판단하고 있습니다. 

보시다시피 해당 메서드에서는 스프링 컨테이너를 통해 AppConfig를 설정 파일로 쓰고 있습니다. 그렇다면 스윙님의 질문에 대한 답변에 의하면 @Configuration이 붙던, 아니던 싱글톤이 유지되어야 하는데, 이 강의 회차의 주 내용이 @Configuration이 있기 때문에 싱글톤이 유지되고, 없다면 유지되지 않는다는 내용이라서 이부분에 대해서 재차 궁금합니다. 

따라서 TestConfig에 @Configuration을 붙이지 않은 이유와 붙이지 않아도 싱글톤으로 작동한 이유가 궁금합니다. 제가 잘못 이해한 부분이 있으면 설명 부탁드리겠습니다. 감사합니다.

oop spring

답변 2

1

최진

결국은 StateFulService의 생성자는 한번만 호출되기 때문에 @Configuration으로 중복생성을 막지 않아도 한개만 만들어졌던 거네요. 저도 궁금했던 점인데 도움이 되었습니다!

0

poowermann

설령 더 호출되더라도, 빈에 등록될 객체가 아닌 일반 객체가 만들어진다면 여전히 빈은 하나로써, 기존 코드에서처럼 빈 조회시 영향이 없습니다!

생각 정리하는 차원에서 작성해봤어요.

1

David

안녕하세요. 유진이님, 공식 서포터즈 David입니다.

1. TestConfig에 @Configuration을 붙이지 않은 이유는 "수동으로 객체를 빈으로 등록"하는 건 TestConfig가 빈으로 등록되어야 하는 것과 @Bean 애노테이션 2가지로도 가능하기 때문입니다. 싱글톤을 보장하는 것과 별개로요.

 

2. @Configuration을 붙이지 않았지만 컨테이너 생성시 파라미터로 TestConfig를 넘겼기 때문에 스프링 빈으로 등록됩니다. TestConfig 자체는 싱글톤 스코프 빈으로 컨테이너에 등록됩니다. 아마 이런 맥락에서 @Configuration이 없어도 싱글톤으로 동작한다고 말한 것 같습니다. 대신, TestConfig 내 객체 생성 메서드의 경우 호출시 싱글톤을 보장하지 않고 매번 새로운 객체를 생성합니다.

 

@Configuration이 붙지 않았을 때 싱글톤이 보장되지 않는 것에 대한 자세한 내용은 아래 글 답변을 참고해주세요.

https://www.inflearn.com/questions/323589?re_comment_id=159873

 

감사합니다.

2

유진이

친절한 답변 감사합니다.

1. @Configuration을 붙이지 않아도 스프링 컨테이너 생성 시 파라미터로 설정정보를 넘길때, @Bean 어노테이션을 붙일때 빈으로 등록된다.

2. @Configuration을 붙이지 않아도 스프링 컨테이너로 설정정보를 넘기면 해당 설정파일은 싱글톤으로 관리된다. 하지만 해당 클래스 내에서 사용되는 메서드 안의 객체들에 대해서는 싱글톤을 보장하지 않는다. 

답변 주신 것 한번 정리해봤는데 말씀하신 부분이 맞나요?

0

David

0

유진이

고맙습니다

 

0

백지우

/대신, TestConfig 내 객체 생성 메서드의 경우 호출시 싱글톤을 보장하지 않고 매번 새로운 객체를 생성합니다. -> 이 부분이 이해가 잘되지 않는데 좀 더 자세히 설명 부탁드립니다. 스프링 등록하면 싱글톤으로 동작해야하는것 아닌가요...

0

David

싱글톤 빈으로 등록되는 것과 빈에서 객체를 생성하는 것은 별개입니다.

코드 자료

0

41

2

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

0

53

2

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

0

75

1

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

0

90

1

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

0

81

1

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

0

77

1

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

0

121

2

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

0

85

1

provider 사용하는 이유

0

89

1

다음 강의 뭘 들어야 할까요

0

126

2

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

0

65

1

beanB

0

82

2

퀴즈다시풀기

0

68

1

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

0

92

2

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

0

67

3

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

0

106

2

도메인의 정의?

0

59

1

ApplicationContext 질문입니다.

0

63

1

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

0

89

2

ai api 선정하기 관련 질문

0

118

2

생성자 자동주입 관련해서

0

65

1

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

0

97

2

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

1

65

1

12:25

0

78

2