编写Java代码对HDFS进行增删改查操作代码实例
作者:Alvis zhao 发布时间:2023-07-08 11:46:42
标签:Java,hdfs,增删改查
本文实例为大家分享了Java代码对HDFS进行增删改查操作的具体代码,供大家参考,具体内容如下
import java.io.File;
import java.io.FileOutputStream;
import java.io.IOException;
import java.net.URI;
import org.apache.commons.compress.utils.IOUtils;
import org.apache.hadoop.conf.Configuration;
import org.apache.hadoop.fs.BlockLocation;
import org.apache.hadoop.fs.FSDataInputStream;
import org.apache.hadoop.fs.FSDataOutputStream;
import org.apache.hadoop.fs.FileStatus;
import org.apache.hadoop.fs.FileSystem;
import org.apache.hadoop.fs.Path;
public class FileOpreation {
public static void main(String[] args) throws IOException {
//CreateFile();
//DeleteFile();
//CopyFileToHDFS();
//MkDirs();
//DelDirs();
ListDirectory();
DownLoad();
}
public static void CreateFile() throws IOException {
String uri = "hdfs://Alvis:9000";
Configuration configuration =new Configuration();
FileSystem fSystem = FileSystem.get(URI.create(uri), configuration);
byte[] file_content_buff="hello hadoop world, test write file !\n".getBytes();
Path dfs = new Path("/home/test.txt");
FSDataOutputStream outputStream = fSystem.create(dfs);
outputStream.write(file_content_buff.length);
}
public FileOpreation() {
// TODO Auto-generated constructor stub
}public static void DeleteFile() throws IOException {
String uri = "hdfs://Alvis:9000";
Configuration configuration =new Configuration();
FileSystem fSystem = FileSystem.get(URI.create(uri), configuration);
Path deletf = new Path("/home/test.txt");
boolean delResult = fSystem.delete(deletf,true);
System.out.println(delResult==true?"删除成功":"删除失败");
}
public static void CopyFileToHDFS() throws IOException {
String uri = "hdfs://Alvis:9000";
Configuration configuration =new Configuration();
FileSystem fSystem = FileSystem.get(URI.create(uri), configuration);
Path src = new Path("E:\\SerializationTest\\APITest.txt");
Path dest_src = new Path("/home");
fSystem.copyFromLocalFile(src, dest_src);
}
public static void MkDirs() throws IOException {
String uri = "hdfs://Alvis:9000";
Configuration configuration =new Configuration();
FileSystem fSystem = FileSystem.get(URI.create(uri), configuration);
Path src = new Path("/Test");
fSystem.mkdirs(src);
}
public static void DelDirs() throws IOException {
String uri = "hdfs://Alvis:9000";
Configuration configuration = new Configuration();
FileSystem fSystem = FileSystem.get(URI.create(uri), configuration);
Path src = new Path("/Test");
fSystem.delete(src);
}
public static void ListDirectory() throws IOException {
String uri = "hdfs://Alvis:9000";
Configuration configuration = new Configuration();
FileSystem fSystem = FileSystem.get(URI.create(uri), configuration);
FileStatus[] fStatus = fSystem.listStatus(new Path("/output"));
for(FileStatus status : fStatus)
if (status.isFile()) {
System.out.println("文件路径:"+status.getPath().toString());
System.out.println("文件路径 getReplication:"+status.getReplication());
System.out.println("文件路径 getBlockSize:"+status.getBlockSize());
BlockLocation[] blockLocations = fSystem.getFileBlockLocations(status, 0, status.getBlockSize());
for(BlockLocation location : blockLocations){
System.out.println("主机名:"+location.getHosts()[0]);
System.out.println("主机名:"+location.getNames()[0]);
}
}
else {
System.out.println("directory:"+status.getPath().toString());
}
}
public static void DownLoad() throws IOException {
Configuration configuration = new Configuration();
configuration.set("fs.defaultFS", "hdfs://Alvis:9000");
FileSystem fSystem =FileSystem.get(configuration);
FSDataInputStream inputStream =fSystem.open( new Path("/input/wc.jar"));
FileOutputStream outputStream = new FileOutputStream(new File("E:\\LearnLife\\DownLoad\\wc.jar"));
IOUtils.copy(inputStream, outputStream);
System.out.println("下载成功!");
}
}
思想:
一、定义虚拟机接口
二、先拿到HDFS远程调用接口对象Configuration
三、定义分布式文件系统FileSystem对象获取对象
四、给定路径
五、用FileSystem对象调用操作
以上所述是小编给大家介绍的Java代码对HDFS进行增删改查操作详解整合网站的支持!
来源:https://blog.csdn.net/qq_41395106/article/details/89036014


