idea中使用maven?archetype新建項(xiàng)目時(shí)卡住問題解決方案
背景
作為一個(gè)后端Java打工人,idea就是最重要的打飯工具。創(chuàng)建項(xiàng)目,熟悉吧,但是,這么多年下來,因?yàn)閕dea換了版本,電腦換了等等,我還是時(shí)不時(shí)遇到根據(jù)maven archetype新建maven項(xiàng)目卡住。沒錯(cuò),我說的就是下面這樣的場景:


總之吧,就是停在上面這里,不動(dòng)了:
[INFO] --- maven-archetype-plugin:3.2.1:generate (default-cli) @ standalone-pom ---
[INFO] Generating project in Batch mode
以前都是網(wǎng)上隨便找個(gè)文章搞一搞,或者有時(shí)候多等一會(huì),解決了也就不管了,直到下次因?yàn)閾Q電腦、重裝idea等等,又不行了。我也奇怪,你拿 Generating project in Batch mode 去網(wǎng)上一搜,出來的解決辦法還各不相同。
這次我決定好好探究下,了解下內(nèi)部原理,知其然,也要知其所以然,把這個(gè)小問題搞清楚。
打開debug級別參數(shù),查看阻塞原因
首先,點(diǎn)這里,可以看到完整命令:

基本就是:
"C:\Program Files\Java\jdk1.8.0_202\bin\java.exe"
-Dmaven.home=F:\tools\apache-maven-3.8.1-bin\apache-maven-3.8.1
--errors
-DgroupId=org.example
-DartifactId=test8
-Dversion=1.0-SNAPSHOT-DarchetypeGroupId=org.apache.maven.archetypes
-DarchetypeArtifactId=maven-archetype-quickstart
-DarchetypeVersion=1.4-DarchetypeRepository=F:/maven/repository
org.apache.maven.plugins:maven-archetype-plugin:RELEASE:generate
可以看下上面的命令,我已經(jīng)去除了不重要的參數(shù),剩下的分幾個(gè)部分:
- maven home目錄
- 日志級別,目前是-errors,不會(huì)打印太詳細(xì)的日志
- -DgroupId/-DartifactId/-Dversion 我們要生成的業(yè)務(wù)module的坐標(biāo)
- -DarchetypeGroupId/-DarchetypeArtifactId/-DarchetypeVersion module模版/原型的坐標(biāo)
- -DarchetypeRepository module模版/原型的本地倉庫位置
- org.apache.maven.plugins:maven-archetype-plugin:RELEASE:generate 丟給maven的執(zhí)行參數(shù),表示要執(zhí)行的插件及目標(biāo)
上面這里,日志級別是比較高的,我們需要調(diào)低,怎么調(diào)呢,通過idea的settings即可:

打開debug級別后,再次運(yùn)行,命令里就會(huì)多出一個(gè): --debug 參數(shù),而運(yùn)行時(shí)就會(huì)出現(xiàn)如下日志:

日志顯示正在獲取某個(gè)xml文件。
這個(gè)文件的url已經(jīng)給出來了,網(wǎng)上都是說,文件特別大,可以自己瀏覽器下載下來,放到某個(gè)位置,然后再改個(gè)參數(shù) -DarchetypeCatalog=local ,后續(xù)讓maven都從這個(gè)位置去讀即可。
我看了下,這個(gè)文件確實(shí)大,14M左右,而且是從maven官方倉庫那小水管下載,確實(shí)要卡很久,文件是干啥的呢,catalog表示目錄,合起來意思就是項(xiàng)目模版的目錄,比如我們常用的quickstart,只是其中的一個(gè):
-DarchetypeGroupId=org.apache.maven.archetypes
-DarchetypeArtifactId=maven-archetype-quickstart
-DarchetypeVersion=1.4
文件內(nèi)容大概如下,整個(gè)文件包含了5w多個(gè)模板,這么多,能不慢嗎:


一個(gè)疑問
按照網(wǎng)上的方案,我把文件下載下來了,但我還不知道把文件放到哪里去。
我想著,我先把參數(shù) -DarchetypeCatalog=local 改了,看看debug日志,在local參數(shù)情況下,是去哪里獲取這個(gè)文件:

然后,注意啊,敲黑板了!rerun的話,這個(gè)參數(shù)是不生效的,必須新建project或module,這個(gè)參數(shù)才會(huì)生效,也就是說,之前建的都沒效果,僅對新project、module生效。

此時(shí),如下,它會(huì)去本地倉庫的根目錄下查找這個(gè)目錄文件:

ok,知道去哪里放這個(gè)目錄文件了,問題是,我還沒放呢,但它這次執(zhí)行為啥就成功了呢?

雖然成功了,但是給我整得有點(diǎn)迷茫,不知道怎么就成功了。我以為是idea有什么緩存,我還重啟了幾次idea,后來發(fā)現(xiàn)應(yīng)該就是這樣設(shè)計(jì)的:
加了-DarchetypeCatalog=local的情況下,會(huì)在本地的本地倉庫下找 archetype-catalog.xml 。但我們沒放,所以找不到。找不到的話,它也就放棄了,會(huì)直接去maven中央倉庫拉取這個(gè)指定模版的jar下來。
[DEBUG] Getting archetypes from catalog: F:\maven\repository\archetype-catalog.xml
// 下面這行,意思是容錯(cuò)處理,去中央倉庫拉取
[WARNING] Archetype not found in any catalog. Falling back to central repository.
拉取下來的模版/原型的內(nèi)容
我們前面提到,模版的坐標(biāo)為:
-DarchetypeGroupId=org.apache.maven.archetypes
-DarchetypeArtifactId=maven-archetype-quickstart
-DarchetypeVersion=1.4
拉取下來后,我們看看其內(nèi)容:

