我想Cascading在我的Hadoop项目中使用.我试图实现Enterprise Data Workflows with Cascading书中给出的第一个例子.我编写了包含Cascading相关代码的java类,我有另一个build.graddle文件,它应该编译该java类并从中构建jar文件.
我的文件夹结构如下:
main_folder
不耐烦
我的build.gradle文件如下所示:
apply plugin: 'java'
apply plugin: 'idea'
apply plugin: 'eclipse'
archivesBaseName = 'impatient'
repositories {
mavenLocal()
mavenCentral()
mavenRepo name: 'conjars', url: 'http://conjars.org/repo/'
}
ext.cascadingVersion = '2.1.0'
dependencies {
compile( group: 'cascading', name: 'cascading-core', version: cascadingVersion )
compile( group: 'cascading', name: 'cascading-hadoop', version: cascadingVersion )
}
jar {
description = "Assembles a Hadoop ready jar file"
doFirst {
into( 'lib' ) {
from configurations.compile
}
}
manifest {
attributes( "Main-Class": "impatient/Main" )
}
}
Run Code Online (Sandbox Code Playgroud)
当我gradle clean jar从命令提示符运行命令时,我得到构建成功的消息.我尝试使用运行此jar文件
hadoop jar impatient.jar <input file path> <output file path>
命令,但它给了我Exception in thread "main" java.lang.ClassNotFoundException: impatient.Main例外.
所以我检查了jar文件的contentes,发现那个jar不包含impatient/Main.class文件.
请注意,我对gradle一无所知.
请求有人请告诉我gradle脚本是否有任何问题或者我犯了一些错误.
谢谢 !!!
Nik*_*sov 10
将源文件移动到
main_folder/impatient/src/main/java/Main.java
但将build.gradle文件留在原处.
默认情况下,Gradle使用src/main/java和src/test/java查找生成和测试java源(相对于根文件夹,impatient在您的情况下)
| 归档时间: |
|
| 查看次数: |
6238 次 |
| 最近记录: |