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();
    }
    }
    }

  • 相关阅读:
    poj 1679 The Unique MST(次小生成树)
    利用微软翻译API做自己的翻译的工具(java)
    第一次用hql语句显示:QuerySyntaxException
    解决java用url中读取html源码时的乱码问题
    用java写的TrieTree
    OpenSessionInViewFilter失效问题
    windows下hadoop伪分布式模式开发环境的搭建(Cygwin)以及Eclipse集成开发环境下的搭建
    毕业设计想做一个垂直搜索引擎,关于手机方面
    struts2自定义拦截器
    根据地区和时区获取当地时间
  • 原文地址:https://www.cnblogs.com/ydy1/p/9733731.html
Copyright © 2011-2022 走看看