用Eclipse对Hadoop文件进行压缩和解压缩编译过程中遇到的问题

本文介绍了解决使用Hadoop解压缩文件时遇到的native库未找到问题的方法,通过配置VM arguments参数来解决。同时提供了相关代码示例。

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

这是解压过程的代码

import java.io.*;

import org.apache.hadoop.conf.Configuration;
import org.apache.hadoop.fs.Path;
import org.apache.hadoop.io.IOUtils;
import org.apache.hadoop.io.compress.*;


public class TestDecompression {

	public static void main(String[] args) throws FileNotFoundException, IOException {
		String file = "/home/hadoop/zlib.tar.gz";
		Configuration conf = new Configuration();
		CompressionCodecFactory codecFactory = new CompressionCodecFactory(conf);
		CompressionCodec codec = codecFactory.getCodec(new Path(file));
		CompressionInputStream in = codec.createInputStream(new FileInputStream(new File(file)));
		FileOutputStream out = new FileOutputStream(new File(codecFactory.removeSuffix(file, codec.getDefaultExtension())));
		IOUtils.copyBytes(in, out, 4096);
		in.close();
		out.close();
	}

}

运行时出现下列错误

14/04/24 22:00:59 WARN util.NativeCodeLoader: Unable to load native-hadoop library for your platform... using builtin-java classes where applicable

原因是因为没有找到native库,需要在运行配置中配置native的路径。解决方法是右键Run As->Run Configurations->Arguments->VM arguments中写入libhadoop.so和libSnappy.so的路径即可。

-Djava.library.path=/home/hadoop/hadoop-1.2.1/lib/native/Linux-amd64-64:/usr/local/lib

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值