設置MAVEN_OPTS環境變量
- 執行mvn命令會調用bin下面的腳本,而這些腳本實際是操作java命令。既然是運行java命令,那么運行java命令可用的參數當然也能夠在運行mvn命令時使用,比如-D就是java參數,當然還有-Xms 等。
- 如果想在執行mvn時為java命令設置參數就可以把參數設置的MAVEN_OPTS環境變量中,通常需要設置MAVEN_OPTS的值為-Xms128m -Xmx521m,因為java默認的最大可用內存往往不能夠滿足Maven運行的需求,比如在項目較大時,使用maven生成項目站點需要占用大量內存,沒有該配置,容易得到java.lang.OutOfMemeoryError,所以推薦為MAVEN_OPTS配置該值。
目錄分析
在安裝好maven后,進入maven解壓目錄,我的maven目錄如下:
文件分析
-
bin: 該目錄存放了mvn運行腳本。 在命令行中輸入任何一條mvn命令時,實際上就是調用這些腳本。
bin目錄下文件 -
boot: 該目錄只存放一個文件plexus-classworlds-2.5.2.jar
boot目錄中的文件- plexus-classworlds是一個類加載器框架,相對于默認的java類加載器,它提供了更豐富的語法以方便配置,Maven使用該框架加載自己的類庫。classworlds更多信息
-
conf:目錄包喊了maven的配置文件
conf目錄中的文件- settings.xml:很重要配置文件,直接修改該文件就能在機器上全局的定制Maven行為,一般更偏向于將文件復制到/.m2/目錄下(表示用戶目錄),然后修改該文件,在用戶范圍定制Maven的行為。
-
lib:該目錄包含了所有Maven運行時需要的Java類庫,plexus-classworlds類加載器會從該文件夾下加載類到內存中。Maven本身是分模塊開發的,因此用戶能看到諸如maven-core-3.3.3.jar、maven-model-3.3.3.jar等。
lib目錄中文件一部分- 其中超級POM文件在包maven-model-builder-3.3.3.jar中的org/apache/maven/model/pom-4.0.0.xml路徑下。對于maven2超級POM在lib/maven-x.x.x-uber.jar中的org/apache/maven/project/pom-4.0.0.xml目錄下。
- LICENSE記錄了Maven使用軟件許可證Apache License Version2.0
- NOTICE記錄了Maven包含的第三方軟件
- READAME.txt則包含了Maven的簡介,包括安裝需求、如何安裝的簡要指令等。
配置本地倉庫
默認位置
- 在使用maven開發過程中下載的依賴包都會存放的本地maven倉庫中,maven的默認倉庫位置為:${user.home}/.m2/repository。一般user.home為C盤下的用戶文件夾。
在setting.xml文件的默認配置如下:
<!-- localRepository
| The path to the local repository maven will use to store artifacts.
|
| Default: ${user.home}/.m2/repository
-->
需求位置
- 改變倉庫位置,由于倉庫內容會變多,我們一般不會設置在C盤,我想設置D:\Soft\maven\maven_jar\repository為maven倉庫。
操作
- 方案1(推薦):新建D:\Soft\maven\maven_jar\repository目錄,然后修改${user.home}/.m2/repository目錄下的setting.xml文件,沒有的話從maven的/config/setting.xml目錄下拷貝過去。我的用戶名為liang,則本地倉庫地址為C:\Users\liang.m2\repository\,而Linux上的本地倉庫地址為home/liang/.m2/repository/注意Liunx中以點(.)開頭的文件或目錄默認隱藏的,可以使用ls-a命令查看。
修改setting.xml如下:
<!-- localRepository
| The path to the local repository maven will use to store artifacts.
|
| Default: ${user.home}/.m2/repository
-->
<localRepository>D:\Soft\maven\maven_jar\repository</localRepository>
- 方案2(針對eclipse設置maven配置文件):新建D:\Soft\maven\maven_jar\repository目錄,將setting.xml文件拷貝一份到目錄下。然后修改該目錄下的setting.xml文件,修改如下:
<!-- localRepository
| The path to the local repository maven will use to store artifacts.
|
| Default: ${user.home}/.m2/repository
-->
<localRepository>D:\Soft\maven\maven_jar\repository</localRepository>
此時執行mvn命令如果有依賴要下載還會下載到${user.home}/.m2/repository目錄下,因為執行的命令時參考的setting.xml文件依然是原來的setting.xml文件而不是D:\Soft\maven\maven_jar\repository下的。
這個操作可以在eclipse中使用maven時,將setting.xml配置文件替換成D:\Soft\maven\maven_jar\repository下載setting.xml。
- 方案3:新建D:\Soft\maven\maven_jar\repository目錄,然后修改maven/config目錄下的setting.xml文件,修改如下:
<!-- localRepository
| The path to the local repository maven will use to store artifacts.
|
| Default: ${user.home}/.m2/repository
-->
<localRepository>D:\Soft\maven\maven_jar\repository</localRepository>
設置HTTP代理
需求
- 公司出于安全考慮,要求使用通過安全認證的代理訪問因特網,這時就需要maven配置http代理,才能正常訪問外部倉庫。
操作
首先確認自己無法直接訪問公共的maven中央倉庫,運行ping repol.maven.org可以檢查網絡,在檢查代理服務器是否暢通,比如現在有一個IP地址為218.14.227.197端口為3128的代理服務器,我們可以運行telnet 218.14.227.197 3128來檢測改地址的該端口是否通暢。出錯則獲取正確的代理信息,如果telnet連接正確,則輸入ctrl+],然后q,回車,退出即可。
設置setting.xml文件,如果不想設置全局的,可以將setting.xml復制到~/.m2/settings.xml。
添加代理如下:
<!-- proxies
| This is a list of proxies which can be used on this machine to connect to the network.
| Unless otherwise specified (by system property or command-line switch), the first proxy
| specification in this list marked as active will be used.
|-->
<proxies>
<!-- proxy
| Specification for one proxy, to be used in connecting to the network.
-->
<proxy>
<id>my-proxy</id>
<active>true</active>
<protocol>http</protocol>
<host>218.14.227.197</host>
<port>3128</port>
<!--
<username>proxyuser</username>
<password>proxypass</password>
<nonProxyHosts>local.net|some.host.com|*.google.com</nonProxyHosts>
-->
</proxy>
<!--<proxy>
<id>optional</id>
<active>true</active>
<protocol>http</protocol>
<username>proxyuser</username>
<password>proxypass</password>
<host>proxy.host.net</host>
<port>80</port>
<nonProxyHosts>local.net|some.host.com</nonProxyHosts>
</proxy>
-->
</proxies>
- 解釋
聲明一個id為my-proxy的代理,active為true表示激活該代理,protocol代表使用的代理協議,這里是http。host主機名(可填ip或域名),port端口。當代理需要服務器需要認證時就要配置username和password。nonProxyHost元素用來指定哪些主機名不需要dialing,可以用"|"符號分隔多個主機名。此外支持通配符,如*.google.com表示所有以google.com結尾的域名訪問都不要通過代理。