groovy hadoop jar with gradle - 包不存在错误
groovy hadoop jar with gradle - package not exist error
我试图用 Gradle 2.12 创建一个 groovy 罐子。 groovy 文件有如下导入语句,我把这个文件放在 src/main/groovy
前两个导入是 java 个文件,它们依次有 org.apache.hadoop
个导入语句。我把这两个文件放在src/main/java
import StartsWithCountMapper
import StartsWithCountReducer
import org.apache.hadoop.conf.Configured
import org.apache.hadoop.fs.Path
import org.apache.hadoop.io.IntWritable
import org.apache.hadoop.io.LongWritable
import org.apache.hadoop.io.Text
import org.apache.hadoop.mapreduce.Job
import org.apache.hadoop.mapreduce.Mapper
import org.apache.hadoop.mapreduce.Reducer
import org.apache.hadoop.mapreduce.lib.input.TextInputFormat
import org.apache.hadoop.mapreduce.lib.output.TextOutputFormat
import org.apache.hadoop.util.Tool
import org.apache.hadoop.util.ToolRunner
下面是我的 build.gradle 文件(使用 this)
apply plugin: 'groovy'
apply plugin: 'application'
version = '1.0'
mainClassName='CountGroovyJob'
repositories {
mavenCentral()
}
dependencies {
compile 'org.codehaus.groovy:groovy-all:2.0.0'
compile 'org.apache.hadoop:hadoop-common:2.7.1'
}
task Createjar(type: Jar,dependsOn:[':compileJava',':compileGroovy']) {
from files(sourceSets.main.output.classesDir)
from configurations.runtime.asFileTree.files.collect { zipTree(it) }
manifest {
attributes 'Main-Class': mainClassName
}
}
我也尝试通过将它们放在依赖项中来编译下面的内容
compile 'org.apache.hadoop:hadoop-client:2.0.0-mr1-cdh4.0.1'
compile 'org.apache.hadoop:hadoop-core:1.2.1'
compile 'org.apache.hadoop:hadoop-hdfs:2.7.1'
但我一直收到此错误:
/Users/../../../gradle/buildSrc/src/main/java/StartsWithCountMapper.java:5: error: package org.apache.hadoop.io does not exist
import org.apache.hadoop.io.IntWritable;
^
/Users/../../../gradle/buildSrc/src/main/java/StartsWithCountMapper.java:6: error: package org.apache.hadoop.io does not exist
import org.apache.hadoop.io.LongWritable;
^
/Users/../../../gradle/buildSrc/src/main/java/StartsWithCountMapper.java:7: error: package org.apache.hadoop.io does not exist
import org.apache.hadoop.io.Text;
如何使用 groovy 和 java 文件中的所有导入语句编译和创建 jar?
编辑
包含构建脚本{}
apply plugin: 'groovy'
apply plugin: 'application'
version = '1.0'
mainClassName='CountGroovyJob'
repositories {
mavenCentral()
}
dependencies {
compile 'org.codehaus.groovy:groovy-all:2.0.0'
compile 'org.apache.hadoop:hadoop-common:2.7.1'
}
task Createjar(type: Jar,dependsOn:[':compileJava',':compileGroovy']) {
from files(sourceSets.main.output.classesDir)
from configurations.runtime.asFileTree.files.collect { zipTree(it) }
manifest {
attributes 'Main-Class': mainClassName
}
}
buildscript{
repositories {
mavenCentral()
}
dependencies {
compile 'org.codehaus.groovy:groovy-all:2.0.0'
compile 'org.apache.hadoop:hadoop-common:2.7.1'
}
}
文件夹结构:
grad-proj
|
+-- build.gradle
|
+-- src
|
+-- main
|
+-- groovy
|
+-- java
导入语句位于 buildSrc
而不是 main
中的代码中,这意味着构建脚本依赖项部分需要依赖项。
相反,您将依赖项应用于通用依赖项部分,该部分适用于位于 main
目录中的源代码。
添加到您的build.gradle:
buildscript{
repositories {
mavenCentral()
}
dependencies {
compile 'org.codehaus.groovy:groovy-all:2.0.0'
compile 'org.apache.hadoop:hadoop-common:2.7.1'
}
}
我试图用 Gradle 2.12 创建一个 groovy 罐子。 groovy 文件有如下导入语句,我把这个文件放在 src/main/groovy
前两个导入是 java 个文件,它们依次有 org.apache.hadoop
个导入语句。我把这两个文件放在src/main/java
import StartsWithCountMapper
import StartsWithCountReducer
import org.apache.hadoop.conf.Configured
import org.apache.hadoop.fs.Path
import org.apache.hadoop.io.IntWritable
import org.apache.hadoop.io.LongWritable
import org.apache.hadoop.io.Text
import org.apache.hadoop.mapreduce.Job
import org.apache.hadoop.mapreduce.Mapper
import org.apache.hadoop.mapreduce.Reducer
import org.apache.hadoop.mapreduce.lib.input.TextInputFormat
import org.apache.hadoop.mapreduce.lib.output.TextOutputFormat
import org.apache.hadoop.util.Tool
import org.apache.hadoop.util.ToolRunner
下面是我的 build.gradle 文件(使用 this)
apply plugin: 'groovy'
apply plugin: 'application'
version = '1.0'
mainClassName='CountGroovyJob'
repositories {
mavenCentral()
}
dependencies {
compile 'org.codehaus.groovy:groovy-all:2.0.0'
compile 'org.apache.hadoop:hadoop-common:2.7.1'
}
task Createjar(type: Jar,dependsOn:[':compileJava',':compileGroovy']) {
from files(sourceSets.main.output.classesDir)
from configurations.runtime.asFileTree.files.collect { zipTree(it) }
manifest {
attributes 'Main-Class': mainClassName
}
}
我也尝试通过将它们放在依赖项中来编译下面的内容
compile 'org.apache.hadoop:hadoop-client:2.0.0-mr1-cdh4.0.1'
compile 'org.apache.hadoop:hadoop-core:1.2.1'
compile 'org.apache.hadoop:hadoop-hdfs:2.7.1'
但我一直收到此错误:
/Users/../../../gradle/buildSrc/src/main/java/StartsWithCountMapper.java:5: error: package org.apache.hadoop.io does not exist
import org.apache.hadoop.io.IntWritable;
^
/Users/../../../gradle/buildSrc/src/main/java/StartsWithCountMapper.java:6: error: package org.apache.hadoop.io does not exist
import org.apache.hadoop.io.LongWritable;
^
/Users/../../../gradle/buildSrc/src/main/java/StartsWithCountMapper.java:7: error: package org.apache.hadoop.io does not exist
import org.apache.hadoop.io.Text;
如何使用 groovy 和 java 文件中的所有导入语句编译和创建 jar?
编辑 包含构建脚本{}
apply plugin: 'groovy'
apply plugin: 'application'
version = '1.0'
mainClassName='CountGroovyJob'
repositories {
mavenCentral()
}
dependencies {
compile 'org.codehaus.groovy:groovy-all:2.0.0'
compile 'org.apache.hadoop:hadoop-common:2.7.1'
}
task Createjar(type: Jar,dependsOn:[':compileJava',':compileGroovy']) {
from files(sourceSets.main.output.classesDir)
from configurations.runtime.asFileTree.files.collect { zipTree(it) }
manifest {
attributes 'Main-Class': mainClassName
}
}
buildscript{
repositories {
mavenCentral()
}
dependencies {
compile 'org.codehaus.groovy:groovy-all:2.0.0'
compile 'org.apache.hadoop:hadoop-common:2.7.1'
}
}
文件夹结构:
grad-proj
|
+-- build.gradle
|
+-- src
|
+-- main
|
+-- groovy
|
+-- java
导入语句位于 buildSrc
而不是 main
中的代码中,这意味着构建脚本依赖项部分需要依赖项。
相反,您将依赖项应用于通用依赖项部分,该部分适用于位于 main
目录中的源代码。
添加到您的build.gradle:
buildscript{
repositories {
mavenCentral()
}
dependencies {
compile 'org.codehaus.groovy:groovy-all:2.0.0'
compile 'org.apache.hadoop:hadoop-common:2.7.1'
}
}