mir.pe (일반/어두운 화면)
최근 수정 시각 : 2025-01-13 14:04:38

Spring(프레임워크)

스프링 프레임워크에서 넘어옴
웹 프레임워크 기술
{{{#!wiki style="margin:0 -10px"
{{{#!folding [ 펼치기 / 접기 ]
{{{#!wiki style="margin:-5px 0px -10px; word-break:keep-all"
$ 유료 포함 • 취소선 단종 및 중단
<colbgcolor=#f6f6f9,#2f3241> 프론트엔드 <colbgcolor=#fcfcfd,#272935> CSS Bootstrap Tailwind CSS Bulma Foundation Skeleton Pico
JSX React SolidJS Astro Preact Gatsby Remix Inferno Qwik
JS Angular Svelte Backbone.js jQuery Astro htmx Ember.js Lit 11ty Marko VanJS Alpine.js
Vue Vue.js VuePress Gridsome Quasar Astro
Python Reflex
백엔드 Java Spring Struts GWT Grails Jooby Play! Framework Scala
Kotlin Ktor
JS Express NestJS koa Hono fastify
.NET ASP.NET$
PHP Laravel Codeigniter Reasonable phalcon Symfony zend CakePHP FuelPHP Yii Slim PHPixe
Python Django Flask FastAPI
Ruby Ruby on Rails Sinatra
Go Gin echo Fiber
풀스택 JSX Next.js Astro SolidStart Remix Qwik City
JS SvelteKit Fresh Astro Marko
Vue Nuxt.js Astro
Java Vaadin$
Python Streamlit Reflex
Rust Rocket Actix Leptos Axum
하이브리드 .NET Blazor
Dart Flutter
Kotlin Kotlin Multiplatform
}}}}}}}}} ||

<colbgcolor=#fff,#1f2023><colcolor=#6DB33F> Spring Framework
파일:Spring 로고.svg
개발 VMware
종류 애플리케이션 프레임워크
출시 2002년 10월 1일
언어 Java
라이선스 아파치 라이선스 2.0
버전 6.1.14 (2024년 10월 17일)
파일:홈페이지 아이콘.svg | 파일:GitHub 아이콘.svg 파일:GitHub 아이콘 화이트.svg
1. 개요2. 상세3. 주요 특징4. 모듈
4.1. Spring Boot4.2. Spring WebFlux
5. 여담6. 관련 문서

[clearfix]

1. 개요

스프링은 Java 기반의 애플리케이션 프레임워크이다.[1][2]

2. 상세

로드 존슨(Rod Johnson)이 2002년에 출판한 저서 Expert One-on-One J2EE Design and Development에서 선보인 소스 코드를 시작으로 점점 발전하게 되었다. 2003년 6월에 최초로 공개되었다. 스프링 프레임워크 프로젝트를 간편하게 설정할 수 있도록 도와주는 서브 프로젝트 스프링 부트가 있으며, 현재는 스프링 부트 위주로 기능이 추가되고 있다.

'스프링'이라는 이름의 유래는 이전에 Java EE(엔터프라이즈 에디션)의 스펙을 구현한 EJB가 기술의 복잡도가 증가해서 성능이 느렸던 것을 탈피하여, EJB 시절을 '겨울'에 빗대어 겨울 후의 '봄'으로 새로운 시작한다는 것을 의미하는 스프링(봄)이 되었다. 그러나 아직 춥다 Java Virtual Machine에서 작동하며, 아파치 라이선스 2.0을 따르는 오픈 소스 프레임워크이다.

한국 전자정부표준프레임워크의 기반 기술이며 한국정보화진흥원에서는 공공 기관의 웹 서비스 제공 시 스프링을 권장하고 있다.

이게 무슨 소리인가 싶은 사람들을 위해 간단하게 설명하자면 군대로 비유하자면 위에서 명령을 내리는 지휘관이라기보다는 작전장교/ 행정보급관처럼 주변에서 정보를 일러주고 필요한 물건이나 인력을 가져다주는 부관, 참모라고 보면 된다. 그래서 용어도 Advice라는 용어를 사용한다.

여러 가지 문제점을 해결하기 위한 디자인 패턴, 아키텍처가 적용되어 있어서 어려운 용어가 많이 사용되는 프레임워크인데, 책을 보고 공부하기보다는 '스프링으로 게시판 만들기' 같은 것의 예제를 병행하면서 공부하는 게 더 이해가 빠를 것이다. 스프링은 프레임워크, 즉 제품이기 때문이다.

