IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 大数据 -> hadoop组件hdfs文件操作(javaapi形式) -> 正文阅读

[大数据]hadoop组件hdfs文件操作(javaapi形式)

记录一下自己写的java操作hdfs文件系统代码,留给学校的后人。
其中user/skl是hdfs的用户目录。

import java.io.*;
import java.net.URI;
import java.nio.charset.StandardCharsets;
import java.text.SimpleDateFormat;
import java.util.Scanner;

import org.apache.hadoop.conf.Configuration;
import org.apache.hadoop.fs.*;
import org.apache.hadoop.io.IOUtils;

public class MergeFile {
    
    private static InputStream input;
    private static OutputStream output;
    public static void upload() throws IOException {
        Configuration conf = new Configuration();
        conf.set("fs.defaultFS", "hdfs://localhost:9000");
        FileSystem fileSystem = FileSystem.get(conf);
        input = new FileInputStream("/usr/local/hadoop/file6.txt");
        output = fileSystem.create(new Path("/user/skl/file6.txt"));
        byte[] buffer = new byte[1024];
        int len = 0;
        while((len=input.read(buffer))!=-1){
            output.write(buffer,0,len);
        }
        output.flush();
        input.close();
        output.close();
    }
    public static void download() throws IOException {
        Configuration conf = new Configuration();
        conf.set("fs.defaultFS", "hdfs://localhost:9000");
        FileSystem fileSystem = FileSystem.get(conf);
        fileSystem.copyToLocalFile(false,new Path("/user/skl/file6.txt"),new Path("/usr/local/hadoop/"),true);
        fileSystem.close();
    }
    public static void textcat(String path) throws IOException {
        Configuration conf = new Configuration();
        conf.set("fs.defaultFS", "hdfs://localhost:9000");
        FileSystem fileSystem = FileSystem.get(conf);
        FSDataInputStream in=fileSystem.open(new Path(path));
        BufferedReader br=new BufferedReader(new InputStreamReader(in));
        String line="";
        while((line=br.readLine())!=null){
            System.out.println(line);
        }
        fileSystem.close();
    }
    public static void getAllDetail(String path) throws IOException {
        Configuration conf = new Configuration();
        conf.set("fs.defaultFS", "hdfs://localhost:9000");
        FileSystem fileSystem = FileSystem.get(conf);
        FileStatus[] fileList = fileSystem.listStatus(new Path(path));
        for(FileStatus file:fileList){
            if(file.isFile()){
                getdetail(file);
            }else{
                getAllDetail(file.getPath().toString());
            }
        }
        fileSystem.close();
    }
    public static void delete(String path) throws IOException {
        Configuration conf = new Configuration();
        conf.set("fs.defaultFS", "hdfs://localhost:9000");
        FileSystem fileSystem = FileSystem.get(conf);
        boolean del = fileSystem.delete(new Path(path));
        if(del){
            System.out.println("删除成功(>ω・*)ノ");
        }else{
            System.out.println("删除失败(〃′-ω・)");
        }
    }
    public static void append(String s1) throws IOException {
        Configuration conf = new Configuration();
        conf.set("fs.defaultFS", "hdfs://localhost:9000");
        FileSystem fileSystem = FileSystem.get(conf);
        FSDataOutputStream append = fileSystem.append(new Path("/user/skl/file5.txt"));
        append.write("追加的内容\n".getBytes(StandardCharsets.UTF_8));
        append.write(s1.getBytes(StandardCharsets.UTF_8));
        append.close();
        textcat("/user/skl/file5.txt");
    }
    public static void textappend() throws IOException {
        Configuration conf = new Configuration();
        conf.set("fs.defaultFS", "hdfs://localhost:9000");
        FileSystem fileSystem = FileSystem.get(conf);
        Scanner scanner = new Scanner(System.in);
        String s = scanner.next();
        if("添加到末尾".equals(s)){
            FSDataOutputStream append = fileSystem.append(new Path("/user/skl/file5.txt"));
            append.write("追加的内容".getBytes(StandardCharsets.UTF_8));
            append.close();
            textcat("/user/skl/file5.txt");
            fileSystem.close();
        }else if("添加到开头".equals(s)){
            FSDataInputStream in=fileSystem.open(new Path("/user/skl/file5.txt"));
            BufferedReader br=new BufferedReader(new InputStreamReader(in));
            String line="";
            String s1 = "";
            while((line=br.readLine())!=null){
                s1 += line;
                s1 += "\n";
            }
            delete("/user/skl/file5.txt");
            fileSystem.create(new Path("/user/skl/file5.txt"));
            fileSystem.close();
            append(s1);
        }else{
            System.out.println("请重新输入");
            textappend();
        }
        fileSystem.close();
    }
    public static void CreateandDelete() throws IOException {
        Configuration conf = new Configuration();
        conf.set("fs.defaultFS", "hdfs://localhost:9000");
        FileSystem fileSystem = FileSystem.get(conf);
        System.out.println("请输入您要进行的操作:");
        Scanner scanner = new Scanner(System.in);
        String require = scanner.next();
        if("删除".equals(require)){
            System.out.println("请输入您要删除的文件:");
            String path = scanner.next();
            delete(path);
        }else if("创建".equals(require)){
            System.out.println("请输入您要创建的文件:");
            String path = scanner.next();
            try {
                fileSystem.create(new Path(path));
            }catch (Exception e){
                System.out.println("抱歉,创建失败了");
            }
        }
        fileSystem.close();
    }
    public static void textmove() throws IOException {
        Configuration conf = new Configuration();
        conf.set("fs.defaultFS", "hdfs://localhost:9000");
        FileSystem fileSystem = FileSystem.get(conf);
        System.out.println("请输入您要移动的文件:");
        Scanner scanner = new Scanner(System.in);
        String root = scanner.next();
        System.out.println("请输入您要移动到的位置:");
        String dst = scanner.next();
        try {
            fileSystem.moveFromLocalFile(new Path(root),new Path(dst));
            System.out.println("移动成功!");
        }catch (Exception e){
            System.out.println("抱歉,移动失败,请重试");
            textmove();
        }
        fileSystem.close();
    }
    public static void main(String[] args) throws IOException {
        //上传文件
        upload();
        //从hdfs下载文件
        download();
        //打印文件内容到控制台(传參为路径)
        textcat();
        //获取文件详细说明,包括读写权限等
        getdetail();
        //获取传参路径下所有文件详细说明,有文件夹则递归处理
        getAllDetail("/user/skl/");
        //删除一个文件
        delete();
        //为文件追加内容,由用户写明是追加到头还是尾
        textappend();
        //创建或删除一个文件
        CreateandDelete();
        //将一个本地文件移动到文件系统,如果要在文件系统目录中移动,可以先下载到本地再上传到指定目录
        textmove();
    }
    public static void getdetail(FileStatus fileStatus) throws IOException {
        System.out.println("文件读写权限:"+fileStatus.getPermission());
        System.out.println("文件大小:"+fileStatus.getLen()+"字节");
        long timeStamp = fileStatus.getModificationTime();
        SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
        String date = format.format(timeStamp);
        System.out.println("文件创建时间:"+date);
        System.out.println("文件路径:"+fileStatus.getPath().toString());
    }
}



  大数据 最新文章
实现Kafka至少消费一次
亚马逊云科技:还在苦于ETL?Zero ETL的时代
初探MapReduce
【SpringBoot框架篇】32.基于注解+redis实现
Elasticsearch:如何减少 Elasticsearch 集
Go redis操作
Redis面试题
专题五 Redis高并发场景
基于GBase8s和Calcite的多数据源查询
Redis——底层数据结构原理
上一篇文章      下一篇文章      查看所有文章
加:2022-04-04 12:18:09  更:2022-04-04 12:21:03 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/16 16:06:26-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码