微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

关于Maven中的version和classifier

原文地址:https://www.coder4.com/archives/4315

今天,在引用mrunit的时候,第一次知道maven中除了version,还有更细粒度的classifier。

我们直接看个例子,要引用mrunit,在maven repo官网查询到gradle的写法为:

'org.apache.mrunit:mrunit:1.1.0'

然而,在执行gradew编译的时候,报错:

Could not resolve all dependencies for configuration ':testCompile'. > Artifact 'org.apache.mrunit:mrunit:1.1.0:mrunit.jar' not found.

这个很奇怪的...

进入http的repo看一下:

Screenshot from 2014-11-10 10:42:58

果然发现问题了,具体的jar包并非是mrunit-1.0.0.jar,而是mrunit-1.1.0-hadoop1.jar。。。经过一番查找,发现这个是mvn中的classifier的概念,如果采用maven,写法应该附加一个classifier属性

 

<dependency> <groupId>org.apache.mrunit</groupId> <artifactId>mrunit</artifactId> <version>1.1.0</version> <classifier>hadoop1</classifier> </dependency>

在gradle中,写法更加简单:在version后再加一个冒号,然后追加一个classifier即可:

'org.apache.mrunit:mrunit:1.1.0:hadoop1'

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