HDFS之FileStatus类

本文详细解析HDFS中FileStatus字段,包括Path路径、文件长度、目录判断、块的复本数、块大小、修改时间、访问时间、权限、所有者、所在组、符号链接等,并提供代码示例展示如何获取文件的元数据。

FileStatus字段解析

private Path path;                  // Path路径
private long length;                // 文件长度
private boolean isdir;              // 是都是目录
private short block_replication;    // 块的复本数
private long blocksize;             // 块大小
private long modification_time;     // 修改时间
private long access_time;           // 访问时间
private FsPermission permission;    // 权限
private String owner;               // 所有者
private String group;               // 所在组
private Path symlink;               // 符号链接,如果isdir为true那么symlink必须为null

FileStatus常用函数介绍

public int compareTo(Object o)          // 比较两个对象是否指向相同的路径
public long getAccessTime()             // 得到访问时间
public long getBlockSize()              // 得到块大小
public String getGroup()                // 得到组名
public long getLen()                    // 得到文件大小
public long getModificationTime()       // 得到修改时间
public String getOwner()                // 获取所有者信息
public Path getPath()                   // 获取Path路径
public FsPermission getPermission()     // 获取权限信息
public short getReplication()           // 获取块副本数
public path getsymlink()                // 获取符号链接的Path路径
public boolean isSymlink()              // 是否为符号链接
public void readFields(DataInput in)    // 序列化读取字段
public void setPath(final Path p)       // 设置Path路径
public void setSymlink(final Path p)    // 设置符号链接
public void write(DataOutput out)       // 序列化写入字段

代码示例
package com.hdfs;

import org.apache.hadoop.conf.Configuration;
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.FileUtil;
import org.apache.hadoop.fs.FsUrlStreamHandlerFactory;
import org.apache.hadoop.fs.Path;
import org.apache.hadoop.io.IOUtils;
import org.apache.hadoop.util.Progressable;

public class HdfsTest1 {
    //显示文件所有信息
    public static void fileInfo(String path) throws IOException{
        Configuration conf = new Configuration();
        FileSystem fs = FileSystem.get(conf);
        Path p = new Path(path);
        //FileStatus对象封装了文件的和目录的额元数据,包括文件长度、块大小、权限等信息
        FileStatus fileStatus = fs.getFileStatus(p);
        System.out.println("文件路径:"+fileStatus.getPath());
        System.out.println("块的大小:"+fileStatus.getBlockSize());
        System.out.println("文件所有者:"+fileStatus.getOwner()+":"+fileStatus.getGroup());
        System.out.println("文件权限:"+fileStatus.getPermission());
        System.out.println("文件长度:"+fileStatus.getLen());
        System.out.println("备份数:"+fileStatus.getReplication());
        System.out.println("修改时间:"+fileStatus.getModificationTime());
    }
    public static void main(String[] args) throws IOException {
        fileInfo("/user/hadoop/aa.mp4");
    }

}

输出结果如下:

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值