Ant 대 Maven 대 Gradle

Ant Vs Maven Vs Gradle



소프트웨어 개발 중에 개발자는 동일한 코드를 계속해서 다시 작성해야 합니다. 그들은 종종 bash 스크립트나 다른 스크립팅 언어를 사용하여 작업을 자동화하려고 합니다. 그러나 빌드 자동화에 더 적합한 빌드 도구를 사용할 수 있습니다. 주요 빌드 도구는 다음과 같습니다.

자세한 내용을 알아보기 위해 도구를 조사해 보겠습니다.

아이비와 아파치 앤트

Apache Ant는 XML 파일을 사용하여 빌드 스크립트를 정의하는 Java 기반 명령줄 도구입니다. 주로 Java 빌드에 사용되지만 C/C++ 개발에도 사용할 수 있습니다. 기본 제공 작업은 소프트웨어 응용 프로그램을 컴파일, 어셈블, 테스트 및 실행하는 방법을 제공합니다. 사용자는 Ant의 기능을 향상시키기 위해 자신의 antlib를 만들 수도 있습니다. Apache Ivy는 Ant와 쉽게 통합되어 보다 강력한 에코시스템을 제공하는 종속성 관리 도구입니다. Ant의 개발은 2000년에 시작되었습니다.

장점

  • 전체 빌드 프로세스에 대한 더 나은 제어
  • 어떤 작업 프로세스에서도 작동할 수 있을 만큼 충분히 유연합니다.

단점

  • XML 기반 빌드 파일이 커져서 유지 관리가 불가능할 수 있음
  • 빌드 스크립트를 유지 관리하는 데 많은 시간과 리소스가 필요합니다.
  • IDE 통합이 어렵습니다.

아이비와 개미 예

다음에서 최신 Ant를 설치할 수 있습니다. 여기 . zip을 다운로드하고 확장하여 경로에 bin 폴더를 넣어야 합니다. 다음 명령을 사용하여 Ant가 제대로 설치되었는지 확인할 수 있습니다.

$ 개미-버전
아파치 개미(TM)2월에 컴파일된 버전 1.10.12 2017.

Ant가 설치되면 최신 Ivy jar를 다운로드하여 Ant 디렉토리 안의 lib 폴더에 넣을 수 있습니다.

Ant를 설치한 후 helloworld 및 helloworld/src 폴더를 만듭니다. src 폴더 안에 다음 코드와 함께 helloworld.java 파일을 넣습니다.

/ **************************

'Hello World!'를 출력합니다.

*************************** /

공공의 수업헬로월드{

공공의 공전 무효의기본( []인수) {
체계 ..인쇄('안녕 월드!');
}

}

이제 helloworld 폴더에서 다음 코드로 build.xml 파일을 만듭니다.

xmlns:아이비='antlib:org.apache.ivy.ant' 이름='헬로월드' 기본='항아리'>

이름='rc.dir' ='rc'/>
이름='빌드.디렉토리' ='짓다'/>
이름='classes.dir' ='${빌드.디렉토리}/클래스'/>
이름='am.dir' ='$ {빌드.디렉토리} / bin'/>
이름='lib.dir' ='리브' />
ID='lib.path.id'>
너에게='$ {lib.dir}' />
>

이름='해결하다'>
/>
>

이름='깨끗한'>
너에게='$ {빌드.디렉토리}'/>
>

이름='엮다' 달려있다='해결하다'>
너에게='$ {classes.dir}'/>
srcdir='$ {src.dir}' 목적지='$ {classes.dir}' 클래스 경로 참조='lib.path.id'/>
>

이름='항아리' 달려있다='엮다'>
너에게='$ {bin.dir}'/>
데스파일='${bin.dir}/${ant.project.name}.jar' 기반='$ {classes.dir}'/>
>

>

그리고 동일한 helloworld 폴더에 다음 코드로 ivy.xml 파일을 생성합니다.

버전='2.0'>
조직='org.apache' 기준 치수='헬로월드'/>
>
조직='주닛' 이름='주닛' 신부님='4.12'/>
>
>

