中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Maven的基礎知識整理

發布時間:2021-08-24 17:24:43 來源:億速云 閱讀:136 作者:chen 欄目:開發技術

本篇內容介紹了“Maven的基礎知識整理”的有關知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠學有所成!

目錄
  • Maven工程基礎知識

    • Maven倉庫的分類

    • Maven常用命令的含義

    • 一個項目生命周期

    • 打包類型:<packaging >

    • 依賴范圍:<scope>

    • 聚合與繼承的關系

  • 依賴沖突

    • 依賴調節原則

    • 解決依賴沖突-使用MavenHelper

Maven工程基礎知識

       maven 工程中不直接將 jar 包導入到工程中,而是通過在 pom.xml 文件中添加所需 jar包的坐標,這樣就很好的避免了 jar 直接引入進來,在需要用到 jar 包的時候,只要查找 pom.xml 文件,再通過 pom.xml 文件中的坐標,到一個專門用于”存放 jar 包的倉庫”(maven 倉庫)中根據坐標從而找到這些 jar 包,再把這些 jar 包拿去運行。

       為了解決這個過程中速度慢的問題,maven 中也有索引的概念,通過建立索引,可以大大提高加載 jar 包的速度

Maven倉庫的分類

本地倉庫 :用來存儲從遠程倉庫或中央倉庫下載的插件和 jar 包,項目使用一些插件或 jar 包,優先從本地倉庫查找

遠程倉庫:如果本地需要插件或者 jar 包,本地倉庫沒有,默認去遠程倉庫下載(私服)。

中央倉庫:在 maven 軟件中內置一個遠程倉庫地址https://www.mvnrepository.com/ ,它是中央倉庫,服務于整個互聯網。

Maven常用命令的含義

    compile:編譯--- compile 是 maven 工程的編譯命令,作用是將 src/main/java 下的文件編譯為 class 文件輸出到 target目錄下。

    clean:清理--- clean 是 maven 工程的清理命令,執行 clean 會刪除 target 目錄及內容。

    test:測試--- test 是 maven 工程的測試命令 mvn test,會執行 src/test/java 下的單元測試類。

    package:打包---package 是 maven 工程的打包命令,對于 java 工程執行 package 打成 jar 包,對于 web 工程打成 war包。

    install:安裝--- install 是 maven 工程的安裝命令,執行 install 將 maven 打成 jar 包或 war 包發布到本地倉庫

一個項目生命周期

Maven的基礎知識整理

打包類型:<packaging >

jar:執行 package 會打成 jar 包

war:執行 package 會打成 war 包

pom :用于 maven 工程的繼承,通常父工程設置為 pom

依賴范圍:<scope>

A 依賴 B,需要在 A 的 pom.xml 文件中添加 B 的坐標,添加坐標時需要指定依賴范圍,依賴范圍包括:

compile:compile指 A 在編譯時依賴 B,此范圍為默認依賴范圍。編譯范圍的依賴會用在編譯、測試、運行,由于運行時需要所以編譯范圍的依賴會被打包。

provided:provided 依賴只有在當 JDK 或者一個容器已提供該依賴之后才使用, provided 依賴在編譯和測試時需要,在運行時不需要,比如:servlet api 被 tomcat 容器提供。

runtime:runtime 依賴在運行和測試系統的時候需要,但在編譯的時候不需要。比如:jdbc的驅動包。由于運行時需要所以 runtime 范圍的依賴會被打包。

test:test 范圍依賴 在編譯和運行時都不需要,它們只有在測試編譯和測試運行階段可用,比如:junit。由于運行時不需要所以 test范圍依賴不會被打包。

system:system 范圍依賴與 provided 類似,但是你必須顯式的提供一個對于本地系統中 JAR文件的路徑,需要指定 systemPath 磁盤路徑,system依賴不推薦使用。

依賴范圍由強到弱的順序是:compile>provided>runtime>test

Maven的基礎知識整理