猜你喜欢
- 一、运行class文件执行带main方法的class文件,命令行为:java <CLASS文件名>注意:CLASS文件名不要带文
- 一、访问或添加request/session/application属性public String scope() throws Excep
- 本文实例讲述了C#实现XML与实体类之间相互转换的方法。分享给大家供大家参考,具体如下:using System;using System.
- 本文实例为大家分享了Javafx实现国际象棋游戏的具体代码,供大家参考,具体内容如下基本规则棋子马设计“日”的移动方式兵设计只能向前直走,每
- 一,设计多图片打包下载逻辑:1,如果是要拉取腾讯云等资源服务器的图片,2,我们先把远程图片拉取到本地的临时文件夹,3,然后压缩临时文件夹,4
- 目标了解HTTP 请求/响应头及常见的属性;了解如何使用SpringBoot处理头信息 ;了解如何使用SpringBoot处理Cookie
- 详解Java虚拟机管理的内存运行时数据区域概述 Java虚拟机在执行Java程序的过程中会把它所管理的内
- NDK部分1、下载ndk这里就一笔带过了。2、解压ndk不要解压,文件权限会出错。执行之,会自动解压,然后mv到想放的地方。我放到了”/us
- 首先,我们需要对.net提供的FileSystemWatcher类有所了解。我有些懒,找了MSDN对该类的描述。FileSystemWatc
- Android 中RecyclerView顶部刷新实现详解1. RecyclerView顶部刷新的原理RecyclerView顶部刷新的实现
- 本文实例为大家分享了java实现拼图游戏的具体代码,供大家参考,具体内容如下游戏说明:设计一款拼图游戏,要求点击图片按钮,实现图片按钮的移动
- 当 Maven 无法依赖 spring-cloud-starter-zipkin 时,您可以尝试以下方法解决:确保拼写正确:请检查项目中的
- 下面就为大家带来3种比较常见的压缩方式先给出一组数据原图:width:2976; height:2976原图实际:--->byte:2
- 新建一个类继承AbstractFunction,重写以下方法:executesetParametersgetReferenceKeygetA
- 最近开发过过成中遇到一些小问题,比如一个btn点击用户可能只点击了一次但是后台响应了多次,像一些表单的提交出现这种问题比较棘手,当然解决这种
- 现在有好多扫描识别银行卡号的SDK都是收费的,但是也有不收费的,但是有一定的问题,就是那种印刷的银行卡号扫描不出来,希望哪位大神指导原因给解
- 在Java中Timer是java.util包中的一个工具类,提供了定时器的功能。我们可以创建一个Timer对象,然后调用其schedule方
- 前言前面文章我们介绍了Broker是如何将消息全量存储到CommitLog文件中,并异步生成dispatchRequest任务更新Consu
- 星期天小哼和小哈约在一起玩桌游,他们正在玩一个非常古怪的扑克游戏——“小猫钓鱼”。游戏的规则是这样的:将一副扑克牌平均分成两份,每人拿一份。
- fifter、servlet、interceptorfifter用来处理请求头、请求参数、编码的一些设置,然后转交给servlet,处理业务