Spring Framework
:book: Contents
프레임워크란
- 정의
- 비기능적 요구사항(보안, 확장성, 안정성 등)을 만족하는 구조와 구현된 기능을 안정적으로 실행하도록 제어해주는 잘 만들어진 구조의 라이브러리 덩어리. '반제품'을 의미한다.
- 목표
- 애플리케이션들의 최소한의 공통점을 찾아 하부 구조를 제공함으로써 개발자가 Application 개발에 집중할 수 있도록 한다.
- 장점
- 개발 기간 단축
- 성능 향상
- 유지보수성 향상
스프링 프레임워크란
자바 엔터프라이즈 개발을 편하게 해주는 경량급 오픈소스 애플리케이션 프레임워크
목표 :
- POJO 기반의 Enterprise Application 개발을 쉽고 편하게 할 수 있도록 한다.
- Java Application을 개발하는데 필요한 하부구조(Infrastructure)를 포괄적으로 제공한다. Spring이 하부구조를 처리하기 때문에 개발자는 Application 개발에 집중할 수 있다.
특징
- 컨테이너 역할
- 자바 객체의 라이프사이클을 관리하며, 필요한 객체를 제공한다.
- DI(의존관계 주입) 지원
- xml 설정파일이나 어노테이션을 통해 객체 간의 의존 관계를 설정할 수 있다.
- AOP 지원
- 스프링은 트랜잭션이나 로깅, 보안과 같이 공통적으로 필요로 하는 모듈들을 실제 핵심 모듈에서 분리해서 적용할 수 있다.
- POJO(Plain Old Java Object) 지원
- 스프링 컨테이너에 저장되는 자바 객체는 특정한 인터페이스를 구현하거나, 특정 클래스를 상속 받지 않아도 된다.
- 트랜잭션 처리를 위한 일관된 방법을 지원
- JDBC, JTA 등 어떤 트랜잭션을 사용하던 설정을 통해 정보를 관리하므로 트랜잭션 구현에 상관없이 동일한 코드 사용 가능
- 영속성과 관련된 다양한 API 지원
- Spring은 MyBatis, Hibernate 등 데이터베이스 처리를 위한 ORM(Object Relational Mapping) 프레임워크들과의 연동 지원
- 컨테이너 역할
POJO
객체지향 원리에 따라 만들어진 자바 언어의 기본에 충실하게 비즈니스 로직을 구현, 즉 프레임워크 인터페이스나 클래스를 구현하거나 확장하지 않는 단순한 클래스.
특징
Java에서 제공하는 API 외에 종속되지 않음
특정 규약, 환경에 종속되지 않음
코드의 간결함 (비즈니스 로직과 특정 환경/low 레벨 종속적인 코드를 분리하므로 단순)
자동화 테스트에 유리 (환경 종속적인 코드는 자동화 테스트가 어렵지만, POJO는 테스트가 매우 유연)
객체지향 설계의 자유로운 사용
Container란
컨테이너(Container)는 보통 인스턴스의 생명주기를 관리하며, 생성된 인스턴스들에게 추가적인 기능을 제공하도록 하는 것이라 할 수 있다. 다시 말해, 컨테이너란 당신이 작성한 코드의 처리과정을 위임받은 독립적인 존재라고 생각하면 된다. 컨테이너는 적절한 설정만 되어있다면 누구의 도움 없이도 프로그래머가 작성한 코드를 스스로 참조한 뒤 알아서 객체의 생성과 소멸을 컨트롤해준다.
Spring 프레임워크는 다른 프레임워크들과 달리 컨테이너 기능을 제공하고 있다. 이와 같은 컨테이너 기능을 제공하는 것이 가능하도록 하는 것이 IoC 패턴이다.
IoC(Inversion of Control, 제어의 역전)
객체의 생성에서부터 생명주기의 관리까지 모든 객체에 대한 제어권이 바뀐 것, 즉 제어 권한을 자신이 아닌 다른 대상에게 위임하는 것이다.
개발자는 프레임워크에 필요한 부품을 개발하고 조립하는 방식의 개발을 하게 된다.
이렇게 조립된 코드의 최종 호출은 개발자에 의해서 제어되는 것이 아니라 프레임워크의 내부에서 결정된 대로 이뤄지게 되는데, 이러한 현상을 "제어의 역전"이라고 표현한다.
Spring에서의 IoC
Spring 프레임워크에서 지원하는 Ioc Container는 POJO(Plain Old Java Object)의 생성과 의존성, 생명주기를 관리하며, 생성된 인스턴스들에게 추가적인 기능들을 제공한다.
라이브러리와 프레임워크의 차이
- 라이브러리 : 특정 기능에 대한 도구들의 집합
- 프레임워크 : 비기능적 요구사항(보안, 확장성, 안정성 등)을 만족하는 구조와 구현된 기능을 안정적으로 실행하도록 제어해주는 잘 만들어진 구조의 라이브러리 덩어리
- 라이브러리를 사용할 경우, 사용자가 애플리케이션 코드를 짜며 능동적으로 라이브러리를 호출하여 애플리케이션 흐름을 직접 제어한다.
- 반면에 프레임워크를 사용할 경우, 프레임워크가 애플리케이션 흐름을 제어한다. 보통 프레임워크 위에 개발자가 개발한 클래스를 등록해두고, 프레임워크가 흐름을 주도하는 중에 이것을 사용하는 방식이다.
Reference
'Web_Backend > Spring' 카테고리의 다른 글
3.Spring AOP (0) | 2024.07.12 |
---|---|
2.Spring DI (0) | 2024.07.12 |
AOP (0) | 2022.05.03 |
Spring Filter, Interceptor, AOP 비교 (0) | 2022.05.03 |
[스프링 입문 - 코드로 배우는 스프링 부트, 웹 MVC, DB 접근 기술 - 인프런] 1. 프로젝트 생성 (0) | 2021.01.10 |