今天,在引用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看一下:
果然发现问题了,具体的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'