티스토리 뷰

Spring

[Spring] Spring과 Spring Boot

예둥 2024. 1. 15. 14:13

'Java'는 1991년도에 개발되었음에도 30년이 지난 지금까지 대표적인 프로그래밍 언어로 사용되고 있습니다.

 

하지만 개발 연도가 오래된 만큼 다른 프로그래밍 언어들보다 속도가 느리고 코드 작성이 어렵다는 단점을 가지고 있습니다. 이러한 단점을 보완하기 위해 여러 프레임워크(Framework)가 개발되었는데요.

 

오늘은 Java의  대표적인 백엔드 개발 프레임워크(Framework)로 사용하는 Spring과 Spring Boot에 대해 말씀 드리겠습니다.

 

Spring 이란

 

스프링 프레임워크(Spring Framework)는 Java 기반 애플리케이션 개발을 지원하는 오픈소스 애플리케이션 프레임워크로 간단히 스프링(Spring)이라고도 불립니다. 스프링이 사용되기 이전에는 초기 기업에서 EJB(Enterprise Java Bean) 방식의 기술을 이용해서 Web Application 을 서비스했습니다. EJB는 데이터베이스 처리 및 트랜잭션 처리 등 기업용 애플리케이션 개발에 필요한 기술을 제공했는데요.

 

 

특정 회사의 EJB 컨테이너(Oracle Weblogic, IBM WebSphere 등)가 없이는 기술이 구현이 어렵고 프로그래밍 모델이 복잡하며, 자동화된 테스트가 거의 불가능하다는 치명적인 단점을 가지고 있습니다.

 

 

스프링은 이러한 EJB의 단점을 해결하여, 순수 자바 객체(POJO)만을 사용하여 복잡성을 제거하고, 단순하고 가벼운 코드로 기업용 애플리케이션을 개발하기 위한 목적으로 개발된 프레임워크(Framework)입니다. POJO(Plain Old Java Object)는 특정한 규약이나 프레임워크에 종속되지 않는 간단하고 순수한 자바 객체를 의미합니다. POJO는 객체지향 개발의 원칙에 충실한 객체를 말하며, 특정한 제약이나 요구사항에 종속되지 않고 유연하고 확장 가능한 코드를 작성할 수 있도록 도와줍니다.

 

 

스프링은 기존의 EJB가 제공하던 기업용 애플리케이션을 개발하기 위한 다양한 기능과 복잡한 시스템이나 개념을 간소화하여 개발자가 애플리케이션을 더 쉽게 개발하고 관리할 수 있도록 돕습니다. 스프링 프레임워크의 핵심 특징은 다음과 같습니다.


스프링의 대표적인 특징 4가지

  • 제어 역전

스프링은 객체의 생명 주기 및 의존성 관리를 담당하는 IoC 컨테이너를 제공합니다. 개발자는 객체의 생성과 관계 설정을 스프링에 위임할 수 있으며, 스프링 컨테이너가 객체의 생명 주기를 관리하고 필요한 의존성을 주입합니다.

 

 

  • 의존성 주입

스프링은 의존성 주입을 통해 객체 간의 관계를 설정합니다. 의존성 주입은 애플리케이션의 결합도를 낮추고 유연성과 테스트 용이성을 향상시킵니다.

 

 

  • AOP지원(관점 지향 프로그래밍)

스프링은 AOP를 지원하여 애플리케이션의 핵심 비즈니스 로직과 부가적인 기능(로킹, 트랜잭션 관리 등)을 분리하여 모듈화할 수 있습니다.

 

 

  • 웹 개발 지원

스프링은 웹 애플리케이션 개발을 위한 다양한 기능과 웹 프레젠테이션 계층을 제공합니다. 스프링 MVC는 유연하고 확장 가능한 웹 애플리케이션을 개발할 수 있는 MVC(Model-View-Controller) 아키텍쳐를 지원합니다.

 

이러한 특징들은 스프링을 사용하여 애플리케이션을 더 유연하고 모듈화된 구조로 개발하고 관리할 수 있도록 돕습니다. 하지만, 스프링이 제공하는 많은 장점에도, 몇 가지 문제점을 가지고 있습니다.


Spring의 문제점

 

스프링은 설정이 복잡해서 기업에서 스프링을 도입, 개발, 운영할 때 다음과 같은 몇 가지 어려움을 겪을 수 있습니다.

 

 

  • 설정의 복잡성

스프링은 강력한 기능을 제공하기 위해 많은 설정과 구성이 필요합니다. 이는 초기 설정의 복잡성을 증가시킬 수 있고, 초보자에게는 어렵게 느껴질 수 있습니다. 개발자들이 애플리케이션 컨텍스트 설정, 빈 정의, 다양한 컴포넌트 구성 등을 위해 많은 설정 코드를 작성해야 합니다.

 

 

  • 높은 초기 학습 난이도

스프링은 다른 프레임워크에 비해 학습이 필요한 부분이 많습니다. 다양한 개념과 기능을 이해하고 사용하기 위해 시간과 노력이 필요할 수 있습니다.

 

 

  • 별도 WAS 서버 구성의 번거로움

