新項目開發的通常做法:項目經理從團隊抽調1名開發人員進行項目工程框架的搭建,剩余的開發人員先研究項目需求,并著手準備業務邏輯的設計。本地項目工程搭建后,上傳SVN或git配置庫,告知其他開發人員可以下載項目工程,啟動開發了。開發運維人員便進行代碼的編寫、編譯、測試以及打包等系列操作。我們將這一系列的操作稱為“構建”。
構建的實質是將我們編寫的Java源文件、XML配置文件、HTML頁面、CSS和JS文件等,通過某種方式組合在一起,變為可對外服務項目的過程。同時,構建過程中很多都是沒有技術含量且重復的工作,手工操作很無趣且太麻煩。最好能夠由手工模式轉變為自動化模式,這樣可以大大節省時間。
構建的工具主要有:
(1). Make;
(2). Ant(Another Neat Tool):另一個整潔的工具;
(3). Maven;
(4). Gradle;
本文將介紹在SDN控制器OpenDaylight中使用的Maven工具。
一、Maven
Maven是Apache組織中一個開源項目,主要用于基于Java平臺的項目構建、依賴管理和項目信息管理。下面來看下其幾個核心概念:
1.坐標
坐標用于唯一標識構件(如jar,war等),坐標的元素包括groupId、artificatId、version、packaging、classifier,其中前3個是必須定義的,后2個是可選的。
①groupId:定義當前Maven項目隸屬的實際項目。
②artificatId:定義實際項目中的一個Maven項目(模塊),建議使用實際項目名稱作為其前綴。
③version:定義Maven項目當前所處的版本。
④packaging:定義Maven項目的打包方式。
⑤classifier:幫助構建輸出的一些附屬構件。
2.生命周期
如前所述,軟件人員每天的工作:項目的清理、初始化、編譯、測試、打包、集成測試、驗證、部署和站點生成等等,Maven對這些工作統一抽象為三個相互獨立的生命周期:clean、default和Site。其中,default生命周期的目的是構建項目,而site生命周期的目的是建立項目站點。下面詳細說明每種生命周期:
(1).clean生命周期的目的是清理項目,包含三個階段:
①pre-clean執行一些清理前需要完成的工作;
②clean清理上一次構建生成的文件;
③post-clean執行一些清理后需要完成的工作。
(2).default生命周期的目的是構建項目,定義構建時所需要執行的所有步驟:
其中重要階段的解釋如下:
(3). pre-site的目的是建立項目站點,包含3個階段:
①site生成項目站點文檔;
②post-site執行一些在生成項目站點之后需要完成的工作;
③site-deploy將生成的項目站點發布到服務器上。
需要說明的是,從命令行執行maven任務實質上就是調用Maven的生命周期階段。例如執行命令mvn clean install,則調用clean生命周期的clean階段和default生命周期的install階段,而實際上執行的階段為clean生命周期的pre-clean、clean階段,以及default生命周期的從validate至install的所有階段。
3.插件
在Maven的生命周期中對軟件人員的工作進行了抽象,相當于做一個模板,具體的實現則由插件來完成。下面列出default生命周期的內置插件綁定關系及具體任務:
更加詳細的內容可以參考Apache Maven官網:
http://maven.apache.org/guides/introduction/introduction-to-the-lifecycle.html
4.倉庫
Maven通過倉庫來統一管理文件,同時,為了實現重用,項目構建后生成的構件也安裝或部署到倉庫中。Maven倉庫的分為本地倉庫和遠程倉庫,而遠程倉庫又包含中央倉庫、私服和其他公共庫。初始狀態下,本地倉庫是不存在的,當用戶執行Maven命令后,則創建本地倉庫,并根據實際需要,從遠程倉庫下載構件至本地倉庫。
(1).本地倉庫:一般來說,在Maven項目目錄下,沒有諸如lib這樣用來存放依賴文件的目錄。當Maven在執行編譯或測試時,如果需要依賴文件,它總是基于坐標使用本地倉庫的依賴文件。通過setting.xml文件標識:
D:/repository/
(2).遠程倉庫:相對本地倉庫而言;
(3).中央倉庫:是一個默認的遠程倉庫;包含了大部分的開源JAVA構件以及源碼等信息。Maven的安裝文件自帶了中央倉庫的配置。在Maven的安裝目錄下:$MAVEN_HOME\\lib\\maven-model-builder-3.3.9.jar
central為中央倉庫的唯一標識。
(4).私服:是一種特殊的遠程倉庫,架設在公司內部。當下載構件時,從私服下載,如果私服不存在,則私服請求提供服務。
5.Archetype
意為“原型”,可以理解為Maven項目的模板,以便用戶可以快速創建項目,同時針對同類項目保持相同的項目結構及配置約定。Archetype是通過maven-archetype-plugin插件實現,官網鏈接:
http://maven.apache.org/archetype/maven-archetype-plugin/
三、Maven在OpenDaylight的使用
OpenDaylight使用Maven工具進行項目構建和依賴管理,并在構建簡單的簡易APP開發一文中對Maven的基礎進行介紹,鏈接如下:
https://docs.opendaylight.org/en/latest/developer-guide/developing-apps-on-the-opendaylight-controller.html
1. 修改settings.xml
為了從遠程倉庫下載OpenDaylight版本的依賴包,首先需要修改maven的settings.xml,并指定遠程倉庫的地址。事實上,OpenDaylight提供了預先寫好的settings.xml文件,其下載地址為:
https://github.com/opendaylight/odlparent/blob/stable/carbon/settings.xml
https://raw.githubusercontent.com/opendaylight/odlparent/master/settings.xml
具體內容解釋如下:
Maven安裝以后,setting.xml文件存在兩個地方:
①USR_HOME/.m2/settings.xml,表示當前用戶范圍的配置文件;
②MAVEN_HOME/conf/settings.xml,表示全局范圍配置文件,修改后將影響本機所有的用戶配置。
詳細的setting文件說明參見鏈接:
https://maven.apache.org/settings.html。
2. 選擇Archetype
Archetype是一個Maven項目模板工具包,使用Archetype來生成項目骨架,可以使得開發人員在開發新的應用程序時,使用與OpenDaylight風格一致的最佳實踐方法。
OpenDaylight應用創建的Archetype可通過如下鏈接查詢:
https://nexus.opendaylight.org/#nexus-search;gav~org.opendaylight.archetypes~~~~
執行命令:
通過交互構建hello示例應用,生成的文件視圖大致為:
-
JAVA
+關注
關注
19文章
2972瀏覽量
104861 -
XML
+關注
關注
0文章
188瀏覽量
33104 -
HTML
+關注
關注
0文章
278瀏覽量
35844
發布評論請先 登錄
相關推薦
評論