zoukankan      html  css  js  c++  java
  • hdfs

     

    package cn.edu.zucc.hdfs;

    import java.io.FileInputStream;

    import java.io.IOException; import org.apache.hadoop.conf.Configuration;

    import org.apache.hadoop.fs.FSDataOutputStream;

     import org.apache.hadoop.fs.FileSystem;

    import org.apache.hadoop.fs.Path;

    public class CopyFromLocalFile {

    /** * 判断路径是否存在  */

    public static boolean test(Configuration conf, String path) {

    try (FileSystem fs = FileSystem.get(conf))

    {

    return fs.exists(new Path(path));

    } catch (IOException e) {

    e.printStackTrace();
    return false;
    }
    }

    /**
    * 复制文件到指定路径 若路径已存在,则进行覆盖
    */
    public static void copyFromLocalFile(Configuration conf,
    String localFilePath, String remoteFilePath) {
    Path localPath = new Path(localFilePath);
    Path remotePath = new Path(remoteFilePath);
    try (FileSystem fs = FileSystem.get(conf)) {
    /* fs.copyFromLocalFile 第一个参数表示是否删除源文件,第二个参数表示是否覆盖 */
    fs.copyFromLocalFile(false, true, localPath, remotePath);
    } catch (IOException e) {
    e.printStackTrace();
    }

    }

    /**
    * 追加文件内容
    */
    public static void appendToFile(Configuration conf, String localFilePath,
    String remoteFilePath) {
    Path remotePath = new Path(remoteFilePath);
    try (FileSystem fs = FileSystem.get(conf);
    FileInputStream in = new FileInputStream(localFilePath);) {
    FSDataOutputStream out = fs.append(remotePath);
    byte[] data = new byte[1024];
    int read = -1;
    while ((read = in.read(data)) > 0) {
    out.write(data, 0, read);
    }
    out.close();
    } catch (IOException e) {
    e.printStackTrace();
    }
    }

    /**
    * 主函数
    */
    public static void main(String[] args) {
    Configuration conf = new Configuration();
    conf.set("fs.defaultFS", "hdfs://localhost:9000");
    String localFilePath = "/usr/local/hadoop/text.txt"; // 本地路径
    String remoteFilePath = "/user/tiny/text.txt"; // HDFS路径
    // String choice = "append"; // 若文件存在则追加到文件末尾
    String choice = "overwrite"; // 若文件存在则覆盖

    try {
    /* 判断文件是否存在 */
    boolean fileExists = false;
    if (CopyFromLocalFile.test(conf, remoteFilePath)) {
    fileExists = true;
    System.out.println(remoteFilePath + " 已存在.");
    } else {
    System.out.println(remoteFilePath + " 不存在.");
    }
    /* 进行处理 */
    if (!fileExists) { // 文件不存在,则上传
    CopyFromLocalFile.copyFromLocalFile(conf, localFilePath,
    remoteFilePath);
    System.out.println(localFilePath + " 已上传至 " + remoteFilePath);
    } else if (choice.equals("overwrite")) { // 选择覆盖
    CopyFromLocalFile.copyFromLocalFile(conf, localFilePath,
    remoteFilePath);
    System.out.println(localFilePath + " 已覆盖 " + remoteFilePath);
    } else if (choice.equals("append")) { // 选择追加
    CopyFromLocalFile.appendToFile(conf, localFilePath,
    remoteFilePath);
    System.out.println(localFilePath + " 已追加至 " + remoteFilePath);
    }
    } catch (Exception e) {
    e.printStackTrace();
    }
    }
    }

  • 相关阅读:
    AJAX请求 $.post方法的使用
    通过jQuery Ajax使用FormData对象上传文件
    iframe跨域访问
    js编码解码
    ajax头像上传
    无边框窗体和用户控件以及权限
    只开启一个窗体和进程以及多线程的操作
    通过一个窗体操作另一个窗体
    流和打印控件用法
    listview和简单的记事本操作
  • 原文地址:https://www.cnblogs.com/ydy1/p/9733731.html
Copyright © 2011-2022 走看看