热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

HDFSAPI

Hadoop的文件操作位于包org.apache.hadoop.fs里面,能够进行新建、删除、修改等操作。比较重要的几个类:(1)Configurati

Hadoop的文件操作位于包org.apache.hadoop.fs里面,能够进行新建、删除、修改等操作。

比较重要的几个类:

(1)Configuration:HDFS的配置信息;

(2)FileSystem: HDFS文件系统;

(3)Path: HDFS文件或目录的路径;

(4)FileStatus: Path下面的文件或目录;

(5)BlockLocation: 文件块的位置;

(6)DistributedFileSystem: 分布式文件系统;

(7)DatanodeInfo:数据节点信息。

代码:

package com.hellohadoop;import java.io.IOException;
import java.text.SimpleDateFormat;
import java.util.Date;import org.apache.hadoop.conf.Configuration;
import org.apache.hadoop.fs.FileStatus;
import org.apache.hadoop.fs.FileSystem;
import org.apache.hadoop.fs.Path;
import org.apache.hadoop.hdfs.DistributedFileSystem;
import org.apache.hadoop.hdfs.protocol.DatanodeInfo;
import org.apache.hadoop.fs.BlockLocation;
import org.apache.hadoop.fs.FSDataOutputStream;public class FileOperator {static Configuration conf;static FileSystem hdfs;public static void main(String[] args) throws Exception{Init();Upload();
// Create();
// CreateFolder();
// Rename();
// Delete();
// IsExist();
// GetTime();
// GetAllFiles();
// GetLocations();
// GetAllHosts();
}// 初始化public static void Init() throws Exception{conf = new Configuration();hdfs = FileSystem.get(conf); }// 上传文件public static void Upload() throws Exception{// 本地文件Path src = new Path("F:\\Hadoop\\DataFiles\\data.txt");// 上传路径Path dst = new Path("hdfs://master:9000/user/Administrator/");// 上传文件
hdfs.copyFromLocalFile(src, dst);System.out.println("Upload to " + conf.get("fs.default.name"));}// 创建文件public static void Create() throws Exception{byte[] buff = "Hello Hadoop!".getBytes();// 新建文件路径Path dfs = new Path("hdfs://master:9000/user/Administrator/hello");FSDataOutputStream outputStream = hdfs.create(dfs);outputStream.write(buff, 0, buff.length);System.out.println("Created!");}// 创建文件夹public static void CreateFolder() throws Exception{// 新建文件路径Path dfs = new Path("hdfs://master:9000/user/Administrator/helloDir");hdfs.mkdirs(dfs);System.out.println("Created!");}// 重新命名HDFS文件public static void Rename() throws Exception{Path of = new Path("hdfs://master:9000/user/Administrator/data.txt");Path nf = new Path("hdfs://master:9000/user/Administrator/newdata.txt");boolean isOk = hdfs.rename(of, nf);String res = isOk? "Yes": "No";System.out.println("Result:" + res);}// 删除HDFS文件public static void Delete() throws Exception{Path file = new Path("hdfs://master:9000/user/Administrator/helloDir");
// hdfs.delete(file, false);// 第二个为是否递归删除,如果目录下面有文件,是否递归删除为false会报错hdfs.delete(file, true);}// 查看某个文件是否存在public static void IsExist() throws IOException{Path file = new Path("hdfs://master:9000/user/Administrator/hello1");String res = hdfs.exists(file)? "Yes": "No";System.out.println("Result:" + res);}// 查看文件最后修改时间public static void GetTime() throws Exception{Path file = new Path("hdfs://master:9000/user/Administrator/hello");FileStatus fs = hdfs.getFileStatus(file);long mTime = fs.getModificationTime();SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd hh:mm:ss");String sTime = sdf.format(new Date(mTime));System.out.println("Modified Time:" + sTime);}// 递归查看文件目录public static void GetAllFiles() throws Exception{Path file = new Path("hdfs://master:9000/");AllFile(file);}public static void AllFile(Path p) throws Exception{FileStatus[] fs = hdfs.listStatus(p);for (FileStatus f: fs){// 是文件输出路径if (hdfs.isFile(f.getPath())){System.out.println(f.getPath());}// 是目录继续递归else{System.out.println();System.out.println(f.getPath() + ":");AllFile(f.getPath());}}}// 查看文件在HDFS中的位置public static void GetLocations() throws Exception{Path file = new Path("hdfs://master:9000/user/Administrator/stsme_20150330.sql");FileStatus fs = hdfs.getFileStatus(file);BlockLocation[] blk = hdfs.getFileBlockLocations(fs, 0, fs.getLen());for(int i=0; i){String[] host = blk[i].getHosts();System.out.println("Block " + i + " Location:" + host[0]);} }// 查看HDFS集群上所有节点public static void GetAllHosts() throws Exception{DistributedFileSystem dfs = (DistributedFileSystem) hdfs;DatanodeInfo[] dns = dfs.getDataNodeStats();for (int i=0; i){System.out.println("Datanode " + i + " Name:" + dns[i].getHostName());}}}




推荐阅读
  • 二维码的实现与应用
    本文介绍了二维码的基本概念、分类及其优缺点,并详细描述了如何使用Java编程语言结合第三方库(如ZXing和qrcode.jar)来实现二维码的生成与解析。 ... [详细]
  • 本文介绍了如何通过C#语言调用动态链接库(DLL)中的函数来实现IC卡的基本操作,包括初始化设备、设置密码模式、获取设备状态等,并详细展示了将TextBox中的数据写入IC卡的具体实现方法。 ... [详细]
  • Android与JUnit集成测试实践
    本文探讨了如何在Android项目中集成JUnit进行单元测试,并详细介绍了修改AndroidManifest.xml文件以支持测试的方法。 ... [详细]
  • Beetl是一款先进的Java模板引擎,以其丰富的功能、直观的语法、卓越的性能和易于维护的特点著称。它不仅适用于高响应需求的大型网站,也适合功能复杂的CMS管理系统,提供了一种全新的模板开发体验。 ... [详细]
  • Java 中的十进制样式 getZeroDigit()方法,示例 ... [详细]
  • 问题场景用Java进行web开发过程当中,当遇到很多很多个字段的实体时,最苦恼的莫过于编辑字段的查看和修改界面,发现2个页面存在很多重复信息,能不能写一遍?有没有轮子用都不如自己造。解决方式笔者根据自 ... [详细]
  • spring boot使用jetty无法启动 ... [详细]
  • 本文详细介绍了如何搭建一个高可用的MongoDB集群,包括环境准备、用户配置、目录创建、MongoDB安装、配置文件设置、集群组件部署等步骤。特别关注分片、读写分离及负载均衡的实现。 ... [详细]
  • linux网络子系统分析(二)—— 协议栈分层框架的建立
    目录一、综述二、INET的初始化2.1INET接口注册2.2抽象实体的建立2.3代码细节分析2.3.1socket参数三、其他协议3.1PF_PACKET3.2P ... [详细]
  • protobuf 使用心得:解析与编码陷阱
    本文记录了一次在广告系统中使用protobuf进行数据交换时遇到的问题及其解决过程。通过这次经历,我们将探讨protobuf的特性和编码机制,帮助开发者避免类似的陷阱。 ... [详细]
  • Logging all MySQL queries into the Slow Log
    MySQLoptionallylogsslowqueriesintotheSlowQueryLog–orjustSlowLog,asfriendscallit.However,Thereareseveralreasonstologallqueries.Thislistisnotexhaustive:Belowyoucanfindthevariablestochange,astheyshouldbewritteninth ... [详细]
  • 本文详细介绍了`android.os.Binder.getCallingPid()`方法的功能和应用场景,并提供了多个实际的代码示例。通过这些示例,开发者可以更好地理解如何在不同的开发场景中使用该方法。 ... [详细]
  • 本文探讨了在使用JavaMail发送电子邮件时,抄送功能未能正常工作的问题,并提供了详细的代码示例和解决方法。 ... [详细]
  • JUC并发编程——线程的基本方法使用
    目录一、线程名称设置和获取二、线程的sleep()三、线程的interrupt四、join()五、yield()六、wait(),notify(),notifyAll( ... [详细]
  • 默认情况下,Java 的克隆机制是浅克隆,即仅复制对象本身而不复制其内部引用的对象。本文将详细介绍如何通过深度克隆来确保对象及其内部引用的对象都能被正确复制。 ... [详细]
author-avatar
海滨2502940147
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有