Maven通俗講解

Maven通俗講解

    也許是本人不才,初識Maven時,被各種不明所以的教程搞得一頭霧水,而在後來的使用中,我發現Maven大部分功能沒有想象的那麼困難。

    本片文章面向Maven初學者,希望能讓其以最快的速度瞭解Maven並享受到它所帶來的一系列好處。

[一個簡單的問題]

    在進行講解前,先提問一個簡單的問題。
    假如你正在Eclipse下開發兩個Java項目,姑且把它們稱爲A、B,其中A項目中的一些功能依賴於B項目中的某些類,那麼如何維繫這種依賴關係的呢?
    筆者在使用Maven前是這樣做的,將B項目打包爲jar,並在A項目的Library下導入B的jar文件。
    這樣做有着很明顯的缺點:
        1.如果在開發過程中,發現B中的bug,則必須重新將B打包並對A項目進行重編譯操作
        2.在協同開發A項目時,爲了保證其能夠正常運行,要麼選擇將B打包入A中,要麼選擇將B一樣發佈出去並告知開發者使用方法。顯然這兩個方法都不太好,前者可能造成資源浪費(比如開發者可能正在開發依賴B的其它項目,B已經存儲到本地了),而後者則會爲項目正常運行帶來風險(一旦把工作交給人工註定會帶來一定的失敗率)。
    因此,這樣手動的控制項目間依賴關係顯然是一種‘拙劣’的方法。

[Maven介紹]

    依據筆者看來,Maven的核心功能便是合理敘述項目間的依賴關係。
    所有的Maven項目包含着一個名爲pom.xml的文件,在文件中記錄着自己的<groupId><artifactId><version>等字段,這些字段在創建Maven項目時填寫,Maven會依據它們來定位到該項目。

    在pom中的另一個關鍵標籤是<dependencies>,該標籤下可以包含若干個<dependency>標籤,而<dependency>下則是上面介紹的<groupId><artifactId><version>等依賴字段,它們確定着一個唯一的項目版本。

一個典型的pom.xml[來自項目luajava]:

<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>org.keplerproject</groupId>
	<artifactId>luajava</artifactId>
	<version>1.1</version>
	<packaging>jar</packaging>

	<name>luajava</name>
	<url>http://maven.apache.org</url>

	<properties>
		<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
	</properties>
	<build>
		<plugins>
			<plugin>
				<groupId>org.apache.maven.plugins</groupId>
				<artifactId>maven-compiler-plugin</artifactId>
				<version>2.0.2</version>
				<configuration>
					<source>1.7</source>
					<target>1.7</target>
				</configuration>
			</plugin>
		</plugins>
	</build>
	<dependencies>
		<dependency>
			<groupId>junit</groupId>
			<artifactId>junit</artifactId>
			<version>3.8.1</version>
			<scope>test</scope>
		</dependency>
	</dependencies>
</project>


[Maven庫]

    以剛纔的A、B項目爲例,在A項目的pom文件中寫入<dependency>關聯B項目,Maven會在工作區中找到B項目,並創建依賴。此時A項目可以直接訪問到B項目中的類資源,而且對A調試時依然會擊中B項目中設置的斷點。
    除去工作區的依賴關聯外,Maven也可以關聯一個遠端鏡像中的項目,在默認情況下,如果工作區中沒有對應的項目記錄,Maven會連接到中心倉庫查找,如果找到,它會把項目下載到本地庫中(Windows中本地庫位於用戶文檔的.m2目錄下),並自動設置關聯。這是一個十分便利的特性,在我們需要額外jar包支持時,不再需要進行手動的下載和引入,我們僅需要將需要項目對應的依賴字段粘貼到pom的合適位置,剩下的交給Maven完成即可。

[一個例子]

    那麼,我們如何知道所需項目的groupId等字段呢?
    一般而言,如果官方項目支持Maven,在其頁面一般會有一段依賴字段以供複製,但也確實存在支持Maven但沒有給出依賴字段的情況。而另一些項目的Maven特性由第三方維護,此時從官方渠道獲得對Maven的支持比較困難。
    因此,查詢依賴字段首選的方案,是使用Maven搜索服務進行搜索。
    這裏筆者推薦一個地址:mvnrepository.com
    下面以使用Eclipse關聯MySqlJDBC驅動爲例子,在此之前,請在Help->About Eclipse中確認其支持Maven:
    
    在Eclipse官方新版本中,已經內置有對Maven的支持,如果版本比較舊可以去安裝Maven插件。

    我們先來新建一個Maven項目,New ->Project ->Maven Project->Create a simple project (skip archetype selection).

    下面是這步比較重要,填寫這個項目的GroupId等依賴字段,這裏填寫的字段會在其它項目對其依賴時用到,未填寫的部分都爲選填內容:

    

    之後,我們去mvnrepository.com搜索"MySql JDBC"
    

    很快,我們找到了結果,點擊進入查看詳細的版本信息:

    

    這裏列出了MySql JDBC的多個版本及使用情況,這裏我們選擇一個第二新的版本5.1.34:
    

    複製Maven框中的內容,把它們寫到pom的<dependencies>下:
    
<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.test</groupId>
	<artifactId>maventest</artifactId>
	<version>0.0.1-SNAPSHOT</version>
	<dependencies>
		<dependency>
			<groupId>mysql</groupId>
			<artifactId>mysql-connector-java</artifactId>
			<version>5.1.34</version>
		</dependency>
	</dependencies>
</project>


    在Progress讀條結束後,可以看到項目中多出Maven Dependencies,裏面可以找到我們剛剛引入的jdbc驅動包:

    

    此時已經可以在開發中正常使用jdbc了。

[其它特性]

    1.鏡像源
很明顯,Maven中心倉庫負載比較大,而且不在國內,因此速度非常慢,有時甚至會找不到依賴。因此,尤其是在小規模團隊開發這種場合下,搭建一個Maven私服會極大的提升效率。這裏推薦一個Maven鏡像搭建工具:Nexus:http://www.sonatype.org/nexus/
使用它可以很快速方便的搭建私有Maven鏡像源,之後在Maven的settings.xml裏進行配置即可。
    2.惰性下載src源碼
在一些時候,我們需要參閱依賴項目的源文件,此時可以嘗試直接雙擊class文件,如果Maven鏡像源中存在源文件,會自動下載到本地,eclipse會自動加載並顯示。
    3.編譯參數配置
筆者使用Eclipse Luna版,Maven默認的Java編譯版本爲1.5,我們可以在pom指定其編譯版本,使其提升至1.7(參考luajava pom中的build標籤);此外這些設置也會被諸如jenkins持續集成等自動化工具讀取並進行恰當配置。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章