pom文件中常用標簽的含義

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>
 <!--聲明項目描述符遵循哪一個POM模型版本。4.0.0-->
 
    <groupId>com.tfjybj</groupId>
    <artifactId>super</artifactId>
    <packaging>pom</packaging>
    <version>1.0.0-SNAPSHOT</version>
    
    <!--項目的名稱, Maven產生的文檔用-->
    <name>super</name>
    <!-- 項目的詳細描述, Maven 產生的文檔用。-->
    <description>super</description>
 
    <!--聚合  來管理同個項目中的其他模塊-->
    <modules>
        <module>super-common</module>
        <module>super-gateway</module>
        <module>super-zipkin</module>
        <module>super-provider</module>
        <module>super-provider-api</module>
    </modules>
 
    <!--繼承  說明這是一個boot工程-->
    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>2.1.8.RELEASE</version>
    </parent>
 
 
    <!--統一管理jar包版本-->
    <properties>
        <!--項目編碼方式,maven編譯版本-->
        <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
        <maven.compiler.source>8</maven.compiler.source>
        <maven.compiler.target>8</maven.compiler.target>
          <!--統一管理jar包版本-->
        <spring.cloud.version>2.1.0.RELEASE</spring.cloud.version>
        <spring.boot.version>2.1.8.RELEASE</spring.boot.version>
        <mysql.version>6.0.6</mysql.version>
    </properties>
 
    <!--統一管理版本號-->
    <!--在父工程pom文件中聲明依賴,但不引入,父項目聲明,供子項目按需引入-->
    <dependencyManagement>
        <dependencies>
            <!-- nacos服務注冊/發現-->
            <dependency>
                <groupId>com.alibaba.cloud</groupId>
                <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
                <version>${spring.cloud.version}</version>
                 <!--排除ribbon的依賴-->
               <exclusions>
                   <exclusion>
                       <groupId>org.springframework.cloud</groupId>
                       <artifactId>spring-cloud-starter-netflix-ribbon</artifactId>
                    </exclusion>
                </exclusions>
            </dependency>
            <!--nacos配置中心來做配置管理-->
            <dependency>
                <groupId>com.alibaba.cloud</groupId>
                <artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
                <version>${spring.cloud.version}</version>
            </dependency>
             <!--mysql-->
            <dependency>
                <groupId>mysql</groupId>
                <artifactId>mysql-connector-java</artifactId>
                <version>${mysql.version}</version>
               <!--  mysql依賴的作用范圍-->
                <scope>runtime</scope>
            </dependency>
           
        </dependencies>
    </dependencyManagement>
 
    <!--所有聲明在父項目 dependencies 中的依賴都會自動引入,并默認被所有子項目繼承-->
    <!--即使在子項目中不引入該依賴,那么子項目依然會從父項目中繼承該依賴項。-->
    <dependencies>
 
    </dependencies>
 
    <!--發現依賴和擴展的遠程倉庫列表  -->
    <!--遠程倉庫列表,它是Maven用來填充本地倉庫所使用的一組遠程項目。 -->
    <repositories>
        <!--包含需要連接到遠程倉庫的信息-->
        <repository>
            <id>spring-milestones</id>
            <name>Spring Milestones</name>
            <url>https://repo.spring.io/milestone</url>
        </repository>
    </repositories>
 
    <!--用于項目打包,打包需要的插件-->
     <build>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
            </plugin>
        </plugins>
    </build>
 
</project>

聚合與繼承的關系

     1、聚合主要是為了方便快速構建項目,繼承主要是為了消除重復配置

  2、對于聚合模塊而言,它知道有哪些被聚合的模塊,但那些被聚合的模塊不知道這個聚合模塊的存在;對于繼承的父pom 而言,它不知道有哪些子模塊繼承它,但那些子模塊都必須知道自己的父pom 是什么

  3、聚合pom 與繼承中的父pom 的 packaging 都必須是 pom;同時,聚合模塊與繼承中的父模塊除了 pom 外,都沒有實際的內容

依賴沖突

         Maven的依賴機制會導致Jar包的沖突。

          舉個例子,現在你的項目中,使用了兩個Jar包,分別是A和B。現在A需要依賴另一個Jar包C,B也需要依賴C。但是A依賴的C的版本是1.0,B依賴的C的版本是2.0。這時候,Maven會將這1.0的C和2.0的C都下載到你的項目中,這樣你的項目中就存在了不同版本的C,這時Maven會依據依賴路徑最短優先原則,來決定使用哪個版本的Jar包,而另一個無用的Jar包則未被使用,這就是所謂的依賴沖突。

依賴調節原則

1.第一聲明者優先原則

在pom文件定義依賴,以先聲明的依賴為準。

誰先在pom.xml中申明,就用誰的。跟坐標代碼的順序有關

2.路徑近者優先原則

Maven的基礎知識整理

以上兩個jar包都依賴了spring-beans。

spring-context和spring-webmvc都會傳遞過來spring-beans,那如果直接把spring-beans的依賴寫在pom文件中,那么項目就不會再使用其他依賴傳遞過來的spring-beans。

因為自己直接在pom中定義spring-beans要比其他依賴傳遞過來的路徑要近。

3.排除依賴原則

使用Maven中的<exclusions>標簽,例如

 <!--使用的openfeign-->
     <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-openfeign</artifactId>
            <version>2.2.1.RELEASE</version>
            <exclusions>
                 <exclusion>
                     <groupId>org.springframework.cloud</groupId>
                     <artifactId>spring-cloud-starter-netflix-ribbon</artifactId>
                 </exclusion>
            </exclusions>
     </dependency>

4.鎖定版本原則

面對眾多的依賴,有一種方法不用考慮依賴路徑、聲明優化等因素可以采用直接鎖定版本的方法確定依賴構件的版本,版本鎖定后則不考慮依賴的聲明順序或依賴的路徑,以鎖定的版本的為準添加到工程中,此方法在企業開發中常用。

解決依賴沖突-使用MavenHelper

在idea中下載插件mavenHelper解決依賴沖突,使用步驟看圖

Maven的基礎知識整理

Maven的基礎知識整理

找到沖突,點擊右鍵,然后選擇Exclude即可排除沖突版本的Jar包。

“Maven的基礎知識整理”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識可以關注億速云網站,小編將為大家輸出更多高質量的實用文章!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

双牌县| 彭山县| 阜康市| 乐至县| 田阳县| 恩平市| 江永县| 沙洋县| 讷河市| 庐江县| 定襄县| 新宁县| 万全县| 厦门市| 海原县| 三门县| 阳新县| 久治县| 鄂伦春自治旗| 华宁县| 晋中市| 仁化县| 营口市| 丰县| 英德市| 黔西县| 正镶白旗| 若尔盖县| 开江县| 沙雅县| 上林县| 孝昌县| 邵东县| 广饶县| 永州市| 河池市| 广宗县| 旌德县| 修文县| 海伦市| 江达县|