前言css
但凡一個略有規模的項目都須要一個持續集成環境的支撐,爲何須要持續集成環境,咱們來看一個例子。假如一個項目,由A、B兩位程序員來協做開發,A負責前端模塊,B負責後端模塊,前端依賴後端。A和B都習慣使用SVN做爲代碼管理工具,他們分別開始工做,一個功能完成後會提交到SVN,以便對方可以使用。一天B告訴A,個人某個功能完成了,提交到SVN,你更新下來試一下。A便從SVN更新下來代碼,結果一試,我檫報錯,因而告訴B你的代碼有問題,B檢查了一下確實有問題,而後B通過1個小時修改後,從新上傳到SVN,A更新下來可使用了。又過了幾個小時,A發現B的代碼仍然有問題,B檢查了半天,沒找到問題所在,後來開發組長檢查他們的代碼發現是兩我的使用不一樣版本的jar包致使的,這個問題確認難以發現,A把jar包的版本弄得和B同樣,A和B又開始繼續工做。終於有一天項目完成了,須要發佈程序,這時A從本身的開發環境上編譯一個版本,把他上傳到服務器上,程序運行的前幾天比較穩定,後來A有點急事請假了,但服務器上的程序這時好像出現了問題,這時B只能使用本身的電腦調試、解決問題並試着發一個版本,但由於他平時作後端,對版本發佈不是很熟悉,又搞了半天終於弄好了。項目上線了,穩定運行了半年,後來A、B前後離職了,新來的C負責維護這個項目,儘管A、B在離職前作了一些工做交接,但當C真正接手的時候才發現頭大,我檫竟然註釋都沒寫,有沒有這麼坑的,因爲C開始硬着頭皮看代碼,發現代碼中各類飄逸寫法,各類爲了臨時需求而打的補丁,C幾乎抓狂。html
以上的例子有點誇大,但或多或少均可能遇到過,咱們須要一種規範來約束這個開發過程,使開發過程嚴格有序的進行。前端
從問題出發java
就以上面這個例子,咱們看其中暴露出了哪些問題:linux
一、團隊彼此協做不流暢,出現彼此阻塞的狀況;程序員
二、使用的類庫版本不統一,形成難以估計的風險;web
三、代碼未經嚴格測試就上傳,形成不斷的返工;spring
四、版本發佈規範欠缺,版本質量不能保證;apache
五、代碼質量低,其餘人難以接手。windows
團隊開發時,咱們經常約定好彼此之間的接口規範,而後開始各自開發,開發完成後,按照接口規範對接起來,這是一個理想的流程,但現實每每不那麼順利,問題經常在於,接口規範可能根據需求變化而常常變動,並且在實際對接時常常發現諸多問題。咱們沒法經過工具來解決這些問題,只能要求開發人員在制定接口規範時,爲可能變動的需求多一些擴展,在開發時多考慮諸多素質,儘可能將減小對接過程當中的問題。下面將講述如何使用Maven和Nexus保證開發人員引用統一的類庫版本,以及如何將本身開發的模塊上傳至Nexus服務器,以提供給其餘模塊引用。
關於Maven和Nexus的搭建在Maven實戰(Maven+Nexus創建私服【Linux系統】)中已經介紹過,在此介紹下主要步驟:
一、下載maven(讀:妹吻)和nexus(讀:耐克色兒絲):
http://maven.apache.org/download.cgi
http://nexus.sonatype.org/downloads/
二、將下載的nexus放置到linux服務器解壓並啓動:
選擇本身的系統並進入:
啓動nexus
./nexus start
nexus啓動成功,訪問:http://192.168.6.204:8081/nexus/
三、將下載的maven解壓放置在開發機上(windows),並配置conf目錄下的setting.xml文件:
(1)在<settings><profiles></profiles></settings>節點之間添加配置:
接着在<settings></settings>節點之間添加配置:
以上配置好了鏈接Nexus私服。
(2)安裝eclipse的m2eclipse插件,並配置maven。
m2eclipse的安裝地址:http://m2eclipse.sonatype.org/sites/m2e(安裝過程略)
安裝完成後配置maven:
配置eclipse的maven爲本地下載的maven地址。主要爲了方便配置和版本管理。
至此,nexus和maven就搭建配置完成了,下面咱們要利用這個環境解決兩個問題:
一、不一樣的模塊項目都使用統一的類庫版本;如spring都使用3.1.2.RELEASE,log4j都使用1.2.17。這樣避免由於jar包版本的不一樣,引起的諸多問題。
二、模塊開發完畢後,將編譯的庫文件發佈到nexus私服上,以便其餘模塊引用。
這裏說一下maven的一個特性,繼承。簡單來講繼承就是先創建一個父項目,其餘項目若是繼承這個父項目,就能夠繼承這個項目定義的庫文件及版本。利用這個特性,咱們可讓多個模塊都繼承一個父項目,而在父項目中定義好類庫的版本,這樣全部模塊都使用統一的類庫文件。例如:
創建名爲maven-parent的父項目,pom配置爲:
<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>com.cnblogs.leefreeman</groupId>
<artifactId>maven-parent</artifactId>
<version>0.0.1-SNAPSHOT</version>
<packaging>pom</packaging>
<properties>
<!-- junit -->
<junit.version>4.10</junit.version>
<!-- servlet -->
<servlet-api.version>2.5 </servlet-api.version>
<!-- log4j -->
<log4j.version>1.2.17 </log4j.version>
<!-- commons.codec -->
<commons.codec.version>1.7</commons.codec.version>
<!-- maven-support -->
<maven-support.version>0.0.1-SNAPSHOT</maven-support.version>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
</properties>
<dependencyManagement>
<dependencies>
<!-- junit -->
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>${junit.version}</version>
<scope>test</scope>
</dependency>
<!-- log4j -->
<dependency>
<groupId>log4j</groupId>
<artifactId>log4j</artifactId>
<version>${log4j.version}</version>
</dependency>
<!-- commons包 -->
<dependency>
<groupId>commons-codec</groupId>
<artifactId>commons-codec</artifactId>
<version>${commons.codec.version}</version>
</dependency>
<!-- servlet -->
<dependency>
<groupId>javax.servlet</groupId>
<artifactId>servlet-api</artifactId>
<version>${servlet-api.version}</version>
<scope>provided</scope>
</dependency>
</dependencies>
</dependencyManagement>
</project>
這個pom定義了一些類庫以及它的版本。
而後再創建模塊項目:maven-sample(web項目)、maven-support(支撐模塊,包括一些工具類以及業務封裝,提供給maven-sample引用)。
maven-sample的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/maven-v4_0_0.xsd">
<modelVersion>4.0.0</modelVersion>
<parent>
<groupId>com.cnblogs.leefreeman</groupId>
<artifactId>maven-parent</artifactId>
<version>0.0.1-SNAPSHOT</version>
</parent>
<artifactId>maven-sample</artifactId>
<packaging>war</packaging>
<dependencies>
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
</dependency>
<dependency>
<groupId>log4j</groupId>
<artifactId>log4j</artifactId>
</dependency>
<dependency>
<groupId>commons-codec</groupId>
<artifactId>commons-codec</artifactId>
</dependency>
<dependency>
<groupId>javax.servlet</groupId>
<artifactId>servlet-api</artifactId>
</dependency>
</dependencies>
<build>
<finalName>maven-sample</finalName>
</build>
</project>
maven-support的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>
<parent>
<groupId>com.cnblogs.leefreeman</groupId>
<artifactId>maven-parent</artifactId>
<version>0.0.1-SNAPSHOT</version>
</parent>
<artifactId>maven-support</artifactId>
<packaging>jar</packaging>
<dependencies>
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
</dependency>
<dependency>
<groupId>log4j</groupId>
<artifactId>log4j</artifactId>
</dependency>
<dependency>
<groupId>commons-codec</groupId>
<artifactId>commons-codec</artifactId>
</dependency>
</dependencies>
</project>
經過以上配置,maven-sample和maven-support引用的jar包,都會使用相同的版本:
接下來咱們解決協做開發的問題,maven-support開發完畢以後,將之發佈到nexus服務器,以便maven-sample能夠引用。咱們須要3步:
一、本地maven的conf目錄下的setting.xml,在<servers></servers>節點之間添加:
二、在maven-support項目的pom.xml中,<project></project>節點之間添加:
<!-- 構件部署倉庫 -->
<distributionManagement>
<repository>
<id>releases</id>
<name>發佈版本倉庫</name>
<url>http://192.168.0.109:8081/nexus/content/repositories/releases/</url>
</repository>
<snapshotRepository>
<id>snapshots</id>
<name>快照版本倉庫</name>
<url>http://192.168.0.109:8081/nexus/content/repositories/snapshots/</url>
</snapshotRepository>
</distributionManagement>
三、對maven-support項目進行編譯,並執行發佈命令:
能夠看到maven-support已經成功發佈到nexus私服中:
這樣maven-sample就能夠引用maven-support模塊,而開發maven-support的人則能夠繼續開發,持續發佈新版本。
小結
本文主要介紹maven和nexus的環境搭建,以及怎麼使用maven和nexus統一管理庫文件和版本,怎麼講本身的模塊上傳至nexus私服,供其餘模塊引用。這樣咱們基本解決了兩個問題:
一、團隊彼此協做不流暢,出現彼此阻塞的狀況;
二、使用的類庫版本不統一,形成難以估計的風險;
下一篇將使用jenkins、svn、tomcat以及sonar解決自動化測試、自動化版本發佈、代碼質量檢查等問題。