Backend/Spring

Spring( 봄 ) ?? 스프링의 원리와 기초

Juwon2106 2022. 1. 10. 15:58
728x90

Spring Framwork

 

Java Platform을 위한 오픈소스 애플리케이션 프레임워크로서 스프링( Spring ) 이라고 불린다.

  • Open Source : 소프트웨어 혹은 하드웨어의 제작자의 권리를 지키면서 원시 코드를 누구나 열람할 수 있도록 한 소프트웨어로서 오픈 소스 라이센스에 준하는 모든 통칭을 말한다.
  • Framework : 개발자를 위한 설계 기본의 뼈대, 구조, 환경을 말한다. ( 문제 영역을 해결한 재사용, 확장 가능한 라이브러리 )
Spring은 JAVA 기반의 Framwork이고 자바는 객체 지향 언어다.
(개발자인 우리는 좋은 객체 지향 프로그래밍이란 무엇인지 알아야한다.)

SOLID - 좋은 객체 지향 설계의 5가지 원칙

  1. SRP : 단일 책임 원칙 ( Single Responsibility Principle )
    • 하나의 클래스는 하나의 책임만 갖는다.
  2. OCP : 개방 - 폐쇄 원칙 ( Open / Closed Principle )
    • 확장에는 열려있으며 변경에는 닫혀있어야 한다.
    • 기능을 추가하려면 코드의 수정은 불가피하며 다형성을 이용하더라도 클라이언트 코드를 변경해야 한다.
  3. LSK : 리스코프 치환 원칙 ( Liskov Substitution Principle )
    • 프로그램의 객체는 프로그램의 정확성을 깨뜨리지 않으면서 하위 타입의 인스턴스로 바꿀 수 있어야 한다.
    • 다형성에서 하위 클래스는 인터페이스 규약을 지켜야 한다.
    • 다형성을 지원하기 위한 원칙, 인터페이스를 구현한 구현체는 믿고 사용하려면, 이 원칙이 필요하다.
  4. ISP : 인터페이스 분리 원칙 ( Interface Segregation Principle )
    • 특정 클라이언트를 위한 여러 개의 인터페이스가 범용 인터페이스 단 하나보다 낫다.
  5. DIP : 의존관계 역전 원칙 ( Dependency inversion principle )
    •  의존성 주입은 추상화에 의존해야하며, 구체화에 의존하면 안된다는 원칙을 따르는 방법 중 하나이다.           ( 구현 클래스에 의존하지 말고 인터페이스에 의존하는 의미이다 )

  

스프링의 특징

  • IOC ( Inversion of Control : 제어의 역행)
    • 컨트롤의 제어권이 사용자가 아닌 프레임워크에 있어 필요에 따라 Spring에서 사용자의 코드를 호출한다.
    • 애플리케이션 간의 느슨한 결합 도모
  • DI ( Dependency Injection : 의존성 주입)
    • 각각의 계층이나 서비스들 간에 의존성이 존재할 경우 프레임워크가 서로 연결시켜준다.
      AOP
  • AOP ( Aspect-Oriented Programming : 관점지향 프로그래밍 )
    • Transaction이나 Logging, Security와 같이 여러 모듈에서 공통적으로 사용하는 기능의 경우 해당 기능을 분리하여 관리할 수 있다.
    • AOP, Filter, Interceptor의 차이점을 알면 이해하기 쉽다. ( 다른 포스팅에서 다루겠습니다. )
  • Container ( 컨테이너 )
    • 애플리케이션 객체의 생명 주기와 설정을 포함하고 관리한다는 점에서 일종의 컨테이너라고 부를 수 있다.
    • iBatis, MyBatis, Hibernate( JPA )등 완성도가 높은 데이터베이스처리 라이브러리와 연결할 수 있는 인터페이스를 제공한다.
  • Transaction Manage Framework
    • 추상화된 트랜잭션 관리를 지원하며 설정파일 (xml, java, property 등)을 이용한 선언적인 방식 및 프로그래밍을 통한 방식을 모두 지원한다.

MVC Pattern 2

  • Model-View-Controller 패턴 ( MVC )
    • 웹 프로그래밍 개발 시 표준적인 방식인 Spring MVC라 불리는 모델-뷰-컨트롤러 패턴을 사용한다.
    • DispatcherServlet이 Controller 역할을 담당하여 각종 요청을 적절한 서비스에 분산시켜주며 이를 각 서비스들이 처리하고 결과를 생성하여 다양한 형식의 View 서비스로 화면에 표시되는 패턴이다. ( MVC 패턴에도 다양한 패턴이 존재한다. )
  • 배치 프레임워크 ( Batch Framework )
    • 스프링은 특정 시간대에 실행하거나 대용량의 자료를 처리하는데 쓰이는 일괄 처리(Batch Processing)을 지원하는 배치 프레임워크를 제공한다. 스프링의 배치( Batch )는 Quartz 기반으로 동작한다.

스프링 모듈 ( Spring module )

  • Spring Core
    • Spring 프레임워크의 근간이 되는 요소. IOC, DI의 기능을 지원하는 영역을 담당한다.
    • BeanFactory를 기반으로 Bean 클래스들을 제어할 수 있는 기능을 지원한다.
  • Spring Context
    • Spring Core 바로 위에 있는 계층으로 Spring Core에서 지원하는 기능 이외의 추가적인 기능들과 개발의 용이성을 제공한다.
    • JNDI, EJB를 위한 Adaptor들을 포함
  • Spring DAO
    • 지금까지 우리들이 일반적으로 많이 사용해왔던 JDBC 기반하의 DAO개발을 좀 더 쉽고, 일관된 방법으로 개발하는 것이 가능하도록 지원한다.
    • Spring DAO를 이용할 경우 지금까지 개발하던 DAO보다 적은 코드와 쉬운 방법으로 DAO를 개발하는 것이 가능하다.
  • Spring ORM ( Object Relation Mapping )
    • ORM Framework인 Hibernate, IBatis, JDO와의 결합을 지원하기 위한 기능이다.
    • Spring ORM을 이용할 경우 Hibernate, IBatis, JDO 프레임워크와 쉽게 통합하는 것이 가능하다.
  • Spring AOP ( Aspect Oriented Programming )
    • AOP Alliance 기반하에서 개발하는 AOP를 지원하는 기능이다.
  • Spring Web
    • Web Application 개발에 필요한 Web Application Context와 Multipart Request등의 기능을 지원한다.
    • Struts, Webwork와 같은 프레임워크의 통합을 지원한다.
  • Spring Web MVC
    • Spring Framework에서 독립적인 Web UI Layer에 Model-View-Controller를 지원하기 위한 기능이다.

 

느슨한 결합이란?
- 객체를 주입 받을 때 외부에서 생성된 객체를 인터페이스를 통해서 넘겨받는 것.
- 객체간의 결합도를 낮출 수 있으며, 런타임시에 의존관계가 결정되기 때문에 유연한 구조를 가진다.


강한 결합이란?
- 객체 내부에서 다른 객체를 생성하는 것은 강한 결합을 가지는 구조이다.
- ex) Class A 내부에서 Class B 객체를 직접 생성하고 있다면, B 객체는 C 객체로 바꾸고 싶은 경우에 A 클래스도 수정해야하는 방식이기 때문에 이를 강한 결합이라고 한다.

 

다음 포스팅에서는 Spring의 Filter, Interceptor, AOP를 비교하겠습니다.

728x90