Spring에서 공식 제공 하는 이클립스 기반의 IDE Spring Tools를 제공 중이며, Visual Studio Code 버전으로도 제공하고 있다. 또한 JetBrains IntelliJ IDEA도 Spring 프레임워크를 훌륭하게 지원하는 IDE이다.

3. 주요 특징

스프링 프레임워크의 특징은 아래와 같다.[3]

4. 모듈

파일:spring-overview.png

위 이미지에 보이듯 스프링 프레임워크는 총 6개의 모듈로 구성되어 있다.

4.1. Spring Boot

파일:스프링부트.png
Spring Boot는 Spring Framework의 복잡한 설정 과정을 간소화하고 빠르게 애플리케이션을 개발할 수 있도록 설계된 자바 기반의 애플리케이션 프레임워크이다. Spring Framework의 강력한 기능을 유지하면서도 초보 개발자부터 숙련된 개발자까지 쉽게 사용할 수 있도록 다양한 기능을 제공한다.

스프링 부트에서는 5가지 핵심 기능을 제공하여 사용자가 스프링 프레임워크를 편리하게 사용하도록 도와준다.
  1. 자동 설정(Auto Configuration): Spring Boot는 애플리케이션의 설정을 자동화하여 개발자가 수동으로 XML이나 Java Config를 작성해야 하는 번거로움을 덜어준다. 기본적으로 application.properties 또는 application.yml 파일을 통해 설정을 정의할 수 있다.
  2. 내장 서버 지원(Embedded Server): Spring Boot는 Tomcat, Jetty, Undertow와 같은 내장 웹 서버를 제공하여 별도의 서버 설치 없이 애플리케이션을 실행할 수 있게 한다. 이를 통해 빠르게 애플리케이션을 테스트하거나 배포할 수 있다.
  3. 스타터 의존성(Starter Dependencies): Spring Boot는 특정 기능에 필요한 라이브러리를 묶어 제공하는 스타터 의존성을 제공한다. 예를 들어, Spring MVC를 사용할 경우 spring-boot-starter-web 의존성을 추가하면 필요한 라이브러리들이 자동으로 포함된다.
  4. 프로덕션 준비 기능(Production Ready Features): Spring Boot는 애플리케이션 모니터링, 상태 점검, 메트릭 수집 등을 위한 Actuator를 제공한다. 이를 통해 운영 환경에서도 애플리케이션을 효율적으로 관리할 수 있다.
  5. 간편한 실행: Spring Boot 애플리케이션은 독립 실행형 JAR 파일로 빌드되어 java -jar 명령으로 쉽게 실행할 수 있다.

Spring Boot는 단순히 빠른 개발뿐만 아니라 확장성과 유연성, 프로덕션 준비 상태 등을 고려한 현대적인 Java 애플리케이션 개발에 적합한 프레임워크이다. 다양한 프로젝트에 적용 가능하며, 특히 마이크로서비스 아키텍처에서 자주 사용된다.

4.2. Spring WebFlux

기존의 Servlet 기반의 Spring Web MVC에서는 지원하지 않는 non-blocking과 함수형 프로그래밍, reactive stream을 지원하기 위해 개발된 모듈이다. Reactive Streams API를 기반으로 구축되었으며 2017년 Spring Framework 5.0 출시와 함께 도입되었다.

비동기/non-blocking의 특성상 리퀘스트 수가 많아지면 많아질수록 Spring MVC에 비해 탁월한 성능을 보이지만, CPU 의존적인 처리에서는 성능 하락이 있고 코드 작성이 보다 까다로워진다는 단점이 있다.

5. 여담

6. 관련 문서



[1] Kotlin, Scala, Groovy도 공식적으로 지원하며, 특히 Kotlin은 거의 문제없이 사용이 가능하다. [2] 더 정확히, 스프링의 본질은 객체 지향 프레임워크에 더 가깝다. 순수 자바만으로 객체 간의 의존 관계 설정과 디자인 패턴의 구현, 관심사의 분리 등을 하기란 매우 힘든 일이며, 확장이나 모듈의 재사용도 어렵다. 그래서 스프링이 관리하는 컨테이너에 빈(Bean)으로서 객체를 등록하고, 빈의 관리와 제어를 개발자가 아닌 스프링이 하게 되어(제어 역전), 개발자는 확장이나 재사용이 유리하게 된다. [3] 난이도가 높기에 Okky 같은 커뮤니티에서도 이해의 어려움을 토로하는 경우가 많다. [4] 실제 약어는 Data Access Object이지만 xml 설정과 합해서 사실상 '데이터베이스 접근 객체'로 사용한다.