翼度科技»论坛 云主机 LINUX 查看内容

Linux xfs文件系统stat命令Birth字段为空的原因探究

9

主题

9

帖子

27

积分

新手上路

Rank: 1

积分
27
在Linux平台找出某个目录下创建时间最早的文件,测试验证脚本结果是否准确的过程中发现一个很有意思的现象,stat命令在一些平台下Birth字段有值,而在一些平台则为空值,如下所示:
RHEL 8.7下, XFS文件系统
  1. [mysql@mysqlu02 ~]$ more /etc/redhat-release 
  2. Red Hat Enterprise Linux release 8.7 (Ootpa)
  3. [mysql@mysqlu02 ~]$ touch test.txt
  4. [mysql@mysqlu02 ~]$ stat test.txt
  5.   File: test.txt
  6.   Size: 0               Blocks: 0          IO Block: 4096   regular empty file
  7. Device: fd05h/64773d    Inode: 144         Links: 1
  8. Access: (0644/-rw-r--r--)  Uid: (  801/   mysql)   Gid: (  800/   mysql)
  9. Access: 2023-05-06 17:09:44.428050549 +0800
  10. Modify: 2023-05-06 17:09:44.428050549 +0800
  11. Change: 2023-05-06 17:09:44.428050549 +0800
  12.  Birth: 2023-05-06 17:09:44.428050549 +0800
复制代码
RHEL 7.9 XFS文件系统
  1. [oracle@KerryDB ~]$ more /etc/redhat-release 
  2. Red Hat Enterprise Linux Server release 7.9 (Maipo)
  3. [oracle@KerryDB ~]$ touch test.txt
  4. [oracle@KerryDB ~]$ stat test.txt
  5.   File: ‘test.txt’
  6.   Size: 0               Blocks: 0          IO Block: 4096   regular empty file
  7. Device: fd03h/64771d    Inode: 4238838     Links: 1
  8. Access: (0644/-rw-r--r--)  Uid: (  700/  oracle)   Gid: (  600/oinstall)
  9. Access: 2023-05-06 17:03:42.964517675 +0800
  10. Modify: 2023-05-06 17:03:42.964517675 +0800
  11. Change: 2023-05-06 17:03:42.964517675 +0800
  12.  Birth: -
  13. [oracle@KerryDB ~]$
复制代码
stat命令的Birth字段表示文件的创建时间,该属性是ext4的新功能(当然也适用于xfs文件系统),也称为crtime或btime,但是当前两个测试环境的文件系统为xfs,之前也在xfs文件系统中测试过,发现xfs不支持creation time. 但是从xfs v5开始,xfs已经支持creation time,文档[1]中已有阐述,如下所示:
  1. /* version 5 filesystem (inode version 3) fields start here */
  2.      __le32                    di_crc;
  3.      __be64                    di_changecount;
  4.      __be64                    di_lsn;
  5.      __be64                    di_flags2;
  6.      __be32                    di_cowextsize;
  7.      __u8                      di_pad2[12];
  8.      xfs_timestamp_t           di_crtime;
  9.      __be64                    di_ino;
  10.      uuid_t                    di_uuid;
  11. };
  12. *di_crtime*::
  13. Specifies the time when this inode was created.
复制代码
但是上面这个差异现象,还是让我有点好奇,因为两个测试环境对应的xfs版本都是v5,如下所示。
KerryDB这台机器的xfs版本信息:
Oracle用户:
  1. $ uname -r
  2. 3.10.0-1160.80.1.el7.x86_64
  3. $ dmesg | grep -iE 'xfs.*\s+mounting' | head -1
  4. [    4.041026] XFS (dm-0): Mounting V5 Filesystem
复制代码
root用户:
  1. # xfs_db -r /dev/mapper/vg00-home
  2. xfs_db> version
  3. versionnum [0xb4b5+0x18a] = V5,NLINK,DIRV2,ATTR,ALIGN,LOGV2,EXTFLG,MOREBITS,ATTR2,LAZYSBCOUNT,PROJID32BIT,CRC,FTYPE
  4. xfs_db>
复制代码
mysqlu02这台机器的xfs版本信息:
mysql用户:
  1. $ dmesg | grep -iE 'xfs.*\s+mounting' | head -1
  2. [    7.654324] XFS (dm-0): Mounting V5 Filesystem
复制代码
root用户:
  1. # xfs_db -r /dev/mapper/vg00-home
  2. xfs_db> version
  3. versionnum [0xb4b5+0x18a] = V5,NLINK,DIRV2,ATTR,ALIGN,LOGV2,EXTFLG,MOREBITS,ATTR2,LAZYSBCOUNT,PROJID32BIT,CRC,FTYPE,FINOBT,SPARSE_INODES,REFLINK
  4. xfs_db>
复制代码
那么到底是什么原因导致。Google搜索了相关资料,原来,如果stat命令查看xfs文件系统的文件时,如果要Birth字段不显示空置,必须满足几个条件,一个是xfs的版本为v5,另外,对操作系统内核版本也有要求(如下所示)
stat “now prints file creation time when supported by the file system, on GNU Linux systems with glibc >= 2.28 and kernel >= 4.11.”
KerryDB这台服务器内核信息如下所示
  1. $ uname -r
  2. 3.10.0-1160.80.1.el7.x86_64
复制代码
mysqlu02这台服务器的内核信息如下所示:
  1. $ uname -r
  2. 4.18.0-425.3.1.el8.x86_64
复制代码
如上所示,stat命令Birth字段为空置的操作系统内核版本为3.10.0,不满足条件kernerl >=4.11 所以stat命令显示空值。
参考资料

[1] 1: https://git.kernel.org/pub/scm/fs/xfs/xfs-documentation.git/tree/design/XFS_Filesystem_Structure/ondisk_inode.asciidoc
扫描上面二维码关注我如果你真心觉得文章写得不错,而且对你有所帮助,那就不妨帮忙“推荐"一下,您的“推荐”和”打赏“将是我最大的写作动力!本文版权归作者所有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接.
来源:https://www.cnblogs.com/kerrycode/p/17389560.html
免责声明:由于采集信息均来自互联网,如果侵犯了您的权益,请联系我们【E-Mail:cb@itdo.tech】 我们会及时删除侵权内容,谢谢合作!

举报 回复 使用道具