====== 개인 빌드 ====== ===== 개요 ===== 개인 빌드란 소프트웨어 개발자가 소프트웨어 소스 코드를 작성하고 이를 자신의 로컬 PC에서 컴파일 하여 실행 코드로 변환하는 일련의 과정을 말하며 주로 빌드 도구를 사용하여 실행한다. ===== 설명 ===== 대표적인 오픈소스 빌드 도구로는 make, ant, maven 등이 있으며 **전자정부 표준 프레임워크에서는 maven을 기본 빌드 도구로 사용**한다. \\ ==== 오픈 소스 빌드 도구 ==== * [[http://www.gnu.org/software/make/|GNU Make]] \\ make는 소프트웨어 개발에서 Unix계열 OS에서 주로 사용되는 프로그램 빌드 도구이다. * [[http://ant.apache.org/|Apache Ant]] \\ Ant는 **자바 기반의 빌드 도구**로 자바 언어를 사용하는 프로젝트에서 make를 사용하면서 겪게되는 많은 어려움을 줄여주고 더 많은 기능을 제공한다. \\ * 자바 소스 파일 컴피일 * jar, war, ear, zip 파일의 생성 * javadoc을 실행하여 도움말 생성 * 각각의 작업에 대한 의존성 설정 * [[http://maven.apache.org/|Maven - 전자정부 표준 프레임워크 기본 빌드 도구]] \\ Maven은 **프로젝트 관리 도구**로 빌드 기능의 수행 뿐 아니라 프로젝트 리포팅, documentation 생성 기능을 제공한다. * [[http://gradle.org/|Gradle]] \\ Gradle은 groovy 언어로 개발된 **프로젝트 관리 도구**로 코드기반의 스크립트를 이용하여 빌드, 배포, 리포팅, documentation 생성 기능을 제공한다. ==== Maven ==== 메이븐은 프로젝트 객체 모델(Project Object Model : POM)이라는 개념을 바탕으로 프로젝트 의존성 관리, 라이브러리 관리, 프로젝트 생명 주기 관리 기능 등을 제공하는 **프로젝트 관리 도구**이다. 또한 플러그인을 기반으로 소스 코드로부터 배포 가능한 산출물을 만들어 내는 **빌드 기능** 뿐만 아니라 레포팅 및 documentation 작성 기능 등을 제공한다. ==== Maven 특징 ==== ^Maven 장점 ^Maven 단점 ^ | • 뛰어난 의존성 관리 \\ - 의존성 자동 업데이트 \\ - 저장소를 통한 라이브러리 일괄 관리 \\ \\ • 모든 프로젝트에 걸쳐 쉽게 적용 가능한 일관적인 사용법 \\ \\ • 라이브러리 및 메타 데이터 저장을 위한 지속적으로 확장 되고 있는 저장소 \\ \\ • 쉽게 작성 가능한 플러그 인을 통한 확장성 \\ \\ • 동시에 다수의 프로젝트를 핸들링 할 수 있는 쉬운 설정 기반의 메커니즘 \\ \\ • 간단한 설정을 통한 배포 관리 \\ \\ • Java, C++ 등 다수의 프로그래밍 언어 지원 | • Repository 관리의 불편함 \\ - Maven 프로젝트의 급속한 발전으로 central repository가 제공하는 라이브러리들이 \\ 빠르게 증가하고 있으나 아직 3rd 파티 라이브러리 등 미제공 라이브러리들이 있음 \\ \\ • pom.xml 파일 관리 \\ - 메이븐 프로젝트 관리에 대한 모든 내용이 \\ pom.xml 파일에 담기게 됨으로 길고 장황하게 될 수 있음 \\ \\ • 프로젝트에 특화된 복잡한 빌드 기능 제약 \\ - 메이븐 프로젝트 특성상 소프트웨어 빌드에 통용되는 \\ 라이프 사이클을 제공하고 있어 세부 항목 또는 특화된 빌드 환경에 대한 지원이 미약함| ==== Maven 아키텍처 ==== Maven은 프로젝트 전체 내용에 대한 기술 및 설정을 담당하는 POM과 라이브러리(Maven에서는 artifact라 호칭함)관리에 대한 dependency/repository 관리 모델 그리고 컴파일, 테스트, 패키징 등의 빌드 생명 주기를 다루는 lifecycle 및 관련된 plugin들과의 연동을 다루는 부분으로 구성된다.\\ {{:egovframework:dev2:dep:build:mvn-arch1.gif|}} ^ POM | 메이븐 엔진 내장 + POM.XML 파일에서 선언적으로 제공한다. - 참조: [[#pom | POM(프로젝트 객체 모델)]] | ^ 의존성 관리 모델| 로컬 및 리모트 저장소를 이용 - 참조: [[egovframework:dev2:dep:maven:의존성_메커니즘 | Dependency Management]] | ^ 프로젝트 생명 주기 모듈| 메이븐 엔진은 플러그인을 통해 파일을 다루는 거의 모든 작업을 수행 - 참조: [[egovframework:dev2:dep:build_tool:개인빌드:빌드_lifecycle | 빌드 lifecycle]] | ==== POM ==== POM은 프로젝트 관리 및 빌드에 필요한 환경 설정, 의존성 관리 등의 프로젝트 정보들을 담고 있으며 이는 메이븐 프로젝트 생성 시 기본 설정 파일로 생성되는 pom.xml 파일에 기술된다. === 설명 === pom.xml 파일은 프로젝트의 세부 메타 데이터 정보를 포함하며 크게 10개의 항목으로 구성된다. \\ 프로젝트 일반 정보, 버전 및 설정 관리, 빌드 환경, 라이브러리 저장소 및 의존성 등의 내용을 포함한다. \\ \\ {{:egovframework:dev2:dep:maven:mvn-pom-structure.gif|}} * **General Information** \\ 프로젝트 이름, 설명, 버전 정보 등을 기술한다. - [[#프로젝트 정보 생성]] 참조 * Organization : 프로젝트 조직 정보: 이름, 홈페이지 URL * Project Team and Collaborations tools \\ 형상관리 서버, 이슈 트랙커, 통합 빌드 서버 정보 등 * **Build** \\ 인코딩 정보 등 [[egovframework:dev2:dep:build_tool:개인빌드:빌드_lifecycle|빌드 Lifecycle]] 환경 설정 * **Reporting** \\ 리포트 생성 기능을 설정한다. * **Dependencies** \\ 프로젝트에서 사용하는 __라이브러리__를 선언하여 Build Path에 포함시킨다. - [[#Dependency(의존성) 설정]] 참조 * Repositories \\ 라이브러리 저장소 위치 설정 * Distribution Management \\ 배포 환경 설정 * Profiles \\ 이기종 환경에서의 이식성을 높여 주기 위한 빌드 설정 \\ [[http://maven.apache.org/guides/introduction/introduction-to-profiles.html|Maven 빌드 profile 소개]] * Properties - 프로젝트 property를 설정한다. ==== Maven 디렉터리 구조 ==== 메이븐은 Best practices을 기반으로 정규화된 디렉터리 구조를 제공하고 있으며 모든 소스 파일들은 /src 디렉터리 밑에, 빌드 된 output은 /target 디렉터리 밑에 위치한다. \\ Maven 프로젝트는 개발자에 의한 특정한 source/resource path 설정 없이 정규화된 디렉토리 구조를 기반으로 프로젝트 자원에 대한 접근 메커니즘을 제공한다. Maven은 소스 또는 리소스에 대한 path 설정이 필요하지 않다. {{:egovframework:dev2:dep:build:mvn-dir.gif|}} ==== Dependency Management ==== 메이븐은 POM에서 선언적인 dependency 설정으로 빌드 및 배포 시에 필요한 라이브러리들을 관리하고 로컬 및 원격 [[egovframework:dev2:dep:maven:maven_repository|저장소]]에서 선언된 라이브러리들을 다운로드 받아 사용한다. === 설명 === 메이븐의 가장 큰 장점 중의 하나로 라이브러리 의존성 관리를 들 수 있다. 일반적인 프로젝트 수행 시 개발자들은 라이브러리 설정을 위해 프로젝트 내부 디렉터리에 직접 라이브러리를 받아와 위치 시키고 path 설정을 통해 이를 이용한다. 이럴 경우 개발자들이 직접 라이브러리를 찾고 설정하는 번거로움과 프로젝트 내부에서 사용하는 라이브러리 종류와 버전을 컨트롤 하는데 문제가 발생할 수 있다. 특히 통합 빌드 과정에서 라이브러리 관련 문제들이 빈번히 발생할 수 있다. 메이븐은 이를 효과적으로 처리하기 위해 의존성 관리 메커니즘을 제공하고 있으며 메이븐 개발자들은 프로젝트의 pom.xml에 dependency 선언만으로 필요한 라이브러리들을 받아와 편하게 사용할 수 있다. 프로젝트 관리자의 경우 사용되고 있는 라이브러리와 버전을 효과적으로 컨트롤할 수 있으며 개발자들에게 검증되고 통일된 버전의 라이브러리를 제공할 수 있다. 예) 아래와 같이 선언하여 junit 테스트를 위한 라이브러리를 사용할 수 있다. ...... junit junit 4.4 test === 의존성 분석 순서 === - 로컬 저장소에서 의존성 확인 - 원격 저장소 리스트에서 의존성 확인 - 1과 2가 실패하면 의존성 에러 보고 === 의존성 필수 선언 항목 === - : 부분적인 프로젝트나 조직에서의 라이브러리 집합을 식별하기 위해 제공한다. - : 프로젝트의 실제 이름으로 groupId와 합쳐져 프로젝트 식별에 쓰인다. - : 선언한 의존성 artifact의 버전으로 프로젝트 내에서 사용하는artifact의 일관성을 추구할 수 있다. === 의존성 SCOPE === - compile: 기본값으로 모든 클래스 패스에서 사용 가능하다. - provided: 컴파일과 유사하나 패키지에는 포함되지 않는다. 컨테이너나 JDK에서 제공한다. 예) Servlet API for web apps - runtime: 컴파일러가 아닌 런타임 시에 사용된다. 예) JDBC drivers - test: 테스트 단계에서만 사용된다. 예)Junit - system: provided와 유사하나 개발자가 직접 JAR 파일을 제공해야 하고 저장소에서 지정한 dependency를 찾지 않는다. 의존성 SCOPE은 선언이 안되어 있을 경우 기본값으로 compile이 적용된다. JDK나 WAS에서 제공하는 라이브러리와 dependency에서 선언한 \\ 라이브러리 간의 충돌이 일어나는 경우가 발생할 수 있으므로 사용하고자 하는 라이브러리의 SCOPE을 잘 명시해야 한다. ===== 사용법 ===== [[#POM | pom.xml]]파일에 프로젝트 이름, 패키징 방법, 버전 정보, 프로젝트 설명 등의 파일을 기술하며 프로젝트에서 사용하는 환경 설정, \\ 빌드 방법, 사용하는 라이브러리 정보 등을 기술하여 빌드 및 프로젝트 관리 환경을 조성한다. ==== 프로젝트 정보 생성 ==== 프로젝트 groupId, artifactId, 패키징 타입, 버전 정보 및 프로젝트 설명을 기술한다. 4.0.0 egovframework.guideprogram egovframework.guideprogram.basicsample war 1.0.0-SNAPSHOT egovframework.guideprogram.basicsample http://maven.apache.org 2.5.6 1.5 UTF-8 ==== Repository 설정 ==== 사용할 리포지토리 정보를 설정한다. 주로 프로젝트에서 Nexus와 같은 로컬 리포지토리를 사용할 경우 접속 정보를 설정해서 Nexus에 접속하여 artifact들을 다운로드 받을 수 있다. central true http://192.168.100.15:8081/nexus/content/groups/public snapshots true http://192.168.100.15:8081/nexus/content/groups/public-snapshots ==== Dependency(의존성) 설정 ==== 프로젝트에서 사용할 라이브러리(Maven에서는 artifact라 함)을 선언한다. org.springframework spring ${spring.maven.artifact.version} org.springframework spring-webmvc 2.5 jar ==== System Dependency(의존성) 설정 ==== system scope을 가지는 dependency는 다른 scope과 달리 리포지토리에서 찾지 않는 artifact로 항상 사용 가능해야 한다. 주로 JDK 또는 \\ VM에서 제공하는 dependency들을 제공한다. 전형적인 예로 JDBC standard extensions나 Java Authentication and Authorization Service(JAAS)를 \\ 들 수 있다. jdbc standard extension 예 ... javax.sql jdbc-stdext 2.0 system ${java.home}/lib/rt.jar ... JDK's tools.jar 선언 예 ... sun.jdk tools 1.5.0 system ${java.home}/../lib/tools.jar ... ==== Reporting 설정 ==== 메이븐은 프로젝트 정보에 대한 기본 report 뿐만 아니라 플러그인 설정을 통해 emma, JavaDoc 등의 문서 생성 기능을 제공한다. ${basedir}/target/site maven-project-info-reports-plugin 2.0.1 org.codehaus.mojo emma-maven-plugin true org.codehaus.mojo surefire-report-maven-plugin true org.apache.maven.plugins maven-javadoc-plugin 128m 512m UTF-8 UTF-8 UTF-8 ===== 샘플 ===== ==== pom.xml 예제 ==== 4.0.0 egovframework.dev.com egovframework-dev-com 1.0 war egovframework-dev-com Maven Webapp junit junit 4.4 test org.apache.maven.plugins maven-compiler-plugin 1.5 1.5 ==== pom.xml 예제 (Hudson에서의 사용 예) ==== 4.0.0 org.jvnet.hudson hudson 1.6 ../pom.xml org.jvnet.hudson.main pom 1.274 pom Hudson main module The module that constitutes the main hudson.war remoting core maven-agent maven-interceptor war test scm:svn:https://svn.dev.java.net/svn/hudson/tags/hudson-1_274 scm:svn:https://svn.dev.java.net/svn/hudson/tags/hudson-1_274 https://hudson.dev.java.net/source/browse/hudson/tags/hudson-1_274 install maven-release-plugin 2.0-beta-8 -P release,ips,sign install javadoc:javadoc animal-sniffer:check assembly:attached deploy maven-assembly-plugin false hudson-${version} assembly-src.xml maven-remote-resources-plugin process org.jvnet.hudson:license:1.0 org.jvnet animal-sniffer 1.2 org.jvnet.animal-sniffer java1.5 1.0 org.jvnet animal-sniffer-annotation 1.0 true 2.0.4 debug true hudson ../dummy.keystore hudson m.g.o-public http://maven.glassfish.org/content/groups/public/ true false m.g.o-public http://maven.glassfish.org/content/groups/public/ true false The MIT license http://www.opensource.org/licenses/mit-license.php repo hudson-www java-net:/hudson/trunk/www/maven-site/ ===== 참고자료 ==== [[http://maven.apache.org/|아파치 메이븐 프로젝트]]