在调试mr实例的时候,遇到如下的情况,如图所示
说明:就是我的mr程序类名称和我设置的setJarByclass()中设置的不一样,但是程序竟然没有报错!!!!当时把我吓尿了
疑惑:如果这样设置的话,那岂不是找不到的main方法了啊?
最后查看setJarByClass()方法,惊奇的发现
在 JobConf中有个setJarByClass方法
/**
* Set the job's jar file by finding an example class location.
*
* @param cls the example class.
*/
public void setJarByClass(Class cls) {
String jar = ClassUtil.findContainingJar(cls);
if (jar != null) {
setJar(jar);
}
}
该方法的作用是 通过传入的class 找到job的jar包,上图我们设置的class 跟我们的job类位于同一个包中,通过public void setJarByClass(Class cls) 返回的是就是我们job包的jar,所以成功了
如果 我们设置的的class跟主类不在同一个工程中,程序会报错:NotFoundClass
本文探讨了在MapReduce实例调试过程中遇到的一个奇特现象:当设置的类名与实际的主类名不一致时,程序并未报错。文章深入剖析了JobConf中的setJarByClass方法的工作原理,并解释了为何在这种情况下程序仍然能够正常运行。
612

被折叠的 条评论
为什么被折叠?



