打jar包

maven插件打包

通過 maven-shade-plugin 生成一個 uber-jar,它包含所有的依賴 jar 包。

 <build>
        <plugins>
            <plugin>
                <groupId>org.apache.maven.plugins</groupId>
                <artifactId>maven-compiler-plugin</artifactId>
                <configuration>
                    <source>1.8</source>
                    <target>1.8</target>
                </configuration>
            </plugin>
            <plugin>
                <groupId>org.apache.maven.plugins</groupId>
                <artifactId>maven-shade-plugin</artifactId>
                <version>3.1.0</version>
                <executions>
                    <execution>
                        <phase>package</phase>
                        <goals>
                            <goal>shade</goal>
                        </goals>
                        <configuration>
                            <transformers>
                                <!-- 設置 MainClass -->
                                <transformer implementation="org.apache.maven.plugins.shade.resource.ManifestResourceTransformer">
                                    <mainClass>com.xxx.examples.Main</mainClass>
                                </transformer>
                                <!-- 如果項目中用到了Spring Framework,將依賴打到一個jar包中,運行時會出現讀取XML schema文件出錯。
                                原因是Spring Framework的多個jar包中包含相同的文件spring.handlers和spring.schemas,
                                如果生成一個jar包會互相覆蓋。爲了避免互相影響,可以使用AppendingTransformer來對文件內容追加合併-->
                                <transformer implementation="org.apache.maven.plugins.shade.resource.AppendingTransformer">
                                    <resource>META-INF/spring.handlers</resource>
                                </transformer>
                                <transformer implementation="org.apache.maven.plugins.shade.resource.AppendingTransformer">
                                    <resource>META-INF/spring.schemas</resource>
                                </transformer>
                            </transformers>
                        </configuration>
                    </execution>
                </executions>
            </plugin>
        </plugins>
    </build>

在POM 4中,<dependency>中還引入了<scope>,它主要管理依賴的部署。目前<scope>可以使用5個值: 

* compile,缺省值,適用於所有階段,會隨着項目一起發佈。 
* provided,類似compile,期望JDK、容器或使用者會提供這個依賴。如servlet.jar。 
* runtime,只在運行時使用,如JDBC驅動,適用運行和測試階段。 
* test,只在測試時使用,用於編譯和運行測試代碼。不會隨項目發佈。 
* system,類似provided,需要顯式提供包含依賴的jar,Maven不會在Repository中查找它。

1compile 的範圍

當依賴的scope爲compile的時候,那麼當前這個依賴的包,會在編譯的時候將這個依賴加入進來,並且在打包(mvn package)的時候也會將這個依賴加入進去

意思就是:編譯範圍有效,在編譯與打包時都會存儲進去

2provided的範圍

當依賴的scope爲provided的時候,在編譯和測試的時候有效,在執行(mvn package)進行打包成war包的時候不會加入,比如:servlet-api,因爲servlet-api,tomcat等web服務器中已經存在,如果在打包進去,那麼包之間就會衝突

3test的範圍

當依賴的scope爲test的時候,指的的是在測試範圍有效,在編譯與打包的時候都不會使用這個依賴

4runtime的範圍

當依賴的scope爲runtime的時候,在運行的時候纔會依賴,在編譯的時候不會依賴

注:在默認的情況下scope的範圍是compile

參考:https://blog.csdn.net/u013704227/article/details/46460913

https://blog.csdn.net/qq_38002337/article/details/83060213


IDEA打包

打開IDEA的file -> Project Structure,進入項目配置頁面。如下圖:

點擊Artifacts,進入Artifacts配置頁面,點擊 + ,選擇如下圖的選項。

進入Create JAR from Modules頁面,按照如下圖配置。

  1. 第一步選擇Main函數執行的類。
  2. 第二步選擇如圖的選項,目的是對第三方Jar包打包時做額外的配置,如果不做額外的配置可不選這個選項(但不保證打包成功)
  3. 第三步需要在src/main目錄下,新建一個resources目錄,將MANIFEST.MF文件保存在這裏面,因爲如果用默認缺省值的話,在IDEA12版本下會有bug。

點擊OK之後,出現如下圖界面,右鍵點擊<output root>,點擊Create Directory,創建一個libs,將所有的第三方JAR放進libs目錄下。

成功之後,如下圖所示:

放入之後,點擊我們要打成的jar的名字,這裏面是kafka-cps.jar,選擇classpath進行配置。

編輯的結果如下:

這裏將所有的jar都寫在libs/裏面。點擊OK,回到配置頁面。

同時還注意在配置頁面,勾選build on make

最後點擊配置頁面的OK,完成配置。回到IDEA,點擊Build->Build Artifacts,選擇build

就會生成我們需要的jar包。其位置在項目目錄的out目錄下/out/artifacts/kafka_cps_jar。

下面放一個正確配置的清單文件內容


springBoot項目打包

1、pom.xml

    <build>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
            </plugin>
        </plugins>
    </build>

 

發佈了49 篇原創文章 · 獲贊 7 · 訪問量 1萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章