English | 简体中文 | 繁體中文 | Русский язык | Français | Español | Português | Deutsch | 日本語 | 한국어 | Italiano | بالعربية

Maven 자동 배포

项目开发过程中,部署的过程包含需如下步骤:

  • 将所的项目代码提交到 SVN 或者代码库中并打上标签。

  • 从 SVN 上下载完整的源代码。

  • 构建应用。

  • 存储构建输出的 WAR 或者 EAR 文件到一个常用的网络位置下。

  • 从网络上获取文件并且部署文件到生产站点上。

  • 更新文档并且更新应用的版本号。

问题描述

通常情况下上面的提到开发过程中会涉及到多个团队。一个团队可能负责提交代码,另一个团队负责构建等等。很有可能由于涉及的人为操作和多团队环境的原因,任何一个步骤都可能出错。比如,较旧的版本没有在网络机器上更新,然后部署团队又重新部署了较早的构建版本。

解决方案

通过结合以下方案来实现自动化部署:

  • 使用 Maven 构建和发布项目

  • 使用 SubVersion, 源码仓库来管理源代码

  • 使用远程仓库管理软件(Jfrog或者Nexus) 来管理项目二进制文件。

修改项目的 pom.xml

我们将会使用 Maven 发布的插件来创建一个自动化发布过程。

例如,bus-core-api 项目的 pom.xml 文件代码如下:

<project xmlns="http://maven.apache.org/POM/4.0.0" 
   xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
   xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 
   http://maven.apache.org/xsd/maven-4.0.0.xsd">
   <modelVersion>4.0.0</modelVersion>
   <groupId>bus-core-api</groupId>
   <artifactId>bus-core-api</artifactId>
   <version>1.0-SNAPSHOT</version>
   <packaging>jar</packaging> 
   <scm>
      <url>http://www.svn.com</url>
      <connection>scm:svn:http://localhost:8080/svn/jrepo/trunk/
      Framework</connection>
      <developerConnection>scm:svn:${username}/${password}@localhost:8080:
      common_core_api:1101:code</developerConnection>
   </scm>
   <distributionManagement>
      <repository>
         <id>Core-API-Java-Release</id>
         <name>Release repository</name>
         <url>http://localhost:8081/nexus/content/repositories/
         Core-Api-Release</url>
      </repository>
   </distributionManagement>
   <build>
      <plugins>
         <plugin>
            <groupId>org.apache.maven.plugins</groupId>
            <artifactId>maven-release-plugin</artifactId>
            <version>2.0-beta-9</version>
            <configuration>
               <useReleaseProfile>false</useReleaseProfile>
               <goals>deploy</goals>
               <scmCommentPrefix>[bus-core-api-release-checkin]-<
               /scmCommentPrefix>
            </configuration>
         </plugin>
      </plugins>
   </build>
</project>

pom.xml 파일에서 자주 사용하는 중요한 요소 노드는 다음 표에 나타ن 것과 같습니다:

요소 노드설명
SCMSVN의 경로를 설정하면 Maven이 해당 경로에서 코드를 가져옵니다.
repository구축된 WAR 또는 EAR 또는 JAR 파일의 위치, 또는 소스 코드가 성공적으로 구축된 후 생성된 구성 요소의 저장 위치.
Pluginmaven을 구성합니다.-release-plugin 플러그인을 사용하여 자동 배포 과정을 구현합니다.

Maven Release 플러그인

Maven이 maven을 사용합니다.-release-다음 작업을 수행하기 위해 plugin 플러그인을 사용합니다.

mvn release:clean

작업 공간을 정리하여 최신 배포 과정이 성공적으로 진행되도록 합니다.

mvn release:rollback

이전 배포 과정이 실패하면, 배포 과정이 성공적으로 진행되도록 작업 공간 코드와 설정을 롤백합니다.

mvn release:prepare

다양한 작업을 수행합니다:

  • 로컬에 아직 반영되지 않은 변경 사항이 있는지 확인합니다.

  • 스냅샷 의존성이 없는지 확인합니다.

  • 배포를 위해 애플리케이션의 버전 정보를 변경합니다.

  • POM 파일을 SVN에 업데이트합니다.

  • 테스트 케이스를 실행합니다.

  • 수정된 POM 파일을 반영합니다.

  • SVN에서 코드에 표시를 합니다.

  • 버전 번호를 추가하고 미래 배포를 위해 스냅샷을 추가합니다.

  • 수정된 POM 파일을 SVN에 반영합니다.

mvn release:perform

코드를 이전에 표시한 위치로 전환한 후 Maven 배포 목표를 실행하여 WAR 파일을 배포하거나 저장소에 필요한 구조를 빌드합니다.

명령 프롬프트를 엽니다. C:\ > MVN > bus-core-api 디렉토리 아래로 이동한 후 다음과 같은 mvn 명령어를 실행합니다.

C:\MVN\bus-core-api>mvn release:prepare

Maven이 전체 프로젝트를 빌드 시작합니다. 빌드가 성공적으로 완료되면 다음 mvn 명령어를 실행할 수 있습니다.

C:\MVN\bus-core-api>mvn release:perform

빌드가 성공적으로 완료되면, 저장소에 업로드한 JAR 파일이 유효한지 확인할 수 있습니다.