inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

토비의 스프링 부트 - 이해와 원리

@Configuration과 proxyBeanMethods

proxyBeanMethods=false 와 관련해서 질문이 있습니다.

1662

비가싫어요

작성한 질문수 87

0

 proxyBeanMethods=false 을 사용하면 Bean 오브젝트가 싱글톤 빈처럼 같은 오브젝트가 리턴되는 것이 아니라 매번 새로운 오브젝트가 생성된다고 하셨는데 이렇게 굳이 새로운 오브젝트를 매번 생성하는 이유가 있을까요?

새로운 오브젝트를 생성하는 비용보다 프록시 생성을 해서 싱글톤 방식으로 같은 오브젝트를 리턴하는 비용이 더 크기 때문일까요?

왜 그렇게 설정을 하는 것인지 궁금합니다.

spring spring-boot spring-jdbc

답변 1

7

토비

proxyBeanMethods는 스프링 5.2에서 처음 등장했습니다. 그 전에 이미 @Configuration이 아닌 일반 빈 클래스에서 @Bean을 사용할 수 있게 해주는 @Bean Lite Mode도 소개됐습니다.

여러가지 이유를 생각해볼 수 있습니다.

첫째는@Configuration 클래스에 cglib 런타임 코드 생성 기술을 적용해서 프록시 방식으로 감싸서 동작하기 때문에 생성 비용이 더 크기 때문이다를 들 수 있는데, 사실 이건 아주 미미합니다. 초기에 딱 한번 빈 생성할 때 일어날 뿐이고 사실 요즘 하드웨어에서 느낄 수 있을만큼의 성능저하가 있는 것도 아닙니다. 그렇게 치면 프록시를 cglib으로 만드는 @Transactional도 AOP 프록시 생성 비용 문제가 있을텐데 그 이상의 유용함이 있고, 성능 영향은 아주 미미하기 때문에 디폴트로 cglib proxy 방식을 사용합니다.

둘째는 @Configuratin의 프록시 방식 @Bean 메소드가 여러번 호출할 때 매번 동일 오브젝트가 실행되는 것이 자바 코드를 봤을 때 기대하는 방식과 다르다는 것인데요. 제 입장은 이게 더 중요하다고 봅니다. 해당 클래스를 테스트 등에서 직접 사용해서 @Bean 메소드를 호출했을 때와 런타임에 스프링에 올라가서 사용되었을 때 동작 방식이 다르다는 것은, 상당한 인지 부하들 줄 뿐더러 코드의 동작 방식을 이해하는데 방해가 됩니다. 게다가 @Bean Lite-mode의 메소드와 @Configuration @Bean 메소드가 동작하는 방식이 다르다는 것도 혼동을 줄 여지가 큽니다.
물론 그래야만 했던, 싱글톤 스코프의 빈 오브젝트 생성 메소므를 다른 빈 오브젝트를 생성하는 코드에서 여러번 호출했을 때 여러 개의 오브젝트가 만들어지는 문제를 해결해야 한다는 이유가 있긴하죠. 그런데 이건 메소드 직접 호출 대신에 @Bean 메소드 파라미터로 주입 받는 방식을 이용하면 프록시 없이도 간단히 해결됩니다.

Lite Mode와의 일관성, 그리고 코드가 환경에 따라 다르게 동작하는 문제, 자바 언어의 기본 동작 방식을 위배한다는 문제가 있었고, 대안도 충분히 있기 때문에 proxy 없는 @Configuration을 사용하게 하는게 지금은 권장 비슷하게 되고 있긴한데요.

여전히 스프링 3 이후 코드와의 호환성 때문에 proxy=true가 디폴트일 수 밖에 없긴합니다. 하지만 강의에서도 설명했듯이 스프링 부트의 자동 구성 @Configuration 클래스들은 대부분 proxyBeanMethods=false를 사용합니다.

그리고 이 옵션이 들어가던 즈음이 GraalVM의 네이티브 컴파일 기능을 적극 수용하려고 스프링이 노력하고 있던 때였는데 런타임의 코드 생성 기술인 cglib은 잘 맞지 않는 장애물로 보였을 것입니다. 그래서 cglib을 최대한 사용하지 않도록 개선하려는 노력을 했다는 이야기도 얼핏 들었는데 이건 확실히 모르겠습니다.

0

비가싫어요

자세한 설명 감사드립니다!

11강에서 cmd에서 spring shell에 $ init 하면 Fail 메세지

0

76

2

TestRestTemplate 을 통해 테스트 실행시 웹 요청 정보가 콘솔에 표시되지 않습니다.

0

85

1

섹션7. 자동구성 정보파일분리 강의 질문(@MyAutoConfiguration 붙힌 이유)

0

202

2

WebApplicationContext를 DispatcherServlet에 this로 넘기는 것

0

279

2

인프라 빈 구성 정보의 분리에서 EnableMyAutoConfiguration 질문드립니다.

0

211

2

질문드립니다.

0

233

2

spring boot 3.3.7로 학습중입니다.

0

372

2

Serverproperties 객체 생성 후 @Impor 어노테이션 사용 이유 용도

0

162

2

spring start io 에서 이제더이상 2.x버전은 지원하지 않는 것 같습니다.

1

299

2

Springboot 3.2 이상에서 파라미터 추론관련

0

918

4

binding error

0

223

3

Arrays.copyOf 메서드의 타입 세이프

1

156

2

MyOnClassCondition에 있는 matches method의 Invoke 횟수

1

233

3

인용구의 출처가 궁금합니다.

0

259

1

프로퍼티 빈의 후처리기 도입 AnnotationUtils의 사용

0

236

2

SimpleCacheConfiguration과 빈 등록

0

169

2

MyAutoConfigImportSelector 에서 생성자로 ClassLoader를 주입받을 수 있는 점

0

244

1

IntelliJ project jenerator spring initailizr

0

150

1

강의 자료 레퍼지토리에 업로드

0

216

1

강의자료

0

388

1

Hikari 라이브러리가 없으면 오류가 나는거 아닌가요

0

314

2

Tomcat 포트 프로퍼티 미설정시 랜덤 포트 설정 문의

0

477

5

@Import 로 Bean을 등록해야하는 기준이 뭔지 궁금합니다.

0

343

2

application.properties파일내 프로퍼티 이름

0

214

1