스프링을 웹상에서 사용하기 위해서는 별도의 Web Application Server(WAS)를 설치하고, 설정해야 합니다. 또한, 애플리케이션을 서비스하기 위해서 별도의 서버에 수동으로 배포해야 하는 번거로움이 있습니다.

 

 

이와 같은 스프링의 문제점을 해결해 주기 위해 스프링의 프레임워크들이 개발되었습니다.

 

스프링 프레임워크 중 대표적인 Spring Boot에 대해 알아보겠습니다.


Spring Boot란

 

스프링 부트(Spring Boot)는 스프링의 문제점을 해결해 주기 위해 개발된 스프링의 프레임워크로 개발자들이 더 쉽고 빠르게 스프링 애플리케이션을 개발하도록 도와주기 위해 개발되었습니다. 

 

 

개발 초기에 "스프링 부트 스타터"라는 프로젝트명으로 시작되었는데요. 이름에서도 느껴지듯이 간단한 설정과 구성을 통해 스프링 애플리케이션의 개발을 빠르게 시작할 수 있도록 도와주는 프로젝트였습니다. 시간이 흘러 프로젝트명은 "스프링 부트"로 변경되었고, 2014년 4월에 공식적으로 스프링 부트1.0이 출시되었습니다.

 

 

스프링 부트는 기업용 애플리케이션 개발을 더 쉽고 빠르게 하도록 도와주며, 모니터링, 건강 상태 확인(Health Check), 로깅, 설정관리 등 운영에 필요한 필수 기능을 내장하고 있는 프레임워크로 어떤 특징을 갖고 있는지 함께 살펴보겠습니다.


Spring Boot의 특징

 

스프링 부트는 기본적인 설정과 보일러 플레이트 코드(여러 곳에서 재사용되는 코드) 작성을 최소화하고, 자동 설정과 컨벤션을 통해 개발자들이 빠르게 애플리케이션을 개발할 수 있도록 지원하는 스프링 프레임워크입니다. 

 

스프링 부트를 사용하면 내장형 서버를 사용하여 별도의 웹 애플리케이션 서버(Web Application Server)를 설치할 필요 없이 애플리케이션을 실행할 수 있으며, 다양한 스프링 프레임워크 기능과 라이브러리, 서드파티 라이브러리와의 통합을 간편하게 구성할 수 있는데요. 주요 특징을 요약하면 다음과 같습니다.

 

  • 간결한 설정

스프링 부트는 번거로운 XML 설정이 필요 없으며, 최소한의 설정으로 Spring을 사용할 수 있고, 기본적인 설정을 자동으로 처리하므로 개발자가 많은 설정 작업을 하지 않아도 됩니다. 설정으로 인한 불편사항을 해소하여 개발자는 애플리케이션 개발에 집중할 수 있습니다.

 

 

  • 내장 서버

스프링 부트는 내장된 서버(내장 Tomcat, Jetty, Undertow)를 제공하여 별도의 서버 설정 없이 애플리케이션을 실행할 수 있습니다. 배포를 위해 War 파일을 생성해서 Tomcat에 배포할 필요 없으며, JAR 파일에는 모든 의존성 라이브러리가 포함되어 있어 외부 서버 없이도 애플리케이션을 실행할 수 있습니다. 이는 애플리케이션의 배포와 관리를 간편하게 만들어 줍니다.

 

 

  • 의존성 관리 간소화

스프링 부트는 여러 3rd party 라이브러리를 사용할 때, 발생하는 라이브러리 버전 충돌로 인한 문제를 해결하기 위해서, 이미 테스트된 여러 라이브러리들의 묶음 패키지를 제공합니다. 

 

3rd party 의존성 관리를 용이하게 하기 위한 ‘starter’ 의존성 통합 모듈을 제공하여 Maven/Gradel 설정 시 버전 관리가 간편합니다. 스프링 부트에서 제공하는 의존성 세트를 통해 개발자는 버전 충돌이나 복잡한 의존성 설정에 대해 걱정하지 않고 필요한 의존성을 쉽게 지정할 수 있습니다.

 

 

  • 운영 편의성

스프링 부트는 애플리케이션의 상태 모니터링, 로깅, 보안 설정 등 운영에 필요한 기능들을 제공합니다. 이를 통해 애플리케이션의 운영과 관리가 편리해지고 안정성이 향상됩니다.

 

스프링 부트는 스프링(Spring Legacy)의 장점은 그대로 계승하면서, 기존의 문제가 되는 부분을 보완하여 기업용 애플리케이션의 개발 생산성 및 서비스 운영, 성능을 모두 해결해 줄 수 있습니다. 

 

이렇듯 스프링 부트는 개발자들의 개발 생산성을 높이고, 애플리케이션의 유연성, 확장성을 제공할 뿐만 아니라, 스프링 프레임 워크들과 강력하게 호환되고, 생태계와의 통합을 가능하게 합니다. 이러한 장점을 가진 스프링 부트를 활용해서 업무에 적용할 수 있는 범위를 살펴보도록 하겠습니다.