Java API 操作 HDFS

实现功能

在HDFS文件系统中实现

  • 创建目录
  • 上传文件
  • 下载文件
  • 列出某个目录下所有文件
  • 读取某个文件的数据

详细步骤

1.Windows安装jdk和eclipse
完成Java环境部署
详情可以参考:java初学者Win 10下eclipse的安装教程(超级详细)
2.新建java工程
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
3.导入Hadoop开发包
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
4.新建包
在这里插入图片描述
在这里插入图片描述
新建类
在这里插入图片描述
在这里插入图片描述
5.编程开发

package com.xf.hdfs;

import java.io.IOException;

import org.apache.hadoop.conf.Configuration;
import org.apache.hadoop.fs.FSDataInputStream;
import org.apache.hadoop.fs.FileStatus;
import org.apache.hadoop.fs.FileSystem;
import org.apache.hadoop.fs.Path;
import org.apache.hadoop.io.IOUtils;

public class hdfTest {

     public static FileSystem fs = null;
	
//得到fs对象
  public static void Info(){
	
	  try {
		  Configuration conf = new Configuration();
		  conf.set("fs.defaultFS", "hdfs://s100");
		  conf.set("yarn.resourcemanager.hostname", "s100");
		fs = FileSystem.get(conf);
	} catch (IOException e) {
		e.printStackTrace();
	}
	  
  }

  //创建目录
  public static void MkdirPath(){
	  Path path = new Path("/test");
	  
	  try {
		  
		  if(fs.exists(path)){
			  
			  System.out.println(path.toString() + "已经存在 !");
		  }else{
			  
			  boolean mkdirs = fs.mkdirs(path);
			  if(mkdirs){
				  System.out.println("创建成功!");
			  }else{
				  System.out.println("创建失败!");
			  }
		  }
		  
		  
//		 fs.close();
	} catch (Exception e) {
		e.printStackTrace();
	} 
	  
  }
	
  //上传目录到HDFS
  public static void PutFile(){
	  
	 Path LocalPath = new Path("file:///d:/wc.txt");
	 
	 Path HdfsPath = new Path("/test/");
	 
	  try {
		
		  fs.copyFromLocalFile(LocalPath, HdfsPath);
		  System.out.println("上传完成!");
//		  fs.close();
	} catch (IOException e) {
		e.printStackTrace();
	}
	  
  }
  
  //下载目录到本地
  public static void GetFile(){
	  
	  Path HdfsPath = new Path("/test/wc.txt");

	  Path LocalPath = new Path("file:///e:/");
		 
	  try {
		fs.copyToLocalFile(HdfsPath, LocalPath);
		System.out.println("下载完成!");
//		fs.close();
	} catch (IOException e) {
		e.printStackTrace();
	}
  }
	
  //查看目录文件
  public static void ListPath(){
	  Path path = new Path("/");
	  try {
		  if(fs.exists(path)){
			  FileStatus[] listStatus = fs.listStatus(path);
			  if(listStatus.length == 0 ){
				  System.out.println("目录为空!");
			  }else{
				  for(FileStatus file : listStatus){
					//获取文件是否为目录和文件
			        	String isdir = file.isFile()?"文件":"目录";
			        	//获取副本数
				        short replication = file.getReplication();
				        //获取权限
				        String permisssion = file.getPermission().toString();
				        //获取文件大小
				        long len = file.getLen();
				        //获取路径
				        String path1 = file.getPath().getName().toString();
				        System.out.println(isdir + "\t" + permisssion + "\t" 
				        		+replication +"\t" + len + "\t" + path1);       
				  }
			  }
			  fs.close();
		  }else{
			  System.out.println("目录不存在!");
		  }
	} catch (Exception e) {
		e.printStackTrace();
	} 
	   
  }

  //读取文件内容
  public static void RadeFile(){
	
	  try {
		  
		Path path = new Path("/wc/wc.txt");  
		  
		if(fs.exists(path)){
			if(fs.isFile(path)){
				
			     FSDataInputStream open = fs.open(path);
			                       //输入流  输出流       缓冲区大小 是否关闭流
			     IOUtils.copyBytes(open, System.out, 4096, true);
			}
			else{
				System.out.println(path.toString()+ "不是文件");
			}
		}
		else{
			System.out.println("文件不存在");
		}
		
		
	} catch (Exception e) {
		e.printStackTrace();
	}
	  
  }
  
  
  
  public static void main(String[] args) {
	
	  Info();
//	  MkdirPath();
//	  ListPath();
//	  PutFile();
//	  GetFile();
	  RadeFile();
}
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

oifengo

你的鼓励将是我创作的最大动力

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

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

打赏作者

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

抵扣说明:

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

余额充值