본문 바로가기
강의 실습/스프링 핵심 원리 - 기본편

자동, 수동의 올바른 실무 운영 기준

by jint 2026. 5. 1.

1. 편리한 자동 기능을 기본으로 사용
스프링이 나오고 시간이 갈수록 점점 자동을 선호하는 추세다.

스프링은 @Component 뿐만 아니라 @Controller, @Service, @Repository 처럼 계층에 맞춘 일반적인 애플리케이션 로직을 자동 스캔하도록 지원한다.
스프링 부트는 컴포넌트 스캔을 기본으로 사용하고, 다양한 스프링 빈들도 조건이 맞으면 자동 등록하도록 설계되었다.
자동 빈 등록을 사용해도 OCP, DIP를 지킬 수 있다.

설정 정보를 기반으로 애플리케이션을 구성하는 부분, 실제 동작하는 부분을 명확히 나누는 것이 이상적이지만, 스프링 빈 1개 등록시 @Component 만 넣어주면 끝나는 것을 @Configuration 설정 정보에서 @Bean 을 적고, 객체를 생성하고, 주입할 대상을 일일이 적어주는 과정은 번거롭고 관리가 어렵다.


2. 수동 빈 등록 사용하는 상황
애플리케이션의 구성)
· 업무 빈 : 비즈니스 요구사항을 개발하는 로직
-> 웹을 지원하는 컨트롤러, 핵심 비즈니스 로직이 있는 서비스, 데이터 계층의 로직을 처리하는 리포지토리 등
· 기술 지원 빈 : 업무 로직을 지원하기 위한 기술적인 것과 공통 관심사(AOP)를 처리하는 로직
-> 데이터베이스 연결, 공통 로그 처리

- 업무 빈 : 자동 빈 등록 사용
업무 로직은 유사한 패턴(컨트롤러, 서비스, 리포지토리)이 있기 때문에 문제 발생시 어떤 곳에서 발생했는지 명확하게 파악하기 쉽다.

- 기술 지원 빈 : 수동 빈 등록 사용
업무 로직과 비교해서 그 수가 매우 적고, 애플리케이션 전반에 걸쳐 광범위하게 영향을 미친다. (설정 정보가 애플리케이션 루트에 존재하여 여기에 기술 지원 빈이 등록되어 있기 때문)
문제 발생시 어디가 문제인지 파악이 어렵고, 적용이 되고 있는지 조차 파악하기 어려운 경우가 많다.
수동 빈 등록을 사용해서 명확하게 드러내 관리하는 것이 좋다.


3. 비즈니스 로직 중 다형성을 적극 활용하는 상황 (전략 패턴 사용시)
특정 인터페이스의 조회한 빈이 모두 필요하여 List, Map 을 사용할 때, 여기에 어떤 빈들이 주입될 지 코드만 보고 파악이 어렵다. 특히 자동 빈 등록시에는 여러 코드를 찾아봐야 하기 때문이다.

1) 수동 빈 등록 (권장)
별도의 설정 정보로 만들어 수동 빈 등록하면, 한 눈에 빈 이름과 주입되는 빈을 파악할 수 있다.

 

@Configuration
public class DiscountPolicyConfig {

    @Bean
    public DiscountPolicy rateDiscountPolicy() {
        return new RateDiscountPolicy();
    }

    @Bean
    public DiscountPolicy fixDiscountPolicy() {
        return new FixDiscountPolicy();
    }

}


2) 자동 빈 등록
특정 인터페이스의 구현체들을 한 패키지에 모아서 관리한다. (인터페이스도 함께 있어도 됨)

-> 핵심 : 딱 보고 이해되야 함


4. 빈 등록 및 주입 설정 예외
스프링과 스프링 부트가 자동으로 등록하는 수많은 빈들은 빈 등록 설정을 따로 건들지 않는다. 스프링을 이해하고 스프링의 의도대로 사용하는게 중요하다.
스프링 부트의 DataSource 처럼 데이터베이스 연결에 사용하는 기술 지원 로직도 내부에서 자동으로 등록되는데, 이런 부분은 메뉴얼을 잘 참고하여 스프링 부트가 의도한 대로 편리하게 사용하면 된다.

스프링 부트가 제공하는게 부족하여 커스텀이 필요하다면, 직접 스프링 빈으로 등록하여 사용 (수동 등록)


5. 정리
기본으로 자동 빈 등록
직접 생성한 기술 지원 객체는 수동 빈 등록
다형성을 적극 활용한 비즈니스 로직은 수동 빈 등록 고민


참고링크 : https://www.inflearn.com/course/%EC%8A%A4%ED%94%84%EB%A7%81-%ED%95%B5%EC%8B%AC-%EC%9B%90%EB%A6%AC-%EA%B8%B0%EB%B3%B8%ED%8E%B8?cid=325969

 

스프링 핵심 원리 - 기본편| 김영한 - 인프런 강의

현재 평점 5.0점 수강생 49,572명인 강의를 만나보세요. 스프링 입문자가 예제를 만들어가면서 스프링의 핵심 원리를 이해하고, 스프링 기본기를 확실히 다질 수 있습니다. 스프링 기본 기능, 스프

www.inflearn.com

댓글