文章目录
- 一、配置项提示
- 二、父子打包
- 三、打包之后不显示target
- 四、自定义打包之后的jar包名称
- 五、整个项目打包
- 5.1、父项目管理插件和微服务打包
一、配置项提示
SpringBoot中提示错误信息
表示的是SpringBoot中的注释提示没有配置!那么可以来使用一下springboot官方的注解处理器来解决这个问题
可以直接点击链接进去
现在依赖中引入对应依赖:
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-configuration-processor</artifactId>
<optional>true</optional>
</dependency>
然后在打包插件中排除掉打包进去的注释处理器
<project>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
<configuration>
<excludes>
<exclude>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-configuration-processor</artifactId>
</exclude>
</excludes>
</configuration>
</plugin>
</plugins>
</build>
</project>
二、父子打包
打包须知
这种微服务项目或者说是maven父子级项目打包要解决的问题就是具体业务代码依赖工具类代码,利用idea的maven插件可以很方便做到。在上层文件夹管理模块中,添加 pom (没有业务代码只做包含其他包的父类空包)
在没有main方法的工具模块中只添加 jar
在具体的业务代码模块中添加:
<build>
<!--maven的打包插件-->
<plugins>
<!--忽略测试类-->
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-surefire-plugin</artifactId>
<configuration>
<testFailureIgnore>true</testFailureIgnore>
</configuration>
</plugin>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
<!--打包规则,打包时将resource文件夹打包进去-->
<resources>
<resource>
<directory>src/main/java</directory>
<includes>
<include>**/*.yml</include>
<include>**/*.properties</include>
<include>**/*.xml</include>
</includes>
<filtering>false</filtering>
</resource>
<resource>
<directory>src/main/resources</directory>
<includes>
<include>**/*.yml</include>
<include>**/*.properties</include>
<include>**/*.xml</include>
</includes>
<filtering>false</filtering>
</resource>
</resources>
</build>
这样,只需在每个有mian方法的具体的业务模块中的pom中添加:
<plugins>
<!--忽略测试类-->
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-surefire-plugin</artifactId>
<configuration>
<testFailureIgnore>true</testFailureIgnore>
</configuration>
</plugin>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
最终打包:只需对最顶层模块进行clean,install,在每个模块对应的target目录中找到jar包。
三、打包之后不显示target
然后就会有对应的显示了。
四、自定义打包之后的jar包名称
没有更改名称之前:stock-1.0-SNAPSHOT.jar
但是当前没有版本,也不是自己想要的名称,但是改名字的话比较简单,下面来进行说明一下
直接进入到pom文件中来,可以看到pom文件配置如下:
<parent>
<artifactId>tuling-mall-demo1-parent</artifactId>
<groupId>com.guang</groupId>
<version>1.0-SNAPSHOT</version>
</parent>
<modelVersion>4.0.0</modelVersion>
<artifactId>stock</artifactId>
那么我们可以自定义改名称:
<parent>
<artifactId>tuling-mall-demo1-parent</artifactId>
<groupId>com.guang</groupId>
<version>1.0-SNAPSHOT</version>
</parent>
<modelVersion>4.0.0</modelVersion>
<artifactId>stock</artifactId>
<version>1.0.0</version>
<name>stock</name>
只是添加了版本号和对应的服务名称,打包后的名称就如同上诉所示。
其实我觉得这里的name应该和微服务名称保持一致。
然后再次来查对应的jar包,就可以看到名称已经发生修改了:stock-1.0.0.jar
五、整个项目打包
直接在父工程中来进行打包的时候,发现出现异常:
Failed to execute goal org.springframework.boot:spring-boot-maven-plugin:2.3
原因分析:项目里面包含了某些工具类的模块,而工具类模块是不需要我们启动的,只是提供给其他微服务引用而已,不需要启动就意味着 没有main启动类,但是父工程的pom文件却引用了 springboot打包插件 spring-boot-maven-plugin,即:
<!--springboot 打包插件-->
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
所以在打包的时候mvn会扫描所有的依赖模块,如果发现某个模块下面没有main启动类,就会报错。
那么解决问题就比较容易了,不在父工程中添加打包插件,而是在有启动类的微服务中来进行添加打包插件。
5.1、父项目管理插件和微服务打包
所以最佳实践应该是,在父pom文件中添加插件管理,然后在具体的微服务中,引入插件
父pom.xml文件:
<build>
<pluginManagement>
<plugins>
<!-- java编译插件 -->
<!--maven打包插件,可打直接可运行的jar包或war包-->
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
<version>${boot.version}</version>
<configuration>
<excludes>
<exclude>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-configuration-processor</artifactId>
</exclude>
</excludes>
</configuration>
</plugin>
</plugins>
</pluginManagement>
</build>
具体的微服务:
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
<version>${boot.version}</version>
</plugin>
</plugins>
</build>
在打包的时候也可以将spring-boot-configuration-processor给排除掉。