本文转载自:https://blog.csdn.net/papiping/article/details/6980573

在测试过程中,f_bfree的值比f_frsize的值大于10%的尺寸大小,意味着16G的磁盘

f_bfree测试出来的结果是17G,f_frsize测试的结果是15G

struct statvfs {

unsigned long  f_bsize;    /* file system block size */文件系统块大小

unsigned long  f_frsize;   /* fragment size */碎片大小

fsblkcnt_t     f_blocks;   /* size of fs in f_frsize units */

fsblkcnt_t     f_bfree;    /* # free blocks */空闲的块

fsblkcnt_t     f_bavail;   /* # free blocks for unprivileged users */用户级的空闲节点

fsfilcnt_t     f_files;    /* # inodes */节点

fsfilcnt_t     f_ffree;    /* # free inodes */空闲的节点

fsfilcnt_t     f_favail;   /* # free inodes for unprivileged users */用户级的空闲节点

unsigned long  f_fsid;     /* file system ID */

unsigned long  f_flag;     /* mount flags */

unsigned long  f_namemax;  /* maximum filename length */

};

测试环境:ext4

1)分析f_bsize和f_frsize的异同

表示每块包含字节的多少

打印结果都是4096字节,显然都是一样的

2)分析f_bfree和f_bavail

表示磁盘剩余空闲的容量

打印结果是

磁盘为16G的情况下,f_bfree比f_bavail大809MB

磁盘为1.5T的情况下,f_bfree比f_bavail大2585MB

并没有我们想象的成线性增长

实际情况下采用df -Th

f_bavail更加接近显示的值

3)f_blocks表示磁盘的整体空间

4)计算磁盘各个方面的数值如下:

磁盘的整体空间:(buf.f_blocks *  buf.f_frsize)/1024/1024)MB

磁盘的空闲空间:(buf.f_bfree *  buf.f_frsize)/1024/1024)MB

磁盘的用户级空闲空间:(buf.f_bavail *  buf.f_frsize)/1024/1024)MB

#include<stdio.h>

#include<stdlib.h>

#include<string.h>

#include<mntent.h>

#include<sys/statvfs.h>

//pszDevicePath是设备的文件描述符,pszDeviceMountPoint是设备的挂载点

intGetDeviceMountPoint(constchar*pszDevicePath,char*pszDeviceMountPoint)

{

structmntent*pent;

FILE*pFile;

pFile=setmntent("/proc/mounts","r");

if(pFile==NULL){

perror("setmntent");

return-1;

}

while(NULL!=(pent=getmntent(pFile)))

{

if(strcmp(pent->mnt_fsname,pszDevicePath)==0)

{

sprintf(pszDeviceMountPoint,"%s",pent->mnt_dir);

printf("Device:%smountpointis:%s\n",pszDevicePath,pszDeviceMountPoint);

}

}

endmntent(pFile);

return0;

}

//通过statvfs查询挂载点上文件系统的空间大小

intGetDeviceRoomSize(constchar*pszDeviceMountPoint)

{

structstatvfsbuf;

intrv=statvfs(pszDeviceMountPoint,&buf);

if(!rv)

{

printf("wholespace:%uMbytes\n",(buf.f_blocks*buf.f_frsize)/1024/1024);

printf("availspace:%uMbytes\n",(buf.f_bavail*buf.f_frsize)/1024/1024);

}

else

{

perror("statvfs");

return-1;

}

return(buf.f_blocks*buf.f_frsize)/1024/1024;

}

intmain(intargc,char*argv[])

{

intnDiskRoomSize=0;

charszMountPoint[32]={0};

GetDeviceMountPoint(argv[1],szMountPoint);

nDiskRoomSize=GetDeviceRoomSize(szMountPoint);

printf("DiskRoomSize=%dMB\n",nDiskRoomSize);

return 0;

}