jar包解壓后,發(fā)現(xiàn)很眼熟,就是我們模板項(xiàng)目的內(nèi)容:

打開其中兩個(gè)文件查看,發(fā)現(xiàn)還有不少占位符:


下面這個(gè)App.java的$package占位符,我們在命令里沒有顯式傳遞,是maven獲取了 -DgroupId=com.example 的值作為其默認(rèn)值。
所以,解決本問題的方法,就是在maven的runner加上參數(shù)-DarchetypeCatalog=local就可以了,不需要下載xml文件再放到指定目錄。
如果我們放置的話呢,看看日志是啥樣:
[INFO] Generating project in Batch mode
[DEBUG] Getting archetypes from catalog: F:\maven\repository\archetype-catalog.xml
[INFO] Archetype repository not defined. Using the one from [org.apache.maven.archetypes:maven-archetype-quickstart:1.4] found in catalog local
了解該插件
https://maven.apache.org/archetype/maven-archetype-plugin/

我也是才知道,還可以根據(jù)現(xiàn)在已有的項(xiàng)目來生成模版,感覺還是不錯(cuò)的,后面打算研究下,畢竟公司內(nèi)項(xiàng)目一多,在項(xiàng)目間需要復(fù)用的東西就越來越多,搞個(gè)模版工程還是不錯(cuò)的。
該插件的goal:generate
我們上面使用的就是該插件的generate 目標(biāo):
https://maven.apache.org/archetype/maven-archetype-plugin/generate-mojo.html
這里就有各個(gè)參數(shù)的解釋,這也是為什么網(wǎng)上文章都讓我們這么改參數(shù)的原因:

mvn命令如何執(zhí)行該插件
mvn archetype:generate ? ?-DarchetypeGroupId=org.apache.maven.archetypes ?-DarchetypeArtifactId=maven-archetype-quickstart ?-DarchetypeVersion=1.1? ?-DgroupId=com.company ?-DartifactId=project ?-Dversion=1.0-SNAPSHOT ?-Dpackage=com.company.project ?-X --errors -DarchetypeCatalog=local
這里-X,就和表示前面idea中的debug級別日志是一樣的,具體可查看 mvn -h :
-X,--debug Produce execution debug output
另外,注意這里,指定了-Dpackage,即手動(dòng)指定了我們module的包名。
到此這篇關(guān)于idea中使用maven archetype新建項(xiàng)目時(shí)卡住的文章就介紹到這了,更多相關(guān)idea新建項(xiàng)目時(shí)卡住內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
源碼分析Spring?中?@Qualifier?注解基本用法
這篇文章主要介紹了源碼分析Spring?中?@Qualifier?注解基本用法,在源碼分析的過程中,也?GET?到?Spring?許多新的玩法,感興趣的小伙伴趕緊去試試吧2023-08-08
java實(shí)現(xiàn)String字符串處理各種類型轉(zhuǎn)換
在日常的程序開發(fā)中,經(jīng)常會(huì)涉及到不同類型之間的轉(zhuǎn)換,本文主要介紹了String字符串處理各種類型轉(zhuǎn)換,具有一定的參考價(jià)值,感興趣的可以了解一下2023-10-10
Java中的異常處理(try,catch,finally,throw,throws)
本文主要介紹了Java中的異常處理,文章主要介紹的異常處理包括5個(gè)關(guān)鍵字try,catch,finally,throw,throws,更多詳細(xì)內(nèi)容需要的朋友可以參考一下2022-06-06
Mybatis Generator最完美配置文件詳解(完整版)
今天小編給大家整理了一篇關(guān)于Mybatis Generator最完美配置文件詳解教程,非常不錯(cuò)具有參考借鑒價(jià)值,感興趣的朋友一起學(xué)習(xí)吧2016-11-11
Java中弱引用和軟引用的區(qū)別以及虛引用和強(qiáng)引用介紹
很早Java API就添加了弱引用(WeakReference)和軟引用(SoftReference),但并不是所有的程序員都熟悉這兩個(gè)概念2014-04-04
Java中使用異或運(yùn)算符實(shí)現(xiàn)加密字符串
這篇文章主要介紹了Java中使用異或運(yùn)算符實(shí)現(xiàn)加密字符串,本文直接給出實(shí)現(xiàn)代碼,以及運(yùn)算結(jié)果加密實(shí)例,需要的朋友可以參考下2015-06-06
Java IO流學(xué)習(xí)總結(jié)之文件傳輸基礎(chǔ)
這篇文章主要介紹了Java IO流學(xué)習(xí)總結(jié)之文件傳輸基礎(chǔ),文中有非常詳細(xì)的代碼示例,對正在學(xué)習(xí)java io流的小伙伴們有很好的幫助,需要的朋友可以參考下2021-04-04
servlet之ServletContext簡介_動(dòng)力節(jié)點(diǎn)Java學(xué)院整理
這篇文章主要介紹了servlet之ServletContext簡介,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-07-07

