1、爲何要作這件事? 項目持續研發,不停地在上面新增功能,新增特性,引入新的框架和組件,jar包依賴多而且複雜,再加上需求各類變動,有很多已經存在的功能下線,但jar包依賴沒人管,仍是放在項目的pom.xml文件裏。項目持續的時間一長,常常會出現項目打包要求內存多,時間慢的問題,如何分析項目中哪些依賴是有用的,哪些能夠剔除的,一方面減輕打包內存佔用多,時間慢的問題,另外一方面照顧研發童鞋的強迫症問題(容不得半點無用jar包在個人項目裏),這事就能夠提上日程了。web
2、怎麼作? 若是是Maven項目,執行起來仍是比較簡單,Maven本身提供了一個檢測工具,輸入命令便可。 在IDEA中,切換到Terminal窗口,或者用命令行打開相應工程目錄,直接輸入spring
mvn dependency:analyze
查看控制檯輸出的日誌,重點關注這兩部分:apache
[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
間接依賴,就是說你在當前項目工程的pom.xml裏沒有直接聲明,這個依賴是由你聲明過的dependency裏的pom.xml依賴傳遞得來的。 例如org.apache.rocketmq:rocketmq-common:jar:4.5.2:compile是你引用了這個:json
<dependency> <groupId>org.apache.rocketmq</groupId> <artifactId>rocketmq-client</artifactId> <version>4.5.2</version> </dependency>
Maven原本就是這樣用的,也不建議說你把這部分引用拷貝到你的pom.xml裏,通常來講這部分的WARNING能夠忽略。架構
無用依賴,這個指咱們在pom.xml聲明瞭這個jar包的依賴,但在項目工程裏沒有使用到,這個不是咱們這次關注的重點,肯定不須要,就能夠剔除掉這個依賴,Reimport後這個jar包就從咱們項目中剔掉了。併發
3、何時作? 1)新項目創建時,引用jar包時要慎重,不要一古腦兒直接拷貝老項目的依賴,避免後期又花時間來剔除。 2)功能代碼重構時,能夠適當作一次剔除,由於後面還有自測,提交測試環節,若是有誤刪,測試的時候能發現。框架
4、有什麼風險要注意的? 1)這個檢測的結果僅供參考,有時也不許確,如上文說起的org.projectlombok:lombok:jar:1.16.20:provided,實際上在項目中有使用到它的註解@Data,這個屬於誤判。要注意剔除依賴後多測試,工具畢竟有畢竟的缺陷性。 2)若是童鞋們接手遺留的老項目時,這種問題確定不少,但剛接手時不建議作這個操做,由於自己對項目不熟悉,上來就刪東西致使問題會浪費不少時間和精力搞定依賴的問題,這塊東西建議暫時先不要動。maven
5、補充一個小插件 查看pom.xml的依賴關係時,能夠在IDEA上安裝maven help插件,能夠直觀地看到各jar依賴關係 分佈式
專一Java高併發、分佈式架構,更多技術乾貨分享與心得,請關注公衆號 ide