使用Maven中的scope总结

网友投稿 356 2022-07-23


目录Maven中的scope总结Maven中的scope主要有以下6种Maven中<scope>参数</scope>配置解决maven项目中无法打包生成空文件夹的问题

Maven中的scope总结

Maven中的scope主要有以下6种

接下来分别介绍下这几种scope:

compile

不声明scope元素的情况下的默认值;compile表示被依赖包需要参与当前项目的编译,包括后续的测试,运行周期也参与其中,是一个比较强的依赖;打包的时候通常需要包含进去。

provided

provided 类型的scope只会在项目的编译、测试阶段起作用;可以认为在目标容器中已经提供了这个依赖,无需在提供,但是在编写代码或者编译时可能会用到这个依赖;依赖不会被打入到项目jar包中。

说到provided,这里就要说到下的子标签 ,如果一个依赖的 设置为true,则该依赖在打包的时候不会被打进jar包,同时不会通过依赖传递传递到依赖该项目的工程;例如:x

依赖B,B由依赖于A(x->B->A),则A中设置 为true的依赖不会被传递到x中。

这两者的区别在于:

1、为true 表示某个依赖可选,该依赖是否使用都不会影响服务运行;

2、provided的在目标容器中已经提供了这个依赖,无需在提供

runtime

runtime与compile比较相似,区别在于runtime 跳过了编译阶段,打包的时候通常需要包含进去。

test

在一般的编译和运行时都不需要,它们只有在测试编译和测试运行阶段可用,不会被打包到项目jar包中,同时如果项目A依赖于项目B,项目B中的test作用域下的依赖不会被继承。

system

表示使用本地系统路径下的jar包,需要和一个systemPath一起使用,如下:

xxxx

xxx

${basedir}/lib/xxxxx.jar

system

1.4.12

import

import 只能在pom文件的中使用,从而引入其他的pom文件中引入依赖,如:在Spring boot 项目的POM文件中,我们可以通过在POM文件中继承 Spring-boot-starter-parent来引

用Srping boot默认依赖的jar包,如下:

org.springframework.boot

spring-boot-starter-parent

2.0.1.BUILD-SNAPSHOT

但是,通过上面的parent继承的方法,只能继承一个 spring-boot-start-parent。实际开发中,用户很可能需要继承自己公司的标准parent配置,这个时候可以使用 scope=import 来实现多继承。代码如下:

org.springframework.boot

spring-boot-dependencies

2.0.1.BUILD-SNAPSHOT

pom

import

通过上面方式,就可以获取spring-boot-dependencies.2.0.1.BUILD-SNAPSHOT.pom文件中dependencyManagement配置的jar包依赖。如果要继承多个,可以在dependencyManagement中添加,如:

org.springframework.data

spring-data-releasetrain

Fowler-SR2

pom

import

org.springframework.boot

spring-boot-dependencies

2.0.1.BUILD-SNAPSHOT

pom

import

Maven中<scope>参数</scope>配置

参数名称具体功能compile默认值,表示当前依赖包要参与当前项目的编译后续测试运行时打包provided当前包只在编译和测试的时候使用,而不再后续的运行和打包的时候不会打包进来test表示当前依赖包只参与测试工作runtime表示当前依赖包只参与运行周期,其他跳过system从参与度和provided一致,不过被依赖项不会从maven远程仓库下载,而是从本地的系统拿。需要systemPath属性来定义路径

解决maven项目中无法打包生成空文件夹的问题

org.apache.maven.plugins

maven-shade-plugin

3.1.1

package

shade

org.apache.flink:force-shading

com.google.code.findbugs:jsr305

org.slf4j:*

org.apache.logging.log4j:*

*:*

META-INF/*.SF

META-INF/*.DSA

META-INF/*.RSA

http:// com.lkr.flink.StreamingJob


版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:java 集合工具类Collections及Comparable和Comparator排序详解
下一篇:Spring中@Scope的几种取值方式
相关文章

 发表评论

暂时没有评论,来抢沙发吧~