@Component가 붙은 클래스들을 모두 스프링 빈으로 등록해준다.
@ComponentScan(
basePackages = "hello.core",
}
컴포넌트 스캔은 @Component 뿐만 아니라 다음과 내용도 추가로 대상에 포함한다.
@Component : 컴포넌트 스캔에서 사용
@Controlller : 스프링 MVC 컨트롤러에서 사용
@Service : 스프링 비즈니스 로직에서 사용
@Repository : 스프링 데이터 접근 계층에서 사용
@Configuration : 스프링 설정 정보에서 사용
참고 : useDefaultFilters 옵션은 기본으로 켜져있는데, 이 옵션을 끄면 기본 스캔 대상들이 제외된다.
Filter(컴포넌트 스캔에서 포함 또는 제외할 수 있는 옵션)
@ComponentScan(
// 포함
includeFilters = @ComponentScan.Filter(classes = MyIncludeComponent.class),
// 제외
excludeFilters = @ComponentScan.Filter(classes = MyexcludeComponent.class)
)
쓸 일은 거의 없다.(@Component면 충분하기 때문에, excludeFilters는 가끔)
컴포넌트 스캔에서 같은 빈 이름이 중복 등록되는 경우
1. 자동 빈 vs 자동 빈
-> ConflictingBeanDefinitionException 예외 발생
@Component
public class MemoryMemberRepository implements MemberRepository {}
@Configuration
@ComponentScan
public class AutoAppConfig {
@Bean(name = "memoryMemberRepository")
public MemberRepository memberRepository() {
return new MemoryMemberRepository();
}
}
위에는 스프링이 클래스명의 앞글자를 소문자로 바꿔 자동으로 빈으로 등록 아래는 수동으로 빈으로 등록한 경우이다. 이럴 경우 수동 빈이 자동빈을 오버라이딩한다.
Overriding bean definition for bean 'memoryMemberRepository' with a different
definition: replacing
의도적으로 개발자가 설정한 경우도 있지만, 그렇지 않고 이런 설정들이 꼬이는 경우가 대부분이다. 최근 스프링 부트에서는 수동 빈 등록과 자동 빈 등록이 충돌나면 오류가 발생하도록 기본 값을 바꾸었다.
출처 : 김영한의 스프링 핵심 원리 - 기본편