hadoop 应用遇到的问题

本文详细介绍了在使用Hadoop相关库与SpringMVC项目整合时遇到的java.lang.UnsupportedOperationException和java.lang.NoSuchMethodError错误,并提供了相应的解决方案。同时,文章还探讨了Hadoop文件系统在多线程环境下多次close导致的问题及其解决方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1、java.lang.UnsupportedOperationException: Not implemented by the DistributedFileSystem FileSyste,这个错误我在maven依赖中本来是加了三个依赖:

<dependency>
	<groupId>org.apache.hadoop</groupId>
	<artifactId>hadoop-common</artifactId>
	<version>2.6.0</version>
</dependency>
<dependency>
	<groupId>org.apache.hadoop</groupId>
	<artifactId>hadoop-client</artifactId>
	<version>2.6.0</version>
</dependency>
<dependency>
	<groupId>org.apache.hadoop</groupId>
	<artifactId>hadoop-core</artifactId>
	<version>1.2.1</version>
</dependency>

然后很诡异的是,我直接在自己打包的hadoop工具类主函数中调用是不会有问题,但是放到springmvc项目中其他类中调用,就一直报这个错误,然后去掉了 hadoop-core 依赖之后,就没报这个错误了。



2、java.lang.NoSuchMethodError: org.eclipse.jdt.internal.compiler.CompilationResult.getProblems(),这个错误应该是有余是Hadoop相关jar中依赖jetty、servlet等第三方jar包和当前项目中的有冲突,自己的 maven 项目中把不需要的依赖去掉,减少不必要的麻烦



3、Hadoop Filesystem 多次close的问题:

然后我就查,为什么呢。我刚刚用final FileSystem dfs = FileSystem.get(getConf()); 得到它啊。后来发现,我是一个多线程的程序。FileSystem.get(getConf())返回的可能是一个cache中的结果,它并不是每次都创建一个新的实例。这就意味着,如果每个线程都自己去get一个文件系统,然后使用,然后关闭,就会有问题。因为你们关闭的可能是同一个对象。而别人还在用它!所以最好是在main函数中就创建好filesystem对象然后在不同函数之间来回传递吧。在main函数用用try…finally关闭它。多线程程序中,如果你确保在你的get和close之间不会有别人调用get,也没问题。


4、Name node is in safe mode  重启之后的hdfs可能会遇到这个问题,执行一下这句:

hadoop dfsadmin -safemode leave





持续更新。。。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值