빌드 관리 도구란 프로젝트에서 필요한 xml, properties, jar 파일들을 자동으로 인식하여 빌드해주는 도구이다. 소스코드를 컴파일, 테스트, 정적분석 등을 하여 실행가능한 앱으로 빌드해준다. 프로젝트 정보 관리, 테스트 빌드, 배포 등의 작업을 진행해주며 외부 라이브러리를 참조하여 자동으로 다운로드 및 업데이트 역시 관리해준다.
Java의 대표적인 빌드 도구는 Ant, Maven, Gradle이 있다.
Maven은 Java의 대표적인 관리 도구였던 Ant를 대체하기 위해 개발되었다.
프로젝트의 외부 라이브러리를 쉽게 참조할 수 있게 pom.xml
파일로 명시하여 관리한다.
참조한 외부 라이브러리에 연관된 다른 라이브러리도 자동으로 관리됨
기존에 사용하는 Ant는 빌드의 기능만 갖고 있다. Maven 자동으로 라이브러리를 관리해주는 기능이 추가되었다. 다운받아 사용하던 라이브러리에 변동 사항이 있으면 자동으로 업데이트하여 적용되는 편리함이 있다.
pom.xml
로 편하게 Dependency 관리pom.xml
의 역할은 다음과 같다.
modelVersion
: maven의 버전groupId
: 프로젝트 그룹 id를 뜻하며, 일반적으로 대표하는 사이트 도메인을 역순으로 적어 사용artifactId
: groupId
외에 다른 프로젝트와는 구분될 수 있는 프로젝트의 id를 작성version
: 프로젝트의 버전을 의미하며 개발 단계에 따라 구분하여 작성name
: 프로젝트의 이름description
: 해당 프로젝트의 간략한 설명을 작성properties
: pom.xml
파일 내에서 빈번하게 사용되는 중복 상수를 정의하는 영역. 해당 영역의 상수를 사용하기 위해서는 ${태그명}
의 형태로 사용하면 된다.dependencies
: 해당 프로젝트에서 의존성을 가지고 사용하는 라이브러리를 정의하는 영역. 각 라이브러리마다 <dependency>
태그를 사용하여 구분build
: 프로젝트 빌드와 관련된 정보를 설정하는 영역Groovy 스크립트를 활용한 빌드 관리 도구다. 안드로이드 프로젝트의 표준 빌드 시스템으로 채택되어 있으며 멀티 프로젝트의 빌드에 최적화하여 설계되었다. Maven에 비해 더 빠른 처리속도를 가지고 있으며 더 간결한 구성이 가능하다. 거의 모든 타입의 소프트웨어를 빌드할 수 있는 빌드 자동화 시스템이다.
참고로, Groovy는 JVM 상에서 실행되는 스크립트 언어로 Java와 유사한 문법 구조를 가지며, 호환성이 아주 좋다.
pom.xml
vs Gradle: build.gradle
Gradle은 프로젝트를 설정 주입 방식으로 정의한다는 특징이 있다.
Maven의 상속 구조보다 재사용에 용의하며, 프로젝트의 조건을 체크할 수 있어서 프로젝트 별로 주입되는 설정을 다르게 할 수 있다.
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
</dependencies>
dependencies {
implementation 'org.springframework.boot:spring-boot-starter'
testImplementation 'org.springframework.boot:spring-boot-starter-test'
}
repositories
: 라이브러리가 저장된 위치 등 설정mavenCentral
: 기본 Maven Repositorydependencies
: 라이브러리 사용을 위한 의존성 설정이런 특징들 때문에 Maven 보다 두 배 이상, 최대 100배 빠르다.
api
: 내부 의존성을 컴파일과 런타임 모두에 보이는 API 의존성implementation
: 내부 의존성을 런타임에서만 보이는 구현 의존성compileOnly
: 컴파일에만 사용되는 의존성 정의runtimeOnly
: 런타임에만 사용되는 의존성 정의test
+ Implementation
, CompileOnly
, RuntimeOnly
: 해당 의존성을 테스트 시에만 사용하도록 정의Apache Maven Shade Plugin, Gradle fat jar를 활용하여 멀티 모듈을 만들어보는 실습 예제를 첨부하여 해당 설명을 대체합니다.