Maven Repository는 artifact들의 저장소로 로컬 및 리모트 repository로 구성되며 프로젝트의 pom.xml에서 선언한 dependency들을 저장소로부터 불러와서 사용한다.
리포지토리 구성도
기본 구성도 | Repository 관리도구(Nexus) 연동 구성도 |
---|---|
Maven의 환경 설정 파일인 settings.xml 파일에서 로컬 repository의 위치 변경 및 리모트 repository에 대한 설정을 할 수 있다.
<settings> <!-- localRepository | The path to the local repository maven will use to store artifacts. | | Default: ~/.m2/repository--> <localRepository>C:/java/.m2/repository</localRepository> </settings>
일반적인 개발 시에 주로 사용되는 라이브러리 관리 메커니즘은 필요로 하는 라이브러리를 프로젝트 내부 디렉터리에 담고 path 설정을 통해 사용하고 있으나 Maven에서는 의존성 설정 메커니즘(라이브러리를 설정 파일에 선언하여 사용함)을 통해 사용하고 관리한다.1. 프로젝트의 pom.xml에서 라이브러리 선언
3. 리모트 리포지토리에서 선언한 라이브러리 검색
artifact가 저장되는 디렉토리 구조
: groupId / artifact name / version / artifact name-version.jar & artifact name-version.pom
예) groupId: org.easymock artifactId: easymock version: 2.4 - 저장 위치: org/easymock/easymock/2.4/easymock-2.4.jar & easymock-2.4.pom
3rd 파티에서 제공하는 Tibero jdbc artifact를 로컬 repository에 추가 하기
실제 3rd 파티에서 제공하는 라이브러리는 각 기업 또는 organization에서 배포하는 라이브러리 파일을 다운로드하여 사용한다. 다운로드한 라이브러리의 이름 및 버전 정보를 확인한다.
받은 라이브러리를 Maven의 artifact로 등록하기 위해서는 3가지 필수 항목을 준수 하여야 한다. - Maven Dependency Management 참조
1. 로컬 repository의 디렉토리 구조에서 설명한 구조로 메이븐 repository에 폴더들을 생성한다.
디렉토리 구조: com/tmax/tibero/tibero-jdbc/3.0 이 디렉토리 밑에 다운로드 받은 라이브러리와 프로젝트 정보를 기술한 pom 파일을 넣는다.
예) 일반적인 artifactId는 라이브러리 이름-버전으로 구성되고 pom 파일의 이름은 artifactId.pom 파일 형태가 된다. 따라서 tibero jdbc의 artifactId는 tibero-jdbc-3.0.jar가 되고 pom 파일 이름은 tibero-jdbc-3.0.pom 이 된다.
2. artifactId.pom 파일을 작성
pom 파일에 기술 되어야 할 정보는 위에서 언급한 groupId, artifactId, version 정보이다.
tibero-jdbc-3.0.pom
<project> <modelVersion>4.0.0</modelVersion> <groupId>com.tmax.tibero</groupId> <artifactId>tibero-jdbc</artifactId> <version>3.0</version> <description>POM was created by Sonatype Nexus</description> </project>
✔artifact를 추가 하기 위한 네이밍 룰은 중요하게 다루어져야 하며 네이밍 룰 오류로 인한 artifact 저장 및 사용에 있어 dependency dismissing 오류가 발생할 수 있다.