java讀寫HDFS


package cn.test.hdfs;
 
import java.io.IOException;
import java.net.URI;
import java.net.URISyntaxException;
 
import org.apache.hadoop.conf.Configuration;
import org.apache.hadoop.fs.FSDataInputStream;
import org.apache.hadoop.fs.FSDataOutputStream;
import org.apache.hadoop.fs.FileStatus;
import org.apache.hadoop.fs.FileSystem;
import org.apache.hadoop.fs.FileUtil;
import org.apache.hadoop.fs.Path;
import org.apache.hadoop.io.IOUtils;
 
public class OperateHdfs {
    
     //讀取hdfs上的文件內容
     public static void ReadFromHDFS(String file) throws IOException 
    { 
        Configuration conf = new Configuration(); 
        FileSystem fs = FileSystem.get(URI.create(file), conf); 
        Path path = new Path(file); 
        FSDataInputStream in = fs.open(path); 
         
        IOUtils.copyBytes(in, System.out, 4096, true); 
        //使用FSDataInoutStream的read方法會將文件內容讀取到字節流中並返回 
        /**
         * FileStatus stat = fs.getFileStatus(path);
      // create the buffer
       byte[] buffer = new byte[Integer.parseInt(String.valueOf(stat.getLen()))];
       is.readFully(0, buffer);
       is.close();
             fs.close();
       return buffer;
         */ 
    }
    
     //在指定位置新建一個文件,並寫入字符 
    public static void WriteToHDFS(String file, String words) throws IOException, URISyntaxException 
    { 
        Configuration conf = new Configuration(); 
        FileSystem fs = FileSystem.get(URI.create(file), conf); 
        Path path = new Path(file); 
        FSDataOutputStream out = fs.create(path);   //創建文件
       
        //兩個方法都用於文件寫入,好像一般多使用后者 
        //out.writeBytes(words);   
        out.write(words.getBytes("UTF-8")); 
         
        out.close(); 
        //如果是要從輸入流中寫入,或是從一個文件寫到另一個文件(此時用輸入流打開已有內容的文件) 
        //可以使用如下IOUtils.copyBytes方法。 
        //FSDataInputStream in = fs.open(new Path(args[0])); 
        //IOUtils.copyBytes(in, out, 4096, true)        //4096為一次復制塊大小,true表示復制完成后關閉流 
    }
    
    //刪除hdfs上的文件
    public static void DeleteHDFSFile(String file) throws IOException 
    { 
        Configuration conf = new Configuration(); 
        FileSystem fs = FileSystem.get(URI.create(file), conf); 
        Path path = new Path(file); 
        //查看fs的delete API可以看到三個方法。deleteonExit實在退出JVM時刪除,下面的方法是在指定為目錄是遞歸刪除 
        fs.delete(path,true); 
        fs.close(); 
    }
   
    //上傳本地文件到hdfs
    public static void UploadLocalFileHDFS(String src, String dst) throws IOException 
    { 
        Configuration conf = new Configuration(); 
        FileSystem fs = FileSystem.get(URI.create(dst), conf); 
        Path pathDst = new Path(dst); 
        Path pathSrc = new Path(src); 
         
        fs.copyFromLocalFile(pathSrc, pathDst); 
        fs.close(); 
    }
   
    //顯示目錄下所有文件
    public static void ListDirAll(String DirFile) throws IOException 
    { 
        Configuration conf = new Configuration(); 
        FileSystem fs = FileSystem.get(URI.create(DirFile), conf); 
        Path path = new Path(DirFile); 
         
        FileStatus[] status = fs.listStatus(path); 
        //方法1   
        for(FileStatus f: status) 
        { 
            System.out.println(f.getPath().toString());   
        } 
        //方法2   
        Path[] listedPaths = FileUtil.stat2Paths(status);   
        for (Path p : listedPaths){  
          System.out.println(p.toString()); 
        } 
    }
   
     public static void main(String[] args) throws IOException, URISyntaxException {
          String file = "hdfs://192.168.13.20:9000/user/hadoop/test.txt";
         
          String localFile = "C:/Users/lenovo/Desktop/test.txt";
         
          //String words = "This words is to write into file!\n";
          String words = "測試向HDFS里面寫文件!";
         
        WriteToHDFS(file, words);
          //ReadFromHDFS(file);
          //DeleteHDFSFile(file);
         
          //UploadLocalFileHDFS(localFile, file);
         
          String path = "hdfs://192.168.13.20:9000/user/hadoop/";
          ListDirAll(path);
     }
}


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM