zoukankan      html  css  js  c++  java
  • 大数据入门——java API对HDFS的操作

    package com.imooc.hadoop.hdfs;
    
    import org.apache.hadoop.conf.Configuration;
    import org.apache.hadoop.fs.*;
    import org.apache.hadoop.io.IOUtils;
    import org.apache.hadoop.util.Progressable;
    import org.junit.After;
    import org.junit.Before;
    import org.junit.Test;
    
    import java.io.BufferedInputStream;
    import java.io.File;
    import java.io.FileInputStream;
    import java.io.InputStream;
    import java.net.URI;
    
    /**
     * Hadoop HDFS Java API 操作
     */
    public class HDFSApp {
    
        public static final String HDFS_PATH = "hdfs://localhost:9000";//HDFS配置文件中填写的地址
    
        FileSystem fileSystem = null;
        Configuration configuration = null;
    
    
        /**
         * 创建HDFS目录
         */
        @Test
        public void mkdir() throws Exception {
            fileSystem.mkdirs(new Path("/hdfsapi/test"));
        }
    
        /**
         * 创建文件
         */
        @Test
        public void create() throws Exception {
            FSDataOutputStream output = fileSystem.create(new Path("/hdfsapi/test/a.txt"));
            output.write("hello hadoop".getBytes());
            output.flush();
            output.close();
        }
    
        /**
         * 查看HDFS文件的内容
         */
        @Test
        public void cat() throws Exception {
            FSDataInputStream in = fileSystem.open(new Path("/hdfsapi/test/a.txt"));
            IOUtils.copyBytes(in, System.out, 1024);
            in.close();
        }
    
    
        /**
         * 重命名
         */
        @Test
        public void rename() throws Exception {
            Path oldPath = new Path("/hdfsapi/test/a.txt");
            Path newPath = new Path("/hdfsapi/test/b.txt");
            fileSystem.rename(oldPath, newPath);
        }
    
        /**
         * 上传文件到HDFS
         *
         * @throws Exception
         */
        @Test
        public void copyFromLocalFile() throws Exception {
            Path localPath = new Path("/Users/rocky/data/hello.txt");
            Path hdfsPath = new Path("/hdfsapi/test");
            fileSystem.copyFromLocalFile(localPath, hdfsPath);
        }
    
        /**
         * 上传文件到HDFS
         */
        @Test
        public void copyFromLocalFileWithProgress() throws Exception {
            InputStream in = new BufferedInputStream(
                    new FileInputStream(
                            new File("/Users/rocky/source/spark-1.6.1/spark-1.6.1-bin-2.6.0-cdh5.5.0.tgz")));
    
            FSDataOutputStream output = fileSystem.create(new Path("/hdfsapi/test/spark-1.6.1.tgz"),
                    new Progressable() {
                        public void progress() {
                            System.out.print(".");  //带进度提醒信息
                        }
                    });
    
    
            IOUtils.copyBytes(in, output, 4096);
        }
    
    
        /**
         * 下载HDFS文件
         */
        @Test
        public void copyToLocalFile() throws Exception {
            Path localPath = new Path("/Users/rocky/tmp/h.txt");
            Path hdfsPath = new Path("/hdfsapi/test/hello.txt");
            fileSystem.copyToLocalFile(hdfsPath, localPath);
        }
    
        /**
         * 查看某个目录下的所有文件
         */
        @Test
        public void listFiles() throws Exception {
            FileStatus[] fileStatuses = fileSystem.listStatus(new Path("/"));
    
            for(FileStatus fileStatus : fileStatuses) {
                String isDir = fileStatus.isDirectory() ? "文件夹" : "文件";
                short replication = fileStatus.getReplication();
                long len = fileStatus.getLen();
                String path = fileStatus.getPath().toString();
    
                System.out.println(isDir + "	" + replication + "	" + len + "	" + path);
            }
    
        }
    
        /**
         * 删除
         */
        @Test
        public void delete() throws Exception{
            fileSystem.delete(new Path("/"), true);
        }
    
    
        @Before
        public void setUp() throws Exception {
            System.out.println("HDFSApp.setUp");
            configuration = new Configuration();
            fileSystem = FileSystem.get(new URI(HDFS_PATH), configuration, "hadoop");
        }
    
        @After
        public void tearDown() throws Exception {
            configuration = null;
            fileSystem = null;
    
            System.out.println("HDFSApp.tearDown");
        }
    
    }
  • 相关阅读:
    染色法判定二分图
    Kruskal算法求最小生成树
    Prim算法求最小生成树
    Floyd算法求多源最短路
    spfa判断负环
    java 线程的使用
    java IO基础
    数据库 EXISTS与NOT EXISTS
    数据库 何为相关查询和不相关查询?
    数据库的基础知识
  • 原文地址:https://www.cnblogs.com/aishanyishi/p/9479684.html
Copyright © 2011-2022 走看看