Spring Boot 에 대한 Study를 진행하면서 얻게 된 정보들, 그리고 저와 동일하게 공부를 시작하려는 분들에게 도움이 되고자, study 섹션으로 분리하여 정리하려고 합니다. 워낙 쉽게 개발 및 배포가 가능하도록 되어 있어 그런지, Spring Boot, Spring Framework에 대한 기본적인 지식 없이, Web 검색을 통해 얻어온 정보들을 정확하게 정리하고 스스로도 공부가 되었으면 합니다.

기본 사항

소스 코드

예제 등을 개발하면서 공유하려고 하고 있으며 모든 정보들은 이 linkeverything GitHub Organization 안에 있는 별도의 repository인 studySpringBoot로 관리하려고 합니다. 최초 시작부터 하여 모든 과정들은 branch 로 분리하여 각 과정의 시작부터 끝까지를 관리해보려고 합니다(이 정책은 향후 변경될 수 있습니다).

studySpringBoot repository로 이동하여 branch 정보를 원하는 글의 번호로 대체합니다. 글 번호는 URL 주소의 마지막 부분으로 넣어 두겠습니다. git 명령어 중 git checkout 명령어를 이용하여 해당 내용을 내려받고 실행해 보면 그 과정에 대해서 확인이 가능합니다. Master branch에는 이 Study section의 모든 내용이 포함되겠지만, 각각의 branch에서는 해당 post에 대한 내용만 담을 수 있도록 할 예정입니다.

출처 및 참고자료

모든 출처, 참고자료 들에 대해서는 그 원본 링크를 첨부합니다. 만약, 도서인 경우 어떤 도서에서 참고하였는지 명시합니다. 저작권 침해가 없는 수준에서 참고 및 자료 활용이 이루어질 예정입니다. 제가 적은 글에 저작권 문제가 있을 소지가 있으면 언제든 연락주시기 바랍니다. 빠른 시간 내에 조치하겠습니다.

사전 정의(Pre-defined)

여기에는 다음의 정보들을 기본으로 가지고 가겠습니다. 중간에 필요에 의해서 다른 방식을 참고할 수는 있겠지만, 큰 틀은 이 룰을 유지합니다. 변경 사항이 발생하는 경우, 이 글에도 update하겠습니다.

소스 및 라이브러리

모든 라이브러리는 작성하는 시점 기준으로 최신 버전을 반영합니다. 만약 Spring Boot나 사용하는 라이브러리의 업데이트가 발생한 경우, 정상적으로 동작하지 않을 수 있습니다.1 이에 대해서는 확인이 가능한 즉시 수정하여 반영할 계획입니다.

빌드 도구

빌드 도구는 크게 Maven 과 Gradle이 있습니다. 그 중에서 Gradle을 선정합니다. 더 오랫동안 사용해 온 것은 Maven이고 관련 자료들도 많이 있겠지만, 현재 추세에 맞게 gradle로 선정하였습니다. 두 빌드 도구 간에 유사성이 많고 호환성을 갖을 수도 있으니 maven을 사용하는 환경이더라도 여기에 남겨진 내용으로 유사하게 구현할 수 있을 것입니다.

IntelliJ IDEA

이 포스팅 전체에서 사용하는 IDE는 IntelliJ IDEA Community edition을 기준으로 합니다. 무료 툴이고 현재 기준으로 가장 많은 개발자가 사용하는 것이라고 판단되어 선정하게 되었습니다.

다만 버전에 대해서는 특정지을 수 없음을 밝힙니다. IntelliJ와 Eclipse동일하게 매 분기마다 버전을 빌드하는 것을 규칙으로 가져가고 있으며 따라서 제가 이 글을 적는 동안에도 버전이 올라갈 수 있습니다.

개인적으로 IDE의 업데이트는 바로바로 진행하는 편입니다. 자동화된 기능, 개발 편의성을 제공해주는 것인 만큼, IDE의 버그로 인한 문제는 없기를 바라는 마음에 그렇게 합니다.

