Java调用hdfs出现java.lang.VerifyError: class org.apache.hadoop.hdfs.protocol.proto异常

Java程序访问Hadoop HDFS时遇到`java.lang.VerifyError`,原因是protobuf-java版本冲突。解决办法是在pom文件中排除低版本protobuf依赖,通过maven-helper插件检查并解决冲突。
摘要由CSDN通过智能技术生成

1. 问题背景:

Java程序访问Hadoop的分布式文件系统(hdfs),如下面语句:

	private List<String> readCsvFile(String path) throws IOException {
		CosmosLogin.loginFromPasswd(ROLE_NAME + "@XXX.COM", ROLE_PASSWORD);
		HdfsConfiguration hdfsConf = new HdfsConfiguration();
		hdfsConf.set("fs.hdfs.impl", org.apache.hadoop.hdfs.DistributedFileSystem.class.getName());
		hdfsConf.set("fs.file.impl", org.apache.hadoop.fs.LocalFileSystem.class.getName());
		FileSystem fs = FileSystem.get(hdfsConf);
		List<String> lines = new ArrayList<String>();
		try {
			BufferedReader reader = new BufferedReader(new InputStreamReader(fs.open(new Path(path))));
			String line;
			while ((line = reader.readLine()) != null) {
				lines.add(line);
			}
			reader.close();
		} finally {
			fs.close();
		}
		return lines;
	}
每次访问到标红语句 FileSystem.get(hdfsConf) 时抛出运行时异常&#x
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值