디렉토리 구조는 다음과 같아야 합니다.

헬로월드
|-- 빌드.xml
| - 아이비.xml
`-- src
`- helloworld.java

이제 다음 명령으로 빌드를 실행할 수 있습니다.

$개미항아리

성공적인 빌드는 다음과 같은 출력을 제공해야 합니다.

$ 개미 항아리
빌드 파일: /Users/zak/_work/LearnBuildScripts/LearnANT/helloworld/build.xml

해결하다:
[ivy:retrieve] :: 아파치 아이비 2.4.0 - 20141213170938 :: http://ant.apache.org/ivy/ ::
[ivy:retrieve] :: 로딩 설정 :: url = jar:file:/Users/zak/BuildTools/ANT/apache
-ant-1.10.1/lib/ivy-2.4.0.jar!/org/apache/ivy/core/settings/ivysettings.xml
[ivy:retrieve] :: 종속성 해결 :: org.apache#helloworld; [이메일 보호됨]
MacBook-Air.local
[ivy:retrieve] confs: [기본값]
[ivy:retrieve] 공개에서 junit#junit;4.12를 찾았습니다.
[ivy:retrieve] 공개된 org.hamcrest#hamcrest-core;1.3을 찾았습니다.
[ivy:retrieve] :: 해결 보고서 :: 해결 397ms :: 아티팩트 dl 15ms
-------------------------------------------------- -------------------
| | 모듈 || 유물 |
| 회의 | 번호| 검색|dwnlded|퇴거|| 번호|dwnlded|
-------------------------------------------------- -------------------
| 기본값 | 2 | 0 | 0 | 0 || 4 | 0 |
-------------------------------------------------- -------------------
[ivy:retrieve] :: 검색 중 :: org.apache#helloworld
[ivy:retrieve] confs: [기본값]
[ivy:retrieve] 복사된 아티팩트 0개, 이미 검색된 아티팩트 4개(0kB/39ms)

엮다:
[mkdir] 생성된 디렉토리: /Users/zak/_work/LearnBuildScripts/LearnANT/helloworld/build/
클래스
[javac] /Users/zak/_work/LearnBuildScripts/LearnANT/helloworld/build.xml:22: 경고:
'includeantruntime'이 설정되지 않았으며 기본값은 build.sysclasspath=last입니다. 거짓으로 설정
반복 가능한 빌드용
[javac] 1개의 소스 파일을 /Users/zak/_work/LearnBuildScripts/LearnANT/로 컴파일
helloworld/빌드/클래스

항아리:
[mkdir] 생성된 디렉토리: /Users/zak/_work/LearnBuildScripts/LearnANT/helloworld/build/bin
[jar] 항아리 만들기: /Users/zak/_work/LearnBuildScripts/LearnANT/helloworld/build/bin/
안녕하세요.jar

성공적인 구축
총 시간: 6초

다음과 같이 jar 파일을 사용해 볼 수 있습니다.

$ java -cp build/bin/helloworld.항아리헬로월드
헬로월드!

build/bin 폴더에 넣을 jar 파일을 정의했습니다. 폴더는 빌드 중에 생성됩니다. ant jar 명령은 build.xml에서 jar 대상을 호출합니다.

메이븐

Maven은 Ant 기반 스크립팅이 직면한 문제를 해결하기 위해 개발되었습니다. XML 파일을 유지했지만 조직에 대해 다른 접근 방식을 취했습니다. Ant에서 개발자는 모든 작업을 생성해야 합니다. Maven은 코드 구성을 위한 더 강력한 표준을 구현하여 작업 생성을 줄입니다. 결과적으로 표준 프로젝트를 시작하기가 더 쉽습니다.

또한 개발을 더 쉽게 만든 종속성 다운로드를 도입했습니다. Ant에 Ivy를 도입하기 전에 사용자는 로컬에서 종속성을 관리해야 했습니다. Maven은 먼저 종속성 관리 철학을 채택했습니다.

