HDFS之FileStatus

简介:

  任何文件系统的一个重要特性都是提供其目录结构浏览和检索它所存文件和目录相关信息的功能。FileStatus对象封装了文件系统中文件和目录的元数据,包括文件的长度、块大小、备份数、修改时间、所有者以及权限等信息。

  FileStatus对象由FileSystem的getFileStatus()方法获得,调用该方法的时候要把文件的Path传进去。

  例子:打印输出某个文件的所有信息

 1 package com.hdfs;
 2
 3 import org.apache.hadoop.conf.Configuration;
 4 import org.apache.hadoop.fs.FSDataInputStream;
 5 import org.apache.hadoop.fs.FSDataOutputStream;
 6 import org.apache.hadoop.fs.FileStatus;
 7 import org.apache.hadoop.fs.FileSystem;
 8 import org.apache.hadoop.fs.FileUtil;
 9 import org.apache.hadoop.fs.FsUrlStreamHandlerFactory;
10 import org.apache.hadoop.fs.Path;
11 import org.apache.hadoop.io.IOUtils;
12 import org.apache.hadoop.util.Progressable;
13
14 public class HdfsTest1 {
15     //显示文件所有信息
16     public static void fileInfo(String path) throws IOException{
17         Configuration conf = new Configuration();
18         FileSystem fs = FileSystem.get(conf);
19         Path p = new Path(path);
20         //FileStatus对象封装了文件的和目录的额元数据,包括文件长度、块大小、权限等信息
21         FileStatus fileStatus = fs.getFileStatus(p);
22         System.out.println(“文件路径:”+fileStatus.getPath());
23         System.out.println(“块的大小:”+fileStatus.getBlockSize());
24         System.out.println(“文件所有者:”+fileStatus.getOwner()+”:”+fileStatus.getGroup());
25         System.out.println(“文件权限:”+fileStatus.getPermission());
26         System.out.println(“文件长度:”+fileStatus.getLen());
27         System.out.println(“备份数:”+fileStatus.getReplication());
28         System.out.println(“修改时间:”+fileStatus.getModificationTime());
29     }
30     public static void main(String[] args) throws IOException {
31         fileInfo(“/user/hadoop/aa.mp4”);
32     }
33
34 }

输出结果为:

文件路径:hdfs://master:9000/user/hadoop/aa.mp4
块的大小:67108864
文件所有者:hadoop:supergroup
文件权限:rw-r–r–
文件长度:76805248
备份数:3
修改时间:1371484526483

相关文章
|
7月前
|
存储 分布式计算 安全
|
8月前
|
存储 分布式计算 Hadoop
Hadoop分布式文件系统(HDFS)
【5月更文挑战第10天】
97 3
|
8月前
|
存储 分布式计算 运维
Hadoop的HDFS问题
【5月更文挑战第5天】Hadoop的HDFS问题
97 3
|
存储 分布式计算 资源调度
Hadoop HDFS(分布式文件系统)
Hadoop HDFS(分布式文件系统)
101 0
|
大数据
HDFS
HDFS
57 0
|
机器学习/深度学习 存储 分布式计算
深入理解HDFS 一
深入理解HDFS 一
156 0
|
存储 分布式计算 Hadoop
|
XML 机器学习/深度学习 存储
|
存储 分布式计算 并行计算
第2章 Hadoop分布式文件系统HDFS
第2章 Hadoop分布式文件系统HDFS
634 0
|
存储 机器学习/深度学习 分布式计算
【Hadoop】(一)分布式文件系统 HDFS
【Hadoop】(一)分布式文件系统 HDFS
203 0
【Hadoop】(一)分布式文件系统 HDFS