appconfig에 등록한거랑 @Component해서 등록한걸로 어느게 우선순위인가요?
학습하는 분들께 도움이 되고, 더 좋은 답변을 드릴 수 있도록 질문전에 다음을 꼭 확인해주세요.
1. 강의 내용과 관련된 질문을 남겨주세요.
2. 인프런의 질문 게시판과 자주 하는 질문(링크)을 먼저 확인해주세요.
(자주 하는 질문 링크: https://bit.ly/3fX6ygx)
3. 질문 잘하기 메뉴얼(링크)을 먼저 읽어주세요.
(질문 잘하기 메뉴얼 링크: https://bit.ly/2UfeqCG)
질문 시에는 위 내용은 삭제하고 다음 내용을 남겨주세요.
=========================================
[질문 템플릿]
1. 강의 내용과 관련된 질문인가요? 예
2. 인프런의 질문 게시판과 자주 하는 질문에 없는 내용인가요? 예
3. 질문 잘하기 메뉴얼을 읽어보셨나요? 예
[질문 내용]
web 라이브러리를 설치했는데
parameter 0 of constructor in hello.core.member.memberserviceimpl required a single bean, but 2 were found
이런 오류가 뜨더라고요
appconfig안에 MemberRepository의 @Bean 과
@Configuration //설정
public class AppConfig {
@Bean
public MemberService memberService() {
return new MemberServiceImpl(memberRepository());
}
@Bean
public MemberRepository memberRepository(){
return new MemoryMemberRepository();
}
....
}MemoryMemberRepository.class의 @component
//@Component
public class MemoryMemberRepository implements MemberRepository {
private static Map<Long, Member> store= new HashMap<>();
@Override
public void save(Member member) {
store.put(member.getId(), member);
}
@Override
public Member findById(Long memberId) {
return store.get(memberId);
}
}
이렇게 두개가 겹쳐서 그런거같은데
@Component를 지우니깐 잘되더라고요.
둘다 우선순위가 따로 없는건가요?
그리고 실습에서는 appconfig안에 Bean을 지웠나요?
component를 지웠나요?
열심히 들었는데 어디서 부터 실습을 잘못했는지 잘모르겠네요 죄송합니다.
답변 2
1
안녕하세요. 캐내기님, 공식 서포터즈 OMG입니다.
문제를 파악하기 위해 강의영상과 메뉴얼 등을 살펴보았는데, 강의 순서대로 잘 진행하셨던 것 같습니다.
-
제가 생각했을 때 두가지 중 한가지에 포함되어 발생한 상황 같습니다.
(1) 스프링부트 3.2 관련
문제 발생 오류 내용(자주하는질문)

문제원인으로 인한 변경사항 및 해결방안(자주하는질문, 강의메뉴얼)
(2) AutoAppConfig의 임시 진행 코드 미삭제

두 가지 가능성 중 첫번째로 인한 원인일 확률이 높을 것 같습니다.
MemoryMemberRepository의 @Component는 지우지 않고 그대로 적용하신 상태에서(=문제가 발생하는 상황 재현) build실행이 IntelliJ IDEA로 되어 있다면 Gradle(Default)로 변경하여 확인해주세요.
해결이 안되거나, 제가 예상한 상황이 아니라면 댓글 남겨주세요
감사합니다.
0
안녕하세요, 인프런 AI 인턴입니다.
캐내기님께서 겪고 계신 @Component와 @Bean 어노테이션의 사용으로 인한 빈 중복 문제는 다른 수강생들도 비슷한 경험을 했던 것으로 보입니다. 스프링에서는 동일한 타입의 빈이 두 개 이상 있을 때 구체적인 우선 순위를 설정하지 않으면 required a single bean, but 2 were found와 같은 오류를 발생시킵니다.
@Component 어노테이션과 @Bean 어노테이션은 모두 스프링 빈을 등록할 때 사용하지만, 사용하는 위치와 방법이 다릅니다. @Component는 클래스 레벨에 선언하여 해당 클래스의 인스턴스를 스프링 빈으로 자동 등록하며, @Bean은 설정 클래스의 메서드 레벨에 선언하여 해당 메서드가 반환하는 객체를 스프링 빈으로 등록합니다. 이 둘 사이에는 명시적인 우선 순위가 정해져 있지 않기 때문에, 타입으로 빈을 주입받으려 할 때 충돌이 발생할 수 있습니다.
해당 문제를 해결하기 위해선 빈이 중복으로 등록되지 않도록 관리해야 하며, 강의 실습에서는 일반적으로 하나의 방법만을 사용하여 빈을 등록합니다. 만약 @ComponentScan과 함께 @Component 어노테이션을 사용하여 자동 빈 등록을 선호한다면 @Configuration 클래스에서 @Bean을 사용하여 수동으로 등록하는 부분을 제거하고, 그 반대의 경우도 마찬가지입니다.
캐내기님의 상황에서는 @Component 어노테이션을 제거함으로써 문제를 해결할 수 있었다고 하셨는데, 실습 중에 어느 부분이 잘못되었는지 확인하기 위해서는 실제 강의 내용과 어떻게 다르게 진행했는지를 다시 검토해 보셔야 할 것 같습니다.
다음은 유사한 경우에 대한 다른 수강생의 질문과 답변을 링크로 제공합니다. 참고하시면 좋을 것 같습니다.
- 질문 제목: “중복 오류”
본 질문 링크에는 @Component와 @Bean을 통한 빈 등록 중복 문제와 관련된 해결 방법이 자세히 설명되어 있으니 참고하시어 캐내기님의 문제를 해결하는 데 도움이 되길 바랍니다.
저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.
코드 자료
0
45
2
구현체가 동적으로 정해질 때, 팩토리 기법을 사용하나요?
0
55
2
MemberService의 인터페이스를 왜 사용하는지 궁금합니다.
0
76
1
롬복 @Setter를 써야 하는 상황이 있는건가요?
0
91
1
빈 등록 메서드의 파라미터가 빈이 아니어도 되나요?
0
81
1
테스트 속도가 나중에 영향이 있을까요?
0
77
1
gradle 설정 안떠서 질문 남깁니다!
0
121
2
build.gradle로 프로젝트를 여는 이유
0
86
1
provider 사용하는 이유
0
89
1
다음 강의 뭘 들어야 할까요
0
126
2
프로토타입 빈, 직접 destroy 호출 안 할 경우
0
66
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
79
2





