关于Maven中的version和classifier

今天,在引用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'

 

 

 

 

Leave a Reply

Your email address will not be published. Required fields are marked *