Linux xfs文件系统stat命令Birth字段为空的原因探究_世界新要闻

来源:2023-05-10 22:37:47    时间:博客园

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


(资料图片仅供参考)

RHEL 8.7下, XFS文件系统

[mysql@mysqlu02~]$more/etc/redhat-releaseRedHatEnterpriseLinuxrelease8.7(Ootpa)[mysql@mysqlu02~]$touchtest.txt[mysql@mysqlu02~]$stattest.txtFile:test.txtSize:0Blocks:0IOBlock:4096regularemptyfileDevice:fd05h/64773dInode:144Links:1Access:(0644/-rw-r--r--)Uid:(801/mysql)Gid:(800/mysql)Access:2023-05-0617:09:44.428050549+0800Modify:2023-05-0617:09:44.428050549+0800Change:2023-05-0617:09:44.428050549+0800Birth:2023-05-0617:09:44.428050549+0800

RHEL 7.9 XFS文件系统

[oracle@KerryDB~]$more/etc/redhat-releaseRedHatEnterpriseLinuxServerrelease7.9(Maipo)[oracle@KerryDB~]$touchtest.txt[oracle@KerryDB~]$stattest.txtFile:‘test.txt’Size:0Blocks:0IOBlock:4096regularemptyfileDevice:fd03h/64771dInode:4238838Links:1Access:(0644/-rw-r--r--)Uid:(700/oracle)Gid:(600/oinstall)Access:2023-05-0617:03:42.964517675+0800Modify:2023-05-0617:03:42.964517675+0800Change:2023-05-0617:03:42.964517675+0800Birth:-[oracle@KerryDB~]$

stat命令的Birth字段表示文件的创建时间,该属性是ext4的新功能(当然也适用于xfs文件系统),也称为crtime或btime,但是当前两个测试环境的文件系统为xfs,之前也在xfs文件系统中测试过,发现xfs不支持creation time. 但是从xfs v5开始,xfs已经支持creation time,文档[1]中已有阐述,如下所示:

/*version5filesystem(inodeversion3)fieldsstarthere*/__le32di_crc;__be64di_changecount;__be64di_lsn;__be64di_flags2;__be32di_cowextsize;__u8di_pad2[12];xfs_timestamp_tdi_crtime;__be64di_ino;uuid_tdi_uuid;};*di_crtime*::Specifiesthetimewhenthisinodewascreated.

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

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

Oracle用户:

$uname-r3.10.0-1160.80.1.el7.x86_64$dmesg|grep-iE"xfs.*\s+mounting"|head-1[4.041026]XFS(dm-0):MountingV5Filesystem

root用户:

#xfs_db-r/dev/mapper/vg00-homexfs_db>versionversionnum[0xb4b5+0x18a]=V5,NLINK,DIRV2,ATTR,ALIGN,LOGV2,EXTFLG,MOREBITS,ATTR2,LAZYSBCOUNT,PROJID32BIT,CRC,FTYPExfs_db>

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

mysql用户:

$dmesg|grep-iE"xfs.*\s+mounting"|head-1[7.654324]XFS(dm-0):MountingV5Filesystem

root用户:

#xfs_db-r/dev/mapper/vg00-homexfs_db>versionversionnum[0xb4b5+0x18a]=V5,NLINK,DIRV2,ATTR,ALIGN,LOGV2,EXTFLG,MOREBITS,ATTR2,LAZYSBCOUNT,PROJID32BIT,CRC,FTYPE,FINOBT,SPARSE_INODES,REFLINKxfs_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这台服务器内核信息如下所示

$uname-r3.10.0-1160.80.1.el7.x86_64

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

$uname-r4.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

关键词:

文章推荐

  • 赏传统年俗逛非遗庙会 铜官窑古镇重温传统民俗年

    中新网长沙2月6日电 (潘杏琼)在多地倡导就地过年的环境下,位于长沙市城北的铜官窑古镇景区,从1月24日至2月15日举行中国年·湖湘味·铜官

    中新网 2022-02-07
  • 哈尔滨铁路迎节后返程高峰 推出复工专列服务

    中新网哈尔滨2月6日电 (周晓舟 记者 史轶夫)中国铁路哈尔滨局有限公司6日发布消息,哈尔滨铁路迎来春节后返程客流高峰,6日至7日预

    中新网 2022-02-07
  • 冬奥动车组设5G超高清演播室 “瑞雪迎春”号智能化人性化结合

    中新网北京2月6日电 (记者 刘文曦)在时速350公里的高铁列车上首设5G超高清演播室,为北京冬奥会量身定制的新型奥运版智能复兴号动车组瑞

    中新网 2022-02-07
  • 中欧班列“签证官”:日行10公里 用锤子“听诊”

    (新春走基层)中欧班列“签证官”:日行10公里 用锤子“听诊”  中新网郑州2月6日电 题:中欧班列“签证官”:日行10公里,用锤子“

    中新网 2022-02-07
  • 西湖守兰人的春节美丽故事:花苞为伴 手留余香

    中新网杭州2月6日电 (记者 谢盼盼)守望花苞,这是西湖守兰人许晔的春节故事,春节正是兰花花苞开花的重要时期。  今年春节里,浙江

    中新网 2022-02-07
  • 广告

    X 关闭

    X 关闭

  • 众测
  • more+

    京张高铁每日开行17对冬奥列车

      京张高铁每日开行17对冬奥列车  预计冬奥服务保障期运送运动员、技术官员、持票观众等20万人次  2月6日,2022北京新闻中心举行“北

    北京冬奥会开幕式上 小学生朱德恩深情演绎《我和我的祖国》

      北京冬奥会开幕式上 小学生朱德恩深情演绎《我和我的祖国》  9岁小号手苦练悬臂吹响颂歌  2月4日晚,在北京冬奥会开幕式上,9岁的

    2022北京冬奥会开幕式这19首乐曲串烧不简单

      多名指挥家列曲目单 再由作曲家重新编曲 本报专访冬奥开幕式音乐总监赵麟  开幕式这19首乐曲串烧不简单  “二十四节气”倒计时、

    “一墩难求” 冰墩墩引爆购买潮

    设计师:没想到冰墩墩成爆款一墩难求冰墩墩引爆购买潮 北京冬奥组委:会源源不断供货北京冬奥会吉祥物冰墩墩近日引爆购买潮,导致一墩难求