Maven項(xiàng)目分析剔除無用jar引用的方法步驟
一、為什么要做這件事?
項(xiàng)目持續(xù)研發(fā),不停地在上面新增功能,新增特性,引入新的框架和組件,jar包依賴多并且復(fù)雜,再加上需求各種變更,有不少已經(jīng)存在的功能下線,但jar包依賴沒人管,還是放在項(xiàng)目的pom.xml文件里。項(xiàng)目持續(xù)的時間一長,經(jīng)常會出現(xiàn)項(xiàng)目打包要求內(nèi)存多,時間慢的問題,如何分析項(xiàng)目中哪些依賴是有用的,哪些可以剔除的,一方面減輕打包內(nèi)存占用多,時間慢的問題,另一方面照顧研發(fā)童鞋的強(qiáng)迫癥問題(容不得半點(diǎn)無用jar包在我的項(xiàng)目里),這事就可以提上日程了。
二、怎么做?
如果是Maven項(xiàng)目,執(zhí)行起來還是比較簡單,Maven自己提供了一個檢測工具,輸入命令即可。
在IDEA中,切換到Terminal窗口,或者用命令行打開相應(yīng)工程目錄,直接輸入
mvn dependency:analyze
查看控制臺輸出的日志,重點(diǎn)關(guān)注這兩部分:
[WARNING] Used undeclared dependencies found: [WARNING] com.fasterxml.jackson.core:jackson-annotations:jar:2.9.0:compile [WARNING] com.fasterxml.jackson.core:jackson-databind:jar:2.9.9:compile [WARNING] io.jsonwebtoken:jjwt:jar:0.9.0:compile [WARNING] org.apache.rocketmq:rocketmq-common:jar:4.5.2:compile [WARNING] org.springframework:spring-beans:jar:5.1.8.RELEASE:compile [WARNING] com.google.code.gson:gson:jar:2.8.0:compile [WARNING] org.springframework.boot:spring-boot:jar:2.1.6.RELEASE:compile [WARNING] com.fasterxml.jackson.core:jackson-core:jar:2.9.9:compile [WARNING] org.springframework:spring-core:jar:5.1.8.RELEASE:compile [WARNING] org.apache.rocketmq:rocketmq-remoting:jar:4.5.2:compile [WARNING] Unused declared dependencies found: [WARNING] org.projectlombok:lombok:jar:1.16.20:provided [WARNING] org.springframework.boot:spring-boot-starter-test:jar:2.1.6.RELEASE:test
Used undeclared dependencies found
間接依賴,就是說你在當(dāng)前項(xiàng)目工程的pom.xml里沒有直接聲明,這個依賴是由你聲明過的dependency里的pom.xml依賴傳遞得來的。
例如org.apache.rocketmq:rocketmq-common:jar:4.5.2:compile是你引用了這個:
<dependency> <groupId>org.apache.rocketmq</groupId> <artifactId>rocketmq-client</artifactId> <version>4.5.2</version> </dependency>
Maven本來就是這樣用的,也不建議說你把這部分引用拷貝到你的pom.xml里,一般來說這部分的WARNING可以忽略。
Unused declared dependencies found
無用依賴,這個指我們在pom.xml聲明了這個jar包的依賴,但在項(xiàng)目工程里沒有使用到,這個不是我們此次關(guān)注的重點(diǎn),確定不需要,就可以剔除掉這個依賴,Reimport后這個jar包就從我們項(xiàng)目中剔掉了。
三、什么時候做?
1)新項(xiàng)目建立時,引用jar包時要慎重,不要一股腦兒直接拷貝老項(xiàng)目的依賴,避免后期又花時間來剔除。
2)功能代碼重構(gòu)時,可以適當(dāng)做一次剔除,因?yàn)楹竺孢€有自測,提交測試環(huán)節(jié),如果有誤刪,測試的時候能發(fā)現(xiàn)。
四、有什么風(fēng)險(xiǎn)要注意的?
1)這個檢測的結(jié)果僅供參考,有時也不準(zhǔn)確,如上文提及的org.projectlombok:lombok:jar:1.16.20:provided,實(shí)際上在項(xiàng)目中有使用到它的注解@Data,這個屬于誤判。要注意剔除依賴后多測試,工具畢竟有畢竟的缺陷性。
2)如果童鞋們接手遺留的老項(xiàng)目時,這種問題肯定很多,但剛接手時不建議做這個操作,因?yàn)楸旧韺?xiàng)目不熟悉,上來就刪東西導(dǎo)致問題會浪費(fèi)很多時間和精力搞定依賴的問題,這塊東西建議暫時先不要動。
五、補(bǔ)充一個小插件
查看pom.xml的依賴關(guān)系時,可以在IDEA上安裝maven help插件,可以直觀地看到各jar依賴關(guān)系
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
mybatis-plus配置攔截器實(shí)現(xiàn)sql完整打印的代碼設(shè)計(jì)
在使用mybatis-plus(mybatis)的時候,往往需要打印完整的sql語句,然而輸出的日志不是很理想,因?yàn)閟ql語句中的關(guān)鍵字段信息都是用?來代替的,所以本文分享了一下自己寫了一個攔截器實(shí)現(xiàn)了sql完整的打印,需要的朋友可以參考下2024-06-06解決zuulGateway網(wǎng)關(guān)添加路由異常熔斷問題
這篇文章主要介紹了解決zuulGateway網(wǎng)關(guān)添加路由異常熔斷問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-10-10啟動異常invalid constant type:15的解決方案
今天小編就為大家分享一篇關(guān)于啟動異常invalid constant type:15的解決方案,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧2018-12-12Java數(shù)據(jù)封裝樹形結(jié)構(gòu)代碼實(shí)例
這篇文章主要介紹了Java數(shù)據(jù)封裝樹形結(jié)構(gòu)代碼實(shí)例,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2020-01-01Java內(nèi)存泄漏問題處理方法經(jīng)驗(yàn)總結(jié)
今天小編就為大家分享一篇關(guān)于Java內(nèi)存泄漏問題處理方法經(jīng)驗(yàn)總結(jié),小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧2019-01-01圖解Java經(jīng)典算法折半查找的原理與實(shí)現(xiàn)
折半查找法也叫做?分查找,顧名思義就是把數(shù)據(jù)分成兩半,再判斷所查找的key在哪?半中,再重復(fù)上述步驟知道找到?標(biāo)key,下面這篇文章主要介紹了圖解Java經(jīng)典算法折半查找的原理與實(shí)現(xiàn)2022-09-09關(guān)于spring中aop的注解實(shí)現(xiàn)方法實(shí)例詳解
這篇文章主要給大家介紹了關(guān)于spring中aop的注解實(shí)現(xiàn)方法的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面跟著小編來一起看看吧。2017-08-08