소개
Maven 은 유대어로 지식의 축적자라는 의미를 가지고 있다.
자바로 관리되는 프로젝트를 관리하고 빌드하는데 도움을 주는 도구이다.
목적
빌드 과정을 쉽게 만들어준다
개발자가 빌드에 필요한 많은 세부지식을 모르더라도 프로젝트를 빌드할 수 있게 해준다. 물론 기본 매커니즘을 몰라도 된다는 이야기는 아니다.
획일화된 빌드 시스템을 제공한다
메이븐은 Project Object Model (POM) 파일과 함께 플러그인의 조합을 이용하여 프로젝트를 빌드한다. 한번 빌드 과정에 익숙해지면 메이븐으로 빌드되는 프로젝트를 살펴보는데 드는 시간을 매우 줄일 수 있다.
양질의 프로젝트 정보를 제공한다
프로젝트 소스코드에서 생성된 POM 파일에는 유용한 정보가 있다. 이를테면 다음과 같은 정보를 제공한다.
- Source Control 에서 생성된 변경 로그
- 서로 참조되는 소스
- 프로젝트에 의해 관리되는 메일링 리스트
- 프로젝트에서 사용되는 의존성
- 커버리지가 포함된 유닛 테스트 결과
서드 파티 코드 분석 제품들은 메이븐에 의해 제공되는 표준 정보에 리포트를 추가하는 메이븐 플러그인을 제공한다.
개발의 베스트 프랙티스로 가는 가이드라인을 제공한다
메이븐은 베스트 프랙티스 개발로 가기 위한 원칙들을 모아준다.
이를테면 명세, 실행, 유닛 테스트 리포팅은 메이븐의 정상 빌드 사이클의 일부이다.유닛 테스팅 베스트 프랙티스는 아래의 가이드라인처럼 사용된다.
- 소스 코드를 분리하지만 소스트리는 병렬적으로 유지한다.
- 테스트를 위치시키고 실행할 때, 테스트 케이스 네이밍 컨벤션을 사용한다.
- 테스트 준비를 위한 빌드를 커스터마이징하는 대신 테스트 케이스 자체의 환경을 만들어놓는다.
메이븐은 이슈 관리나 릴리즈와 같은 프로젝트 워크플로우를 어시스트한다.
프로젝트의 디렉토리 구조를 어떻게 가져갈지에 대해서도 제안해준다. 한번 프로젝트 디렉토리 구조에 익숙해지면 어떤 프로젝트든 메이븐으로 만들어졌다면 쉽게 둘러볼 수 있다.
메이븐은 프로젝트 레이아웃에 대해서 고정된 접근법을 사용하지만, 몇몇 레거시 프로젝트는 이러한 구조를 따르지 않을 수도 있다. 메이븐은 이러한 니즈에 대해서도 유연하게 대응하도록 설계되었다. 그러나 모든 상황에 대응할 수는 없다.
프로젝트를 재구성할 수 없는 특이한 빌드 구조를 가진 경우 일부 기능이나 메이븐 사용을 완전히 포기해야 할 수도 있다.
메이븐을 오해하지 마세요
- 메이븐은 웹사이트도 아니고 문서화 도구가 아닙니다.
- 메이븐은 의존성을 다운로드 받을 수 있도록 도와주기만 하는 도구가 아닙니다.
- 메이븐은 재사용 가능한 Ant 스크립트 모음집이 아닙니다.
레퍼런스
다음으로 읽어볼만한 글
실무에서 메이븐을 쓰려면 메이븐의 골과 페이즈에 대해서 꼭 알기를 권장한다.
'빌드 도구 > 메이븐' 카테고리의 다른 글
메이븐의 .lastupdated 확장자 파일이란? (0) | 2023.03.03 |
---|---|
메이븐 인코딩 에러 해결하기 (0) | 2022.06.08 |
로컬 파일 메이븐 의존성 추가하기 (0) | 2022.06.08 |
intellij mvnw 파일이 없을 때 메이븐 경로 잡기 (0) | 2022.06.08 |
메이븐 유저가 꼭 알아야 할 메이븐의 골(Goal)과 페이즈(Phase)란 무엇일까? (1) | 2022.06.01 |