Hadoop学习总结之七:HDFS 操作
来源:互联网 发布:淘宝助理导入csv卡住了 编辑:程序博客网 时间:2024/05/29 15:15
转自:http://www.xuehuile.com/blog/db693eb859b64c39b945d7ae333a1343.html
package com.java.api.hdfs;import java.io.BufferedReader;import java.io.IOException;import java.io.InputStream;import java.io.InputStreamReader;import org.apache.hadoop.conf.Configuration;import org.apache.hadoop.fs.FileStatus;import org.apache.hadoop.fs.FileSystem;import org.apache.hadoop.fs.Path;/** * @author 三劫散仙 * Java API操作HDFS * 工具类 * * **/public class OperaHDFS {public static void main(String[] args)throws Exception {//System.out.println("aaa");//uploadFile();//createFileOnHDFS();//deleteFileOnHDFS();//createDirectoryOnHDFS();//deleteDirectoryOnHDFS();//renameFileOrDirectoryOnHDFS();//downloadFileorDirectoryOnHDFS();readHDFSListAll();}/*** * 加载配置文件 * **/ static Configuration conf=new Configuration(); /** * 重名名一个文件夹或者文件 * * **/ public static void renameFileOrDirectoryOnHDFS()throws Exception{ FileSystem fs=FileSystem.get(conf); Path p1 =new Path("hdfs://10.2.143.5:9090/root/myfile/my.txt"); Path p2 =new Path("hdfs://10.2.143.5:9090/root/myfile/my2.txt");fs.rename(p1, p2);fs.close();//释放资源System.out.println("重命名文件夹或文件成功....."); } /*** * * 读取HDFS某个文件夹的所有 * 文件,并打印 * * **/ public static void readHDFSListAll() throws Exception{ //流读入和写入 InputStream in=null; //获取HDFS的conf //读取HDFS上的文件系统 FileSystem hdfs=FileSystem.get(conf); //使用缓冲流,进行按行读取的功能 BufferedReader buff=null; //获取日志文件的根目录 Path listf =new Path("hdfs://10.2.143.5:9090/root/myfile/"); //获取根目录下的所有2级子文件目录 FileStatus stats[]=hdfs.listStatus(listf); //自定义j,方便查看插入信息 int j=0; for(int i = 0; i < stats.length; i++){ //获取子目录下的文件路径 FileStatus temp[]=hdfs.listStatus(new Path(stats[i].getPath().toString())); for(int k = 0; k < temp.length;k++){ System.out.println("文件路径名:"+temp[k].getPath().toString()); //获取Path Path p=new Path(temp[k].getPath().toString()); //打开文件流 in=hdfs.open(p); //BufferedReader包装一个流 buff=new BufferedReader(new InputStreamReader(in)); String str=null; while((str=buff.readLine())!=null){ System.out.println(str); } buff.close(); in.close(); } } hdfs.close(); } /** * 从HDFS上下载文件或文件夹到本地 * * **/ public static void downloadFileorDirectoryOnHDFS()throws Exception{ FileSystem fs=FileSystem.get(conf); Path p1 =new Path("hdfs://10.2.143.5:9090/root/myfile//my2.txt"); Path p2 =new Path("D://7");fs.copyToLocalFile(p1, p2);fs.close();//释放资源System.out.println("下载文件夹或文件成功....."); } /** * 在HDFS上创建一个文件夹 * * **/ public static void createDirectoryOnHDFS()throws Exception{ FileSystem fs=FileSystem.get(conf); Path p =new Path("hdfs://10.2.143.5:9090/root/myfile");fs.mkdirs(p);fs.close();//释放资源System.out.println("创建文件夹成功....."); } /** * 在HDFS上删除一个文件夹 * * **/ public static void deleteDirectoryOnHDFS()throws Exception{ FileSystem fs=FileSystem.get(conf); Path p =new Path("hdfs://10.2.143.5:9090/root/myfile");fs.deleteOnExit(p);fs.close();//释放资源System.out.println("删除文件夹成功....."); } /** * 在HDFS上创建一个文件 * * **/ public static void createFileOnHDFS()throws Exception{ FileSystem fs=FileSystem.get(conf); Path p =new Path("hdfs://10.2.143.5:9090/root/abc.txt");fs.createNewFile(p);//fs.create(p);fs.close();//释放资源System.out.println("创建文件成功....."); } /** * 在HDFS上删除一个文件 * * **/ public static void deleteFileOnHDFS()throws Exception{ FileSystem fs=FileSystem.get(conf); Path p =new Path("hdfs://10.2.143.5:9090/root/abc.txt");fs.deleteOnExit(p);fs.close();//释放资源System.out.println("删除成功....."); } /*** * 上传本地文件到 * HDFS上 * * **/public static void uploadFile()throws Exception{//加载默认配置FileSystem fs=FileSystem.get(conf); //本地文件 Path src =new Path("D:\\6"); //HDFS为止 Path dst =new Path("hdfs://10.2.143.5:9090/root/"); try {fs.copyFromLocalFile(src, dst);} catch (IOException e) {// TODO Auto-generated catch blocke.printStackTrace();} System.out.println("上传成功........"); fs.close();//释放资源 }}
0 0
- Hadoop学习总结之七:HDFS 操作
- Hadoop学习总结之HDFS
- Hadoop学习之HDFS的相关操作
- hadoop之HDFS总结
- Hadoop学习之HDFS
- Hadoop之HDFS文件操作
- Hadoop之HDFS文件操作
- HADOOP之HDFS文件操作
- Hadoop之HDFS文件操作
- Hadoop之HDFS文件操作
- Hadoop之HDFS文件操作
- Hadoop之HDFS文件操作
- Hadoop之HDFS的操作
- Hadoop之HDFS文件操作
- Hadoop之HDFS文件操作
- Hadoop之HDFS文件操作
- Hadoop之HDFS文件操作
- Hadoop入门之HDFS操作
- JavaScript权威指南_48_第7章_数组_7.0-概述
- cocos studio 各模块使用方法
- Client Feature 简介-1
- 关于新版本struts2.3.16出现乱码问题
- C语言gettimeofday()函数:获取当前时间
- Hadoop学习总结之七:HDFS 操作
- 数据倾斜
- 多线程并发访问可能出现的崩溃问题
- Mac下Lua Sublime Text2 开发环境搭建
- LeetCode Unique Paths II
- 【小莨】如何打开扩展名为.DB 文件 ,sqlite3 的使用
- JavaScript权威指南_49_第7章_数组_7.1-创建数组
- Python的学习之旅---开始篇
- JAVA 验证AD域名登陆