聊聊 Maven 最佳實(shí)踐
本文翻譯自國(guó)外論壇 medium,原文地址:https://medium.com/@AlexanderObregon/maven-best-practices-tips-and-tricks-for-java-developers-438eca03f72b
Maven 簡(jiǎn)介
Maven 是一種廣泛使用的 Java 項(xiàng)目構(gòu)建自動(dòng)化工具。它簡(jiǎn)化了構(gòu)建過程并幫助管理依賴關(guān)系,使開發(fā)人員的工作更輕松。在這篇博文中,我們將討論一些最佳實(shí)踐、提示和技巧,以優(yōu)化我們?cè)陧?xiàng)目中對(duì) Maven 的使用并改善我們的開發(fā)體驗(yàn)。
Maven 標(biāo)準(zhǔn)目錄結(jié)構(gòu)
Maven 遵循標(biāo)準(zhǔn)目錄結(jié)構(gòu)來保持項(xiàng)目之間的一致性。遵循這種結(jié)構(gòu)可以讓其他開發(fā)人員更輕松地理解我們的項(xiàng)目。
src/
main/
java/ # 源代碼目錄
resources/ # 配置文件目錄
test/
java/ # 測(cè)試代碼目錄
resources/ # 測(cè)試配置文件目錄
pom.xml
指定 Maven 編譯器插件
默認(rèn)情況下,Maven 使用 Java5 編譯我們的項(xiàng)目。要使用不同的 Jdk 版本,請(qǐng)?jiān)?nbsp;pom.xml 文件中配置 Maven 編譯器插件:
<build>
<plugins>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-compiler-plugin</artifactId>
<version>3.8.1</version>
<configuration>
<source>11</source>
<target>11</target>
</configuration>
</plugin>
</plugins>
</build>
有效管理依賴關(guān)系
Maven 的依賴管理系統(tǒng)是其最強(qiáng)大的功能之一。使用 pom.xml 文件中的 <dependencyManagement> 標(biāo)簽來集中管理依賴項(xiàng)的版本。這有助于避免沖突并確保所有模塊使用相同版本的依賴項(xiàng):
<dependencyManagement>
<dependencies>
<dependency>
<groupId>com.fasterxml.jackson.core</groupId>
<artifactId>jackson-databind</artifactId>
<version>2.12.5</version>
</dependency>
</dependencies>
</dependencyManagement>
針對(duì)不同環(huán)境使用配置文件
Maven 配置文件允許我們配置不同環(huán)境的構(gòu)建設(shè)置,例如開發(fā)、測(cè)試和生產(chǎn)。在 pom.xml 文件中定義配置文件并使用命令行參數(shù)激活它們:
<profiles>
<profile>
<id>development</id>
<activation>
<activeByDefault>true</activeByDefault>
</activation>
<properties>
<environment>dev</environment>
</properties>
</profile>
<profile>
<id>production</id>
<properties>
<environment>prod</environment>
</properties>
</profile>
</profiles>
使用命令行激活配置文件:
mvn clean install -P production
保持 pom.xml 干凈且井然有序
組織良好的 pom.xml 文件更易于維護(hù)和理解。以下是維護(hù)干凈的 pom.xml 的一些技巧:
- 將相似的依賴項(xiàng)和插件組合在一起。
- 使用注釋來描述特定依賴項(xiàng)或插件的用途。
- 將插件和依賴項(xiàng)的版本號(hào)保留在 <properties> 標(biāo)簽內(nèi)以便于管理。
<properties>
<junit.version>5.7.0</junit.version>
<mockito.version>3.9.0</mockito.version>
</properties>
使用 Maven Wrapper
Maven Wrapper 確保構(gòu)建過程使用正確的 Maven 版本,即使系統(tǒng)上沒有安裝它。要使用 Maven Wrapper,請(qǐng)?jiān)陧?xiàng)目目錄中運(yùn)行以下命令:
mvn wrapper:wrapper
此命令會(huì)在我們的項(xiàng)目中生成 Maven Wrapper 文件?,F(xiàn)在我們可以使用 ./mvnw (或 Windows 上的 ./mvnw.cmd)而不是 mvn 來執(zhí)行 Maven 命令。
通過持續(xù)集成實(shí)現(xiàn)構(gòu)建自動(dòng)化
將 Maven 項(xiàng)目與持續(xù)集成 (CI) 系統(tǒng)(例如 Jenkins 或 GitHub Actions)集成,可確保自動(dòng)構(gòu)建、測(cè)試和部署我們的代碼。CI 有助于及早發(fā)現(xiàn)問題并在整個(gè)團(tuán)隊(duì)中提供一致的構(gòu)建流程。以下是 Maven 項(xiàng)目的簡(jiǎn)單 GitHub Actions 工作流程示例:
name: Java CI with Maven
on: [push]
jobs:
build:
runs-on: ubuntu-latest
steps:
- name: Checkout code
uses: actions/checkout@v2
- name: Set up JDK 11
uses: actions/setup-java@v2
with:
java-version: '11'
distribution: 'adopt'
- name: Build with Maven
run: ./mvnw clean install
利用 Maven 插件獲得附加功能
有許多 Maven 插件可用于擴(kuò)展 Maven 的功能。一些流行的插件包括:
- maven-surefire-plugin:配置并執(zhí)行單元測(cè)試。
- maven-failsafe-plugin:配置并執(zhí)行集成測(cè)試。
- maven-javadoc-plugin:生成 Javadoc 格式的項(xiàng)目文檔。
- maven-checkstyle-plugin:強(qiáng)制執(zhí)行編碼標(biāo)準(zhǔn)和最佳實(shí)踐。
探索可用的插件并在 pom.xml 文件中配置它們以增強(qiáng)我們的開發(fā)過程。
總結(jié)
Maven 是一個(gè)強(qiáng)大的工具,可以簡(jiǎn)化 Java 項(xiàng)目的構(gòu)建過程和依賴關(guān)系管理。通過遵循這些最佳實(shí)踐和技巧,我們可以優(yōu)化 Maven 的使用并改善我們的 Java 開發(fā)體驗(yàn)。請(qǐng)記住使用標(biāo)準(zhǔn)目錄結(jié)構(gòu),有效管理依賴關(guān)系,利用不同環(huán)境的配置文件,并將項(xiàng)目與持續(xù)集成系統(tǒng)集成,以確保構(gòu)建一致。
本文參考
- Maven Official Website
- Maven Getting Started Guide
- Maven Plugins
- Maven Wrapper