그러나 Maven의 엄격한 표준으로 인해 사용자 정의 빌드 스크립트를 작성하기가 어렵습니다. 이 도구는 프로젝트가 엄격한 표준을 따르는 한 작업하기 쉽습니다.

장점

  • 자동 종속성 다운로드
  • 모든 종속성은 Maven 스크립트의 일부로 소스 제어에 자동으로 기록됩니다.
  • 빌드 프로세스 표준화 및 단순화
  • IDE 및 CI/CD 시스템과 쉽게 통합

단점

  • 맞춤형 워크플로를 만드는 데 유연하지 않음
  • 초보자가 이해하기 어려운 가파른 학습 곡선과 과정
  • 빌드 문제 및 새로운 라이브러리 통합을 해결하는 데 시간이 많이 소요됨
  • 동일한 종속성의 여러 버전에서는 좋지 않습니다.

메이븐 예제

최신 Maven을 다음에서 다운로드할 수 있습니다. 여기 . 다음과 같이 설치를 확인할 수 있습니다.

$ mvn --버전
아파치 메이븐 3.5.2(138edd61fd100ec658bfa2d307c43b76940a5d7d; 2017.-10-18T00:58:13-07: 00)
메이븐 홈: /Users/zak/BuildTools/Maven/apache-maven-3.5.2
Java 버전: 1.8.0_74, 공급업체: Oracle Corporation
자바 홈: /Library/Java/JavaVirtualMachines/jdk1.8.0_74.jdk/목차/홈/jre
기본 로케일: en_US, 플랫폼 인코딩: UTF-8
OS 이름:'맥 OS X', 버전:'10.11.6', 아치:'x86_64', 가족:'맥'

helloworld 폴더를 만들고 다음 명령으로 프로젝트를 생성합니다.

$ mvn archetype:generate -DgroupId=com.회사 이름.헬로월드-DartifactId=helloworld
-DarchetypeArtifactId = maven-archetype-quickstart -DinteractiveMode =거짓

폴더 구조를 만들고 다음과 같은 출력을 생성해야 합니다.

[정보] 프로젝트 검색 중...
[정보]
[정보] ----------------------------------------------------------- --------------------------
[INFO] Maven Stub 프로젝트 빌드(POM 없음) 1
[정보] ----------------------------------------------------------- --------------------------
[정보]
[정보] >>> maven-archetype-plugin:3.0.0:generate(default-cli) > 생성 소스
@ 독립형-pom >>>
[정보]
[정보]<<< maven-archetype-plugin:3.0.0:generate (default-cli) < generate-sources
@ 독립형-pom<<<
[정보]
[정보]
[정보] --- maven-archetype-plugin:3.0.0:generate (default-cli) @ standalone-pom ---
[정보] Batch 모드에서 프로젝트 생성
[정보] ----------------------------------------------------------- --------------------------
[정보] Old(1.x) Archetype에서 프로젝트를 생성하기 위해 다음 매개변수 사용:
maven-archetype-quickstart:1.0
[정보] ----------------------------------------------------------- --------------------------
[정보] 매개변수: basedir, 값: /Users/zak/_work/LearnBuildScripts/LearnMaven
[정보] 매개변수: 패키지, 값: com.companyname.helloworld
[정보] 매개변수: groupId, 값: com.companyname.helloworld
[정보] 매개변수: artifactId, 값: helloworld
[정보] 매개변수: packageName, 값: com.companyname.helloworld
[정보] 매개변수: 버전, 값: 1.0-SNAPSHOT
[INFO] 디렉토리의 Old(1.x) Archetype에서 생성된 프로젝트: /Users/zak/_work/
LearnBuildScripts/LearnMaven/helloworld
[정보] ----------------------------------------------------------- --------------------------
[정보] 구축 성공
[정보] ----------------------------------------------------------- --------------------------
[정보] 총 시간: 8.602초
[정보] 종료일: 2018-01-27T00:05:37-08:00
[정보] 최종 메모리: 15M/152M
[정보] ----------------------------------------------------------- --------------------------

폴더 구조는 다음과 같아야 합니다.

헬로월드
|- pom.xml
``-- src
|-- 기본
| ``-자바
| ``-- 와 함께
| ``-- 회사 이름
| ``-- 헬로월드
| ``- 앱.자바
``-시험
``-자바
``-- 와 함께
``-- 회사 이름
``-- 헬로월드
``- 앱테스트.자바

pom.xml에는 빌드 구성이 포함되어 있습니다. pom.xml 내부의 코드는 다음과 같습니다.

xmlns='http://maven.apache.org/POM/4.0.0' xmlns:xsi='http://www.w3.org/2001/
XMLSchema 인스턴스'
xsi:스키마위치='http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0
_0.xsd'>
>4.0.0>
>com.companyname.helloworld>
>헬로월드>
>항아리>
>1.0-스냅샷>
>헬로월드>
>http://maven.apache.org>
>
>
>주니트>
>주니트>
>3.8.1>
>시험>
>
>
>

다음 명령을 사용하여 jar 파일을 생성할 수 있습니다.

$ mvn 패키지

[정보] 프로젝트 검색 중...
[정보]
[정보] ----------------------------------------------------------- --------------------------
[INFO] 헬로월드 1.0-SNAPSHOT 구축
[정보] ----------------------------------------------------------- --------------------------
[정보]
[정보] --- maven-resources-plugin:2.6:resources (default-resources) @ helloworld ---
[경고] 플랫폼 인코딩(실제로는 UTF-8)을 사용하여 필터링된 리소스를 복사합니다.
빌드는 플랫폼에 따라 다릅니다!
[정보] 존재하지 않는 resourceDirectory 건너뛰기 /Users/zak/_work/LearnBuildScripts/LearnMaven/
helloworld/src/main/resources
[정보]
[정보] --- maven-compiler-plugin:3.1:compile(기본 컴파일) @ helloworld ---
[정보] 변경 사항이 감지되었습니다. 모듈을 다시 컴파일하는 중입니다!
[경고] 플랫폼 인코딩 UTF-8을 사용하여 파일 인코딩이 설정되지 않았습니다. 즉, 빌드가
플랫폼 의존!
[정보] 1개의 소스 파일을 /Users/zak/_work/LearnBuildScripts/LearnMaven/으로 컴파일
헬로월드/타겟/클래스
[정보]
[정보] --- maven-resources-plugin:2.6:testResources(기본값-testResources) @
헬로월드 ---
[경고] 플랫폼 인코딩(실제로는 UTF-8)을 사용하여 필터링된 리소스를 복사합니다.
빌드는 플랫폼에 따라 다릅니다!
[정보] 존재하지 않는 resourceDirectory 건너뛰기 /Users/zak/_work/LearnBuildScripts/LearnMaven/
helloworld/src/test/resources
[정보]
[정보] --- maven-compiler-plugin:3.1:testCompile (default-testCompile) @ helloworld ---
[정보] 변경 사항이 감지되었습니다. 모듈을 다시 컴파일하는 중입니다!
[경고] 플랫폼 인코딩 UTF-8을 사용하여 파일 인코딩이 설정되지 않았습니다. 즉, 빌드가
플랫폼 의존!
[정보] 1개의 소스 파일을 /Users/zak/_work/LearnBuildScripts/LearnMaven으로 컴파일
/helloworld/target/test-classes
[정보]
[정보] --- maven-surefire-plugin:2.12.4:test (default-test) @ helloworld ---
[정보] Surefire 보고서 디렉토리: /Users/zak/_work/LearnBuildScripts/LearnMaven
/helloworld/타겟/
확실한 보고서

-------------------------------------------------- ------
T E S T S
-------------------------------------------------- ------
com.companyname.helloworld.AppTest 실행
테스트 실행: 1, 실패: 0, 오류: 0, 건너뛰기: 0, 경과 시간: 0.014초

결과 :

테스트 실행: 1, 실패: 0, 오류: 0, 건너뛰기: 0

[정보]
[정보] --- maven-jar-plugin:2.4:jar (기본-jar) @ helloworld ---
[정보] jar 빌드: /Users/zak/_work/LearnBuildScripts/LearnMaven/helloworld/target/
helloworld-1.0-SNAPSHOT.jar
[정보] ----------------------------------------------------------- --------------------------
[정보] 구축 성공
[정보] ----------------------------------------------------------- --------------------------
[정보] 총 시간: 5.624초
[정보] 종료일: 2018-01-27T00:11:10-08:00
[정보] 최종 메모리: 16M/114M
[정보] ----------------------------------------------------------- --------------------------

다음과 같이 jar 파일을 실행할 수 있습니다.

$ java -cp 대상/helloworld-1.0-스냅 사진.항아리와 함께.회사 이름.헬로월드.
헬로월드!

jar 파일은 대상 폴더에 저장됩니다.

그라들

Gradle은 Ant와 Maven의 기능을 결합합니다. Gradle의 첫 번째 버전은 2012년에 출시되었습니다. 빠르게 채택되었습니다. Google은 현재 Android OS에 사용하고 있습니다.

XML 대신 Gradle은 Groovy 언어를 사용합니다. 결과적으로 Gradle의 빌드 스크립트는 작성 및 읽기가 더 쉽습니다. 처음에는 종속성 관리를 위해 Ivy를 사용했지만 지금은 자체 종속성 엔진을 사용하고 있습니다.

장점

  • 유연성을 유지하면서 표준화 제공
  • 읽기 쉬운 빌드 스크립트
  • 여러 버전의 종속성을 더 잘 처리함
  • 여러 프로그래밍 언어와 기술을 다룰 수 있는 사람
  • 도구 개발을 돕는 활발한 커뮤니티
  • Gradle DSL(Domain-Specific Language)은 구성 구조를 단순화합니다.
  • Gradle은 증분, 빌드 캐시 및 Gradle 데몬을 사용하여 성능 향상을 제공합니다.

단점

  • Maven만큼 좋지 않은 IDE 통합

Gradle 예제

다음에서 Gradle을 설치할 수 있습니다. 여기 . 경로에 Gradle을 설정하면 다음을 통해 확인할 수 있습니다.

$ 그래들--버전

-------------------------------------------------- ----------
그라들4.5
-------------------------------------------------- ----------

빌드 시간:2018년-01-24 17: 04:52UTC
개정: 77d0ec90636f43669dc794ca17ef80dd65457bec

그루비: 2.4.12
개미: 아파치 개미(TM)2월에 컴파일된 버전 1.9.92 2017.
JVM: 1.8.0_74(오라클 코퍼레이션25.74-b02)
OS: 맥 OS X 10.11.6 x86_64

다음으로 다음 디렉터리 구조를 만듭니다.

헬로월드
| -짓다.그라들
``-src
| -기본
``-자바
``-헬로월드
``-안녕하세요.자바

helloworld.java의 경우 Ant 예제의 코드를 넣으십시오. 그리고 build.gradle의 경우 다음 코드를 입력합니다.

플러그인 적용: '자바'

버전= '1.0'

저장소{
메이븐센트럴()
}

의존성{
testCompile 그룹: '주닛', 이름: '주닛', 버전: '4.12'
}

gradle tasks –all 명령을 사용하여 사용 가능한 모든 명령을 볼 수 있습니다. Gradle은 build.gradle 파일에서 지정한 플러그인을 자동으로 선택하고 플러그인으로 인해 사용 가능한 추가 작업을 보여줍니다.

다음을 실행하여 빌드를 얻을 수 있습니다.

$ 그래들 항아리

짓다 성공적인 1초 안에
2실행 가능한 작업:2처형

다음과 같이 jar를 실행할 수 있습니다.

$ java -cp 빌드/libs/helloworld-1.0.항아리헬로월드
헬로월드!

jar 파일은 build/libs 폴더에 있습니다.

결론

빌드 도구 중에서 Ant는 소규모 프로젝트에 유용할 수 있으며 Maven은 모든 개발자가 동일한 규칙을 따르도록 하는 데 더 좋습니다. Gradle은 최고의 유연성을 제공하는 최신 도구입니다.

참조: