实验二 熟悉常用的HDFS操作

实验2

熟悉常用的HDFS操作

 

 

1.实验目的

1理解HDFSHadoop体系结构中的角色;

2熟练使用HDFS操作常用的Shell命令;

3熟悉HDFS操作常用的Java API

2. 实验平台

1操作系统:Linux(建议Ubuntu16.04Ubuntu18.04);

2Hadoop版本:3.1.3

3JDK版本:1.8

4Java IDEEclipse

3. 实验步骤

(一)编程实现以下功能,并利用Hadoop提供的Shell命令完成相同任务:

(1) HDFS中上传任意文本文件,如果指定的文件在HDFS中已经存在,则由用户来指定是追加到原有文件末尾还是覆盖原有的文件;

 

Shell命令:hadoop fs -put localfile.txt /user/hadoop/

 

 

Java代码

 

import org.apache.hadoop.conf.Configuration;  

import org.apache.hadoop.fs.FileSystem;  

import org.apache.hadoop.fs.Path;  

 

public class HDFSUpload {  

    public static void uploadFile(String localFilePath, String hdfsFilePath) throws Exception {  

        Configuration conf = new Configuration();  

        FileSystem fs = FileSystem.get(conf);  

        Path srcPath = new Path(localFilePath);  

        Path destPath = new Path(hdfsFilePath);  

        fs.copyFromLocalFile(srcPath, destPath);  

        fs.close();  

    }  

}

 

(2) HDFS中下载指定文件,如果本地文件与要下载的文件名称相同,则自动对下载的文件重命名;

Shell命令:hadoop fs -get /user/hadoop/test.txt /local/path/test.txt

 

 

Java代码

 

public static void downloadFile(String hdfsFilePath, String localFilePath) throws Exception {  

    Configuration conf = new Configuration();  

    FileSystem fs = FileSystem.get(conf);  

    Path hdfsPath = new Path(hdfsFilePath);  

    Path localPath = new Path(localFilePath);  

    fs.copyToLocalFile(hdfsPath, localPath);  

    fs.close();  

}

(3) HDFS中指定文件的内容输出到终端中;

 

Shell命令:hadoop fs -cat /user/hadoop/test.txt

 

 

 

Java代码

 

public static void readFile(String hdfsFilePath) throws Exception {  

    Configuration conf = new Configuration();  

    FileSystem fs = FileSystem.get(conf);  

    FSDataInputStream inputStream = fs.open(new Path(hdfsFilePath));  

    BufferedReader br = new BufferedReader(new InputStreamReader(inputStream));  

    String line;  

    while ((line = br.readLine()) != null) {  

        System.out.println(line);  

    }  

    br.close();  

    fs.close();  

}

(4) 显示HDFS中指定的文件的读写权限、大小、创建时间、路径等信息;

 

Shell命令:hadoop fs -ls /user/hadoop/test.txt

 

 

Java代码

 

public static void getFileInfo(String hdfsFilePath) throws Exception {  

    Configuration conf = new Configuration();  

    FileSystem fs = FileSystem.get(conf);  

    FileStatus fileStatus = fs.getFileStatus(new Path(hdfsFilePath));  

    System.out.println("Path: " + fileStatus.getPath());  

    System.out.println("Size: " + fileStatus.getLen());  

    System.out.println("Permissions: " + fileStatus.getPermission());  

    System.out.println("Modification Time: " + fileStatus.getModificationTime());  

    fs.close();  

}

(5) 给定HDFS中某一个目录,输出该目录下的所有文件的读写权限、大小、创建时间、路径等信息,如果该文件是目录,则递归输出该目录下所有文件相关信息;

 

Shell命令:hadoop fs -ls -R /user/hadoop/

 

Java代码

 

public static void listDirectory(String hdfsDirPath) throws Exception {  

    Configuration conf = new Configuration();  

    FileSystem fs = FileSystem.get(conf);  

    RemoteIterator<LocatedFileStatus> fileStatusListIterator = fs.listFiles(new Path(hdfsDirPath), true);  

    while (fileStatusListIterator.hasNext()) {  

        LocatedFileStatus fileStatus = fileStatusListIterator.next();  

        System.out.println("Path: " + fileStatus.getPath());  

        System.out.println("Size: " + fileStatus.getLen());  

        System.out.println("Permissions: " + fileStatus.getPermission());  

        System.out.println("Modification Time: " + fileStatus.getModificationTime());  

    }  

    fs.close();  

}

(6) 提供一个HDFS内的文件的路径,对该文件进行创建和删除操作。如果文件所在目录不存在,则自动创建目录;

Shell命令: hadoop fs -mkdir -p /user/hadoop/newdir  

hadoop fs -touchz /user/hadoop/newdir/newfile.txt  

hadoop fs -rm /user/hadoop/newdir/newfile.txt

 

 

 

Java代码

 

public static void createFile(String hdfsFilePath) throws Exception {  

    Configuration conf = new Configuration();  

    FileSystem fs = FileSystem.get(conf);  

    FSDataOutputStream outputStream = fs.create(new Path(hdfsFilePath));  

    outputStream.close();  

    fs.close();  

}  

 

public static void deleteFile(String hdfsFilePath) throws Exception {  

    Configuration conf = new Configuration();  

    FileSystem fs = FileSystem.get(conf);  

    fs.delete(new Path(hdfsFilePath), false);  

    fs.close();  

}

 

(7) 提供一个HDFS的目录的路径,对该目录进行创建和删除操作。创建目录时,如果目录文件所在目录不存在,则自动创建相应目录;删除目录时,由用户指定当该目录不为空时是否还删除该目录;

 

Shell命令: hadoop fs -mkdir -p /user/hadoop/newdir  

hadoop fs -rmdir /user/hadoop/newdir

 

 

Java代码

 

public static void createDirectory(String hdfsDirPath) throws Exception {  

    Configuration conf = new Configuration();  

    FileSystem fs = FileSystem.get(conf);  

    fs.mkdirs(new Path(hdfsDirPath));  

    fs.close();  

}  

 

public static void deleteDirectory(String hdfsDirPath, boolean recursive) throws Exception {  

    Configuration conf = new Configuration();  

    FileSystem fs = FileSystem.get(conf);  

    fs.delete(new Path(hdfsDirPath), recursive);  

    fs.close();  

}

(8) HDFS中指定的文件追加内容,由用户指定内容追加到原有文件的开头或结尾;

 

Shell命令:echo "new content" | hadoop fs -appendToFile - /user/hadoop/test.txt

 

 

Java代码

 

public static void appendToFile(String hdfsFilePath, String content) throws Exception {  

    Configuration conf = new Configuration();  

    FileSystem fs = FileSystem.get(conf);  

    FSDataOutputStream outputStream = fs.append(new Path(hdfsFilePath));  

    outputStream.writeBytes(content);  

    outputStream.close();  

    fs.close();  

}

(9) 删除HDFS中指定的文件;

 

Shell命令:hadoop fs -rm /user/hadoop/test.txt

 

 

 

Java代码

public static void removeFile(String hdfsFilePath) throws Exception {  

    Configuration conf = new Configuration();  

    FileSystem fs = FileSystem.get(conf);  

    fs.delete(new Path(hdfsFilePath), false);  

    fs.close();  

}

(10) HDFS中,将文件从源路径移动到目的路径。

 

Shell命令:hadoop fs -mv /user/hadoop/test.txt /user/hadoop/moved_test.txt

 

Java代码

 

public static void moveFile(String sourcePath, String destPath) throws Exception {  

    Configuration conf = new Configuration();  

    FileSystem fs = FileSystem.get(conf);  

    fs.rename(new Path(sourcePath), new Path(destPath));  

    fs.close();  

}

 

(二)编程实现一个类“MyFSDataInputStream”,该类继承“org.apache.hadoop.fs.FSDataInputStream”,要求如下:实现按行读取HDFS中指定文件的方法“readLine()”,如果读到文件末尾,则返回空,否则返回文件一行的文本。

 

import org.apache.hadoop.fs.FSDataInputStream;  

import org.apache.hadoop.fs.FileSystem;  

import org.apache.hadoop.conf.Configuration;  

import java.io.BufferedReader;  

import java.io.InputStreamReader;  

 

public class MyFSDataInputStream extends FSDataInputStream {  

    public MyFSDataInputStream(FileSystem fs, Path path) throws IOException {  

        super(fs.open(path));  

    }  

 

    public String readLine() throws IOException {  

        BufferedReader br = new BufferedReader(new InputStreamReader(this));  

        return br.readLine();  

    }  

}

 

(三)查看Java帮助手册或其它资料,用“java.net.URL”“org.apache.hadoop.fs.FsURLStreamHandlerFactory”编程完成输出HDFS中指定文件的文本到终端中。

 

 

import java.net.URL;  

import java.net.URLConnection;  

import org.apache.hadoop.fs.FsURLStreamHandlerFactory;  

 

public class HDFSFileReader {  

    static {  

        URL.setURLStreamHandlerFactory(new FsURLStreamHandlerFactory());  

    }  

 

    public static void main(String[] args) throws Exception {  

        URL url = new URL("hdfs://namenode:port/user/hadoop/test.txt");  

        URLConnection connection = url.openConnection();  

        BufferedReader in = new BufferedReader(new InputStreamReader(connection.getInputStream()));  

        String line;  

        while ((line = in.readLine()) != null) {  

            System.out.println(line);  

        }  

        in.close();  

    }  

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/861602.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

风继续吹

风继续吹 一、学期回顾 1.1 回顾你对于软件工程课程的想象 在学期初,我对软件工程课程没多少了解,觉得它应该和之前的部分课程一样,老师讲解一些编程语法然后布置作业,后期周末去实验室编程完成实验,期末再复习一下这门课编写代码作答题目这门课也就过去了。但实际上的软工…

初识Spring -2024/12/30

Spring优点Spring FrameworkCore Container:核心容器 AOP:面向切面编程 Aspects: AOP思想实现 Data Access :数据访问 Data Integration: 数据集成IoC,IoC容器,Bean,DI导入依赖 <dependency><groupId>org.springframework</groupId><artifactId>spring…

【Leetcode】链表

链表 160. 相交链表 206. 反转链表 234. 回文链表 141. 环形链表 142. 环形链表 II 21. 合并两个有序链表 2. 两数相加 19. 删除链表的倒数第 N 个结点 25. K 个一组翻转链表 138. 随机链表的复制 148. 排序链表 23. 合并 K 个升序链表 146. LRU 缓存 160. 相交链表 方法一:模…

The end-软工实践之旅

一、学期回顾 1.1 回顾你对于软件工程课程的想象 在学期初,我眼中的软件工程课程是一门教大家如何从零开始开发软件,实际上大部分知识都需要自己学习掌握,软工课着重系统地学习软件开发流程,掌握从需求分析、设计、编码到测试的全套本领,雕琢出实用且受欢迎的软件作品。 如…

‍禁止蕉绿——软件工程个人总结

这个作业属于哪个课程 软件工程这个作业要求在哪里 软件工程2024秋——个人总结作业这个作业的目标 学期总结学号 102202150🙅‍禁止焦虑——2024秋软工实践个人总结博客 一、🎞️学期回顾🎞️ 1.1 💭回顾你对于软件工程课程的想象💭 刚开始我对软件工程的理解只局限…

《计算机组成及汇编语言原理》阅读笔记:p133-p159

《计算机组成及汇编语言原理》学习第 11 天,p133-p159 总结,总计 27 页。 一、技术总结 1.segment (1)定义 Broadly speaking, a contiguous section of memory. More specifically, a section of memory referenced by one of the segment registers of the 80x86 family.…

并非银河战舰,皮划艇也能启航

目录标题一、学期回顾1.1 回顾对软工课程的想象1.2 回顾在这门课程中的投入与产出1.3 最印象深刻的答辩二、总结收获2.1 自己的人月神话2.2 学习到的新技术和生产力工具2.3 除了技术之外,还得到了哪些提升2.4 对下一届实践的建议三、致谢这个作业属于哪个课程 https://edu.cnb…

GitHub Copilot免费上线!快速上手指南与功能解析

GitHub Copilot在12月宣布免费订阅,不再限制学生和开源项目的维护者了,对于习惯白嫖的开发者来说无疑多了一个选择。 价格和功能 免费版目前可以选择Claude 3.5 Sonnet或GPT-4o模型,每月可以调用 2000 次生成和补全代码,以及 50 次聊天信息。快速开始注册一个GIthub账号 VS…

C#/.NET/.NET Core技术前沿周刊 | 第 19 期(2024年12.23-12.29)

前言 C#/.NET/.NET Core技术前沿周刊,你的每周技术指南针!记录、追踪C#/.NET/.NET Core领域、生态的每周最新、最实用、最有价值的技术文章、社区动态、优质项目和学习资源等。让你时刻站在技术前沿,助力技术成长与视野拓宽。欢迎投稿、推荐或自荐优质文章、项目、学习资源等…

Notepad – – (文本编辑器) v3.0.0 官方版

这是一个使用C++编写的文本编辑器Notepad- -,可以支持Win/Linux/Mac平台。 我们的目标是要替换Notepad++,重点在国产Uos系统、Mac 系统上发展。 一个支持windows/linux/mac的文本编辑器,目标是要替换notepad++,来自中国。 对比Notepad++而言,我们的优势是可以跨平台,支持l…

【Node.js编程】实现GETPOST请求

创建基本的服务器 const express = require(express); const indexRouter = require(./router); // 引入路由 const app = express(); const port = 3000; // 挂载路由 app.use(/api, indexRouter); app.listen(port, () => {console.log(`Server is running on http://loca…

openEuler RISC-V上磁盘I/O性能测试的IOZone实例

IOZone 是一个广泛使用的文件系统性能基准测试工具,旨在评估磁盘 I/O 性能。它能够测试各种类型的文件操作,包括顺序读写、随机读写、重载(re-write)、读取已写入的数据等。通过这些测试,IOZone 可以帮助用户了解不同文件系统和存储设备的性能特点,从而为选择合适的硬件和…