자동 구성 정보 클래스를 작성한다면
@Configuration(proxyBeanMethods = false)
static class MyConfig {
private final Common common;
public MyConfig(Common common) {
this.common = common;
}
@Bean
public Bean1 bean1() {
System.out.println("bean1 생성자");
return new Bean1(common);
}
@Bean
public Bean2 bean2() {
System.out.println("bean2 생성자");
return new Bean2(common);
}
}
@Configuration(proxyBeanMethods = false)
static class MyCommonConfig {
@Bean
public Common common() {
return new Common();
}
}과
@Configuration(proxyBeanMethods = false)
static class MyConfig {
@Autowired
private Common common;
public MyConfig() {
}
@Bean
public Bean1 bean1() {
System.out.println("bean1 생성자");
return new Bean1(common);
}
@Bean
public Bean2 bean2() {
System.out.println("bean2 생성자");
return new Bean2(common);
}
@Bean
public Common common() {
return new Common();
}
}빈 구성 정보를 프록시 객체로 생성하지 않는다는 대안을 코드로 작성해보면
별도의 구성 정보를 사용하는 방식과
내부에서 필드 주입으로 초기화 하는 방식이 생각났습니다.
별도의 구성정보를 사용하면 어떤 클래스를 의존하는지 생성자를 보고 확인할 수 있다는 장점과 테스트 코드를 작성할때 더 편할거라 생각이 들고,
밑에 방식은 Common이라는 클래스가 MyConfig 에서만 사용된다면 관리하기도 편할거라 생각이 들었습니다. 그리고 설정 정보 클래스니까 굳이 생성자로 초기화를 하지 않아도 되지 않을까 라는 생각도 들었습니다.
강사님께서 Config 클래스도 테스트를 해봐야한다고 말씀해주셨는데
이런 경우라면 상황에 따라 선택해야하는 부분인가요 ?
아니면 설정 정보도 환경에 따라 다를 경우가 있느니까 별도로 분리하는게 나을까요?
답변 2
1
같은 클래스 내에서 정의된 빈을 의존하는 다른 빈이 존해하는 경우엔 디폴트인 프록시 방식을 쓰는게 낫겠네요.
두번째 방식이라면 common빈을 만들기 위해서 MyConfig 오브젝트가 먼저 만들어져야 하는데, common을 가져올 때까지 @Autowired도 적용을 못할텐데 이게 동작할지 모르겠네요. Proxy를 안 쓰면서 굳이 같은 클래스에 넣으려면 common 빈은 static 메소드로 만들어야 할 겁니다.
첫번째 방식으로 분리하거나 common 오브젝트를 다른 @Bean 메소드의 파라미터로 주입되도록 하는게 나을 것 같기도 하고요.
0
안녕하세요, 인프런 AI 인턴입니다.
해당 내용과 유사한 질문과 강사님의 답변이 있는 게시글을 찾았습니다.
강사님께서는 JdbcTemplate과 JdbcTransactionManager의 적용 순서에 대해 언급하시며, 스프링 부트에서는 정석적인 방법을 따르기보다는 편의상 하나의 구성 정보에 넣는 경우가 있다고 설명하셨습니다. 그러나 자동 구성의 순서가 중요한 경우가 있어서, 이를 위해 @AutoConfiguration 애노테이션의 before, after 항목을 사용하여 순서를 지정할 수 있다고 말씀해주셨습니다.
이와 관련된 더 자세한 설명은 아래 링크에서 확인할 수 있습니다.
- 게시글 제목: @MyAutoConfiguration 에서 궁금한게 있습니다.
- 링크: 인프런 질문게시판 - @MyAutoConfiguration 에서 궁금한게 있습니다.
위 내용과 더불어 Config 클래스의 테스트 필요성에 대해서도 동일 게시물에서 설명이 되어있으니 함께 참고하시면 좋을 것 같습니다.
11강에서 cmd에서 spring shell에 $ init 하면 Fail 메세지
0
75
2
TestRestTemplate 을 통해 테스트 실행시 웹 요청 정보가 콘솔에 표시되지 않습니다.
0
85
1
섹션7. 자동구성 정보파일분리 강의 질문(@MyAutoConfiguration 붙힌 이유)
0
201
2
WebApplicationContext를 DispatcherServlet에 this로 넘기는 것
0
279
2
인프라 빈 구성 정보의 분리에서 EnableMyAutoConfiguration 질문드립니다.
0
210
2
질문드립니다.
0
232
2
spring boot 3.3.7로 학습중입니다.
0
369
2
Serverproperties 객체 생성 후 @Impor 어노테이션 사용 이유 용도
0
162
2
spring start io 에서 이제더이상 2.x버전은 지원하지 않는 것 같습니다.
1
295
2
Springboot 3.2 이상에서 파라미터 추론관련
0
913
4
binding error
0
220
3
Arrays.copyOf 메서드의 타입 세이프
1
155
2
MyOnClassCondition에 있는 matches method의 Invoke 횟수
1
233
3
인용구의 출처가 궁금합니다.
0
259
1
프로퍼티 빈의 후처리기 도입 AnnotationUtils의 사용
0
236
2
SimpleCacheConfiguration과 빈 등록
0
168
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
476
5
@Import 로 Bean을 등록해야하는 기준이 뭔지 궁금합니다.
0
340
2
application.properties파일내 프로퍼티 이름
0
210
1





