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

在linux平台找出某个目录下创建时间最早的文件,测试验证脚本结果是否准确的过程中发现一个很有意思的现象,stat命令在一些平台下Birth字段有值,而在一些平台则为空值,如下所示:

RHEL 8.7下, XFS文件系统

  1. [mysql@mysqlu02~]$more/etc/RedHatrelease
  2. RedHatEnterpriseLinuxrelease8.7(Ootpa)
  3. [mysql@mysqlu02~]$touchtest.txt
  4. [mysql@mysqlu02~]$stattest.txt
  5. File:test.txt
  6. Size:0blocks:0IOBlock:4096regularemptyfile
  7. Device:fd05h/64773dInode:144Links:1
  8. Access🙁0644/-rwrr–)Uid🙁801/mysql)Gid🙁800/mysql)
  9. Access:2023050617:09:44.428050549+0800
  10. Modify:2023050617:09:44.428050549+0800
  11. Change:2023050617:09:44.428050549+0800
  12. Birth:2023050617:09:44.428050549+0800

RHEL 7.9 XFS文件系统

  1. [oracle@KerryDB~]$more/etc/redhatrelease
  2. RedHatEnterpriseLinuxServerrelease7.9(Maipo)
  3. [oracle@KerryDB~]$touchtest.txt
  4. [oracle@KerryDB~]$stattest.txt
  5. File:‘test.txt
  6. Size:0Blocks:0IOBlock:4096regularemptyfile
  7. Device:fd03h/64771dInode:4238838Links:1
  8. Access:(0644/-rw-r–r–)Uid:(700/oracle)Gid:(600/oinstall)
  9. Access:2023-05-0617:03:42.964517675+0800
  10. Modify:2023-05-0617:03:42.964517675+0800
  11. Change:2023-05-0617: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. /*version5filesystem(inodeversion3)fieldsstarthere*/
  2. __le32di_crc;
  3. __be64di_changecount;
  4. __be64di_lsn;
  5. __be64di_flags2;
  6. __be32di_cowextsize;
  7. __u8di_pad2[12];
  8. xfs_timestamp_tdi_crtime;
  9. __be64di_ino;
  10. uuid_tdi_uuid;
  11. };
  12. *di_crtime*::
  13. Specifiesthetimewhenthisinodewascreated.

但是上面这个差异现象,还是让我有点好奇,因为两个测试环境对应的xfs版本都是v5,如下所示。

KerryDB这台机器的xfs版本信息:

Oracle用户:

  1. $unamer
  2. 3.10.01160.80.1.el7.x86_64
  3. $dmesg|grepiE‘xfs.*\s+mounting’|head1
  4. [4.041026]XFS(dm0):MountingV5Filesystem

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|grepiE‘xfs.*\s+mounting’|head1
  2. [7.654324]XFS(dm0):MountingV5Filesystem

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. $unamer
  2. 3.10.01160.80.1.el7.x86_64

mysqlu02这台服务器的内核信息如下所示:

  1. $unamer
  2. 4.18.0425.3.1.el8.x86_64

如上所示,stat命令Birth字段为空置的操作系统内核版本为3.10.0,不满足条件kernerl >=4.11 所以stat命令显示空值。

参考资料

1: https://git.kernel.org/pub/scm/fs/xfs/xfs-documentation.git/tree/design/XFS_Filesystem_Structure/ondisk_inode.asciidoc

到此这篇关于Linux xfs文件系统stat命令Birth字段为空的原因探究的文章就介绍到这了,更多相关Linux xfs文件系统stat命令内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

标签

发表评论