참고로, IntelliJ IDEA는 여러 설정 정보들을 기기간 연동할 수 있는 기능을 제공합니다. Settings Repository 가 그것인데, GitHub에 repository를 하나 생성하고 그 repository에 설정 정보들을 commit&push 하거나 pull 하는 형태로 sync 합니다. 참고링크

Java(JDK)

JDK 는 편의 상 1.8을 기준으로 작성합니다. 역시 현재 기준으로 가장 보편적인 버전이라고 판단되며, lamda표현식 등 가장 큰 변화가 있는 시점의 버전이라고 판단됩니다.2 JDK에 대해서는 하위호환을 해줄 것이라고 가정하고 모든 코드를 작성합니다. 예를 들어 JDK 11을 사용한다고 해서 여기서 소개하는 코드가 빌드되지 않을 현상은 없을 것입니다.

Spring Initializr

Spring Boot 프로젝트는 신규 생성 시, IntelliJ의 방식을 사용하지 않습니다. IntelliJ IDEA 에서 제공하는 Spring initializr 기능은 일반 Community 버전(무료)이 아닌 Ultimate 버전에서만 사용 가능하기 때문에 보편적인 기능을 제공하지 못합니다. 따라서 위 그림에서 보이는 것 처럼 web 에서 Spring initializr를 실행하고, 이를 통해 IDE에 import하는 개념으로 사용합니다.

그 외 도구들

이 이외에도 다음과 같은 도구들을 활용할 예정입니다. 반드시 필요한 요소임에는 틀림없지만, 각자의 환경에 맞는 방식으로 처리하면 됩니다. 설치형이든, 설치되어있는 것을 사용하든, Public Cloud에 있는 SaaS를 활용하든 자유입니다.

Httpie / Postman

자주는 아닐 수 있지만, API를 테스트하는 데 필요한 도구입니다. http/https 요청을 보내고 response를 확인할 수 있는 툴입니다.

Httpie 는 명령어 형태로, 즉, MacOS 의 terminal이나 Windows의 명령프롬프트, 혹은 Powershell 등의 도구를 이용하여 명령어를 직접 typing하여 기능을 동작시킵니다. (참고: Httpie 홈페이지)

반면에 postman은 UI가 있는 툴입니다. 많은 양의 request를 보내는 것은 유료로 구입해야 가능하지만, 평소 개발하면서 간단히 요청 보내는 수준은 충분합니다. 설치형이고 홈페이지의 다운로드 페이지를 통해 다운로드 후 설치하면 됩니다.

Docker

Spring Boot로 만든 어플리케이션이 아닌 다른 시스템, 즉 DB나 Queue, 혹은 다른 web server 등을 구동시키는 데 docker를 사용합니다. docker 설치 방법에 대해서도 추가로 정리를 할 예정이니 따라하시거나, 혹은 홈페이지의 설명에 따라 설치하면 됩니다.3

Database

Database는 특별한 이유가 없는 한, mariadb를 사용합니다. 테스트 목적으로 local에서 완벽하게 H2를 구현하는 방법도 있겠지만, 거의 대부분의 운영 환경은 H2 Database를 사용하지 않고 있으므로 mariadb로 선정하였습니다. 기본적으로 mySql과 유사하지만 조금 더 편하게 사용할 수 있고, 그 대신 아주 세세한 설정은 조금 복잡할 수 있습니다.

mariadb를 사용하기 때문에 Windows 에서는 HeidiSQL이나 MySQL Workbench, MacOS에서는 Sequel Pro 를 다운로드 받고 설치합니다. Database의 내용을 보고 사용자 등을 설치할 수 있습니다.

  1. 만약 아래 disqus 기능을 이용하여 안되는 부분을 지적해 주시면 확인 후 수정하도록 하겠습니다. 

  2. 저는 MacOS 상에서 brew를 이용한 설치 방법을 사용하고 있습니다. 

  3. Windows 와 MacOS 의 경우에는 Docker Desktop 버전을 설치하는 것이 편합니다. 


Leave a comment