이번에는 중복 등록과 충돌에 대해 알아보았다.
컴포넌트 스캔에서 같은 빈 이름을 동록하면 어떻게 될까?
1. 자동 빈 등록 vs 자동 빈 등록
2. 수동 빈 등록 vs 자동 빈 등록
자동 빈 등록 vs 자동 빈 등록 시에
컴포넌트 스캔에 의해 자동으로 스프링 빈이 등록되는데, 그 이름이 같은 경우 스프링은 오류를 발생시킨다.
수동 빈 등록 vs 자동 빈 등록
만약 수동 빈 등록과 자동 빈 등록에서 빈 이름이 충돌시에 어떻게 될까?
package hello.core;
import hello.core.member.MemberRepository;
import hello.core.member.MemoryMemberRepository;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.ComponentScan;
import org.springframework.context.annotation.Configuration;
import org.springframework.context.annotation.FilterType;
@Configuration
@ComponentScan(
excludeFilters = @ComponentScan.Filter(
type = FilterType.ANNOTATION, classes = Configuration.class)
)
public class AutoAppConfig {
@Bean(name = "memoryMemberRepository")
MemberRepository memberRepository(){
return new MemoryMemberRepository();
}
}
AutoAppConfig에
memoryMemberRepository를 등록해준다.
package hello.core.scan;
import hello.core.AutoAppConfig;
import hello.core.member.MemberService;
import org.assertj.core.api.Assertions;
import org.junit.jupiter.api.Test;
import org.springframework.context.annotation.AnnotationConfigApplicationContext;
import static org.assertj.core.api.Assertions.*;
public class AutoAppConfigTest {
@Test
void basicScan(){
AnnotationConfigApplicationContext ac = new AnnotationConfigApplicationContext(AutoAppConfig.class);
MemberService memberService= ac.getBean(MemberService.class);
assertThat(memberService).isInstanceOf(MemberService.class);
}
}
테스트코드를 돌려보면 테스트가 성공한다.
이 경우 수동 빈 등록이 우선권을 가진다.
수동 빈이 자동 빈을 오버라이딩 해버리며 문제를 해결한다.
수동 빈 등록시
18:05:47.418 [main] DEBUG org.springframework.beans.factory.support.DefaultListableBeanFactory - Overriding bean definition for bean 'memoryMemberRepository' ...
이런 로그가 남는다.
개발자가 의도적으로 이런 결과를 기대한다면, 자동 보다는 수동이 우선권을 가지는 것이 좋다.
현실은 개발자가 의도적으로 설정해서 이런 결과가 만들어지기 보다는 여러 설정이 꼬여서 이런 결과가 만들어지는 경우가
대부분이라고 한다.
그렇게되면 잡기 어려운 버그가 만들어진다.
그래서 최근 스프링부트에서는 수동 빈 등록과 자동 빈 등록이 충돌나면 오류가 발생하도록 기본 값을 바꾸었다.
package hello.core;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
@SpringBootApplication
public class CoreApplication {
public static void main(String[] args) {
SpringApplication.run(CoreApplication.class, args);
}
}
스프링 부트를 실행시켜보자
이렇게 친절한 오류를 발생시켜준다!!
'웹프로그래밍 > Spring 핵심 원리' 카테고리의 다른 글
35. 옵션 처리 (0) | 2021.08.13 |
---|---|
34. 다양한 의존관계 주입 방법 (0) | 2021.08.12 |
33. 필터 (0) | 2021.08.10 |
33. 탐색 위치와 기본 스캔 대상 (0) | 2021.08.05 |
32. 컴포넌트 스캔과 의존관계 자동 주입 시작하기 (0) | 2021.08.03 |