java操作hdfs文件系统

本文介绍如何使用Hadoop进行文件系统的配置及文件的读写操作。通过具体示例展示了如何获取文件系统实例、如何从本地文件系统写入文件到Hadoop文件系统以及如何从Hadoop文件系统中读取文件。

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

 ads:

关注以下公众号查看更多文章

maven做如下配置

groupId:org.apache.hadoop
artifactId:hadoop-client

version:${hadoop.version}

代码如下:

获取文件系统

	private static FileSystem getFileSystem() throws Exception{
		Configuration conf = new Configuration();
		FileSystem fileSystem = FileSystem.get(conf);
		return fileSystem;
	}

写文件

	private static void write(String toFolder) throws Exception{
		FileSystem fileSystem = getFileSystem();
		fileSystem.delete(new Path(toFolder), true);
		FileInputStream in = null;
		FSDataOutputStream out = null;
		try {
			in = new FileInputStream(new File("E:\\1804211523.txt"));
			out = fileSystem.create(new Path(toFolder));
			IOUtils.copyBytes(in, out, 4096, false);
		} catch (Exception e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}finally{
			IOUtils.closeStream(in);
			IOUtils.closeStream(out);
		}
		
	}

读取文件:

	private static void read(String filePath) throws Exception{
		//预处理,删除文件加
		FileSystem fileSystem = getFileSystem();
		Path path = new Path(filePath);
		FSDataInputStream inStream = null;
		//用文件系统操作路径
		try{
			inStream = fileSystem.open(path);
			IOUtils.copyBytes(inStream, System.out, 4096, false);
		}catch(Exception e){
			e.printStackTrace();
		}finally{
			IOUtils.closeStream(inStream);
		}
	}

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

ApiChain

扔个包子砸我一下吧~

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值