Linux 使用statvfs读取文件系统信息的更多相关文章

  1. linux删除、读取文件原理

    linux删除文件原理 LINUX的文件名是存在父目录的block里面,并指向这个文件额inode节点,这个文件的inode节点再标记指向存放这个文件的block的数据块.我们删除一个文件,实际上并不 ...

  2. C# 如何在Linux操作系统下读取文件

    发布在Window环境上的微服务需要部署在Linux环境上,本以为没有什么问题,结果因为一处读取文件路径的原因报错了,在此记录一下两个问题:1.C#如何判断当前运行环境是什么操作系统:2.C#读取文件 ...

  3. Linux shell逐行读取文件的方法

    方法1:while循环中执行效率最高,最常用的方法. function while_read_line_bottom(){ while read line do echo $line done < ...

  4. windows 和 linux 上 循环读取文件名称的区别和方法

    function showGetFileName($type){ $url="/opt/mobile_system/gscdn"; //另一台服务器映射到linux过来的路径. # ...

  5. Linux下 Java 读取文件路径

    一般文件路径在windows中用 \ 表示,但是在其他系统平台下比如linux中就不是 \ 所以java给我们提供了一个与平台无关的表示路径的常量 File.separator在windows中则表示 ...

  6. WinAPI: GetVolumeInformation - 读取文件系统信息

    //声明: GetVolumeInformation(   lpRootPathName: PChar;              {磁盘驱动器代码字符串}   lpVolumeNameBuffer: ...

  7. Linux C 读取文件夹下所有文件(包括子文件夹)的文件名【转】

    转自:https://www.cnblogs.com/xudong-bupt/p/3504442.html 本文:http://www.cnblogs.com/xudong-bupt/p/350444 ...

  8. Linux中常用头文件的作用--转

    http://blog.sina.com.cn/s/blog_5c93b2ab0100q62k.html 1. Linux中一些头文件的作用: <assert.h>:ANSI C.提供断言 ...

  9. Linux 底下使用C语言的 单链表 ,双链表,二叉树 读取文件,并排序

    直接上代码 单链表Linux读文件排序: 双链表Linux读取文件排序: 二叉树LinuX读取文件并排序:

随机推荐

  1. R 包

    [下面列出每个步骤最有用的一些R包] .数据导入 以下R包主要用于数据导入和保存数据: feather:一种快速,轻量级的文件格式:在R和python上都可使用 readr:实现表格数据的快速导入 r ...

  2. word中加入endnote

    http://jingyan.baidu.com/article/f54ae2fc3926d91e92b849c2.html 1.如果安装完endnote后,word中没有出现 endnote菜单,则 ...

  3. anacoda 安装默认源中没有的包

    pip install -i https://pypi.tuna.tsinghua.edu.cn/simple 1 安装失败 conda install pygame 2 搜索 anaconda se ...

  4. 在统一软件开发过程中使用UML

    如何在统一软件开发过程中使用UML? 起始阶段常用UML图 在起始阶段,通常有用例图.类图.活动图.顺序图等UML图的参与. 获取用户需求之后首先要将这些需求转化为系统的顶层用例图. 在确定了用例之后 ...

  5. 说说html 的<!DOCTYPE>声明&标准模式与兼容模式

    我们都知道<!DOCTYPE>声明位于文档的最前面,处于<html>标签之前. <!DOCTYPE>声明不是html标签,它的作用:告知web浏览界面应该使用哪个h ...

  6. 转自大神的KM想法

    我第一次理解KM算法看到大神的讲解不胜感激这km挺神奇的接下来就见识一下这个大牛的吧 转自 http://blog.csdn.net/wuxinxiaohuangdou/article/details ...

  7. 配置tomcat的https域名

    配置tomcat的https域名: <Connector port=" protocol="org.apache.coyote.http11.Http11NioProtoco ...

  8. 20165305 实验三 敏捷开发与XP实践

    实验3-1 敏捷开发与XP实践 http://www.cnblogs.com/rocedu/p/4795776.html, Eclipse的内容替换成IDEA 参考 http://www.cnblog ...

  9. 设计模式之Command(命令)(转)

    Command模式是最让我疑惑的一个模式,我在阅读了很多代码后,才感觉隐约掌握其大概原理,我认为理解设计模式最主要是掌握起原理构造,这样才对自己实际编程有指导作用.Command模式实际上不是个很具体 ...

  10. 102.自己实现ArrayList

    package collection; import java.util.ArrayList; import java.util.List; /** * 自己实现一个ArrayList,帮助理解底层结 ...