linux 查找文件 时间,Linux如何查找文件的建立时间

Linux的文件可否找到文件的建立时间取决于文件系统类型,在ext4以前的早期文件系统中(ext、ext二、ext3),文件的元数据不会记录文件的建立时间,它只会记录访问时间、修改时间、更改时间(状态更改时间)。php

Access 是访问时间,文件数据的最后访问时间。例如读文件内容node

Modify 是修改时间,文件数据的最后修改时间。例如使用VIM修改文件内容mysql

Change 是状态更改时间,这个跟Modify时间很容易混淆,change time:更改文件的属性便会更新该时间,好比使用chmod命令更改文件属性,例如chmod、chown命令。或者执行其余命令时隐式的附带更改了文件的属性若文件大小等。linux

因此,对于ext、ext二、ext3文件格式的文件, 文件建立时间实际上是不存在的,若文件从建立后未曾修改过则可认为建立时间=修改时间,若文件建立后状态也未曾改变过文件属性,则可认为建立时间=状态更改时间,若文件建立后未曾被读取过则可认为建立时间=访问时间。可是不多有文件自建立后,从不被访问、修改。因此基本没法找到一个准确的建立时间,可是在ext4文件格式中,文件的建立时间保存在ext4文件系统的inode中,因此咱们可使用debugfs &stat命令来获取准确的文件建立时间。sql

注意:Linux文件系统繁多,通常较常见的有:ext二、ext三、ext四、jfs、ReiserFS、XFS、Btrfs 。这里面,我的只用过ext三、ext四、XFS文件系统类型。维基百科上列出的文件系统类型有下面这些,不少文件系统都没有使用过,本文测试环境为ext三、ext四、XFS。ubuntu

文件系统app

建立命令工具

工具测试

Archiso[1]spa

内核文档[2]

说明

Btrfs

mkfs.btrfs(8)

btrfs-progs

Yes

btrfs.txt

稳定状态

VFAT

mkfs.fat(8)

dosfstools

Yes

vfat.txt

exFAT

mkexfatfs(8)

exfat-utils

Yes

N/A (FUSE-based)

F2FS

mkfs.f2fs(8)

f2fs-tools

Yes

f2fs.txt

基于闪存的设备

ext3

mke2fs(8)

e2fsprogs

Yes (base)

ext3.txt

ext4

mke2fs(8)

e2fsprogs

Yes (base)

ext4.txt

HFS

mkfs.hfsplus(8)

hfsprogsAUR

No

hfs.txt

macOS文件系统

JFS

mkfs.jfs(8)

jfsutils

Yes (base)

jfs.txt

NILFS2

mkfs.nilfs2(8)

nilfs-utils

Yes

nilfs2.txt

NTFS

mkfs.ntfs(8)

ntfs-3g

Yes

N/A (FUSE-based)

Windows文件系统

Reiser4

mkfs.reiser4(8)

reiser4progsAUR

No

ReiserFS

mkfs.reiserfs(8)

reiserfsprogs

Yes (base)

UDF

mkfs.udf(8)

udftools

Optional

udf.txt

XFS

mkfs.xfs(8)

xfsprogs

Yes (base)

xfs.txt

xfs-delayed-logging-design.txt

xfs-self-describing-metadata.txt

ZFS

zfs-linuxAUR

No

N/A (OpenZFS移植)

步骤通常为:

1:找到文件或目录的索引节点号

ls -i filename

2:找到文件所在的分区或VG

df -T

3:使用debugfs找到文件的建立时间(crtime)

debugfs -R 'stat ' /dev/xxxx

下面为测试用例,以下所示:

[root@mylnx06 resource]# touch test.txt

[root@mylnx06 resource]# stat test.txt

File:  ‘test.txt’

Size: 0                 Blocks: 0          IO Block: 4096   regular empty file

Device: 811h/2065d      Inode: 13          Links: 1

Access: (0644/-rw-r--r--)  Uid: (    0/    root)   Gid: (    0/    root)

Access: 2019-02-27 09:26:03.833224736 +0800

Modify: 2019-02-27 09:26:03.833224736 +0800

Change: 2019-02-27 09:26:03.833224736 +0800

Birth: -

[root@mylnx06 resource]# ls -i test.txt

13 test.txt

[root@mylnx06 resource]# debugfs -R 'stat <13>' /dev/sdb1

debugfs 1.42.9 (28-Dec-2013)

Inode: 13   Type: regular    Mode:  0644   Flags: 0x80000

Generation: 3202520017    Version: 0x00000000:00000001

User:     0   Group:     0   Size: 0

File ACL: 0    Directory ACL: 0

Links: 1   Blockcount: 0

Fragment:  Address: 0    Number: 0    Size: 0

ctime: 0x5c75e72b:c6a80080 -- Wed Feb 27 09:26:03 2019

atime: 0x5c75e72b:c6a80080 -- Wed Feb 27 09:26:03 2019

mtime: 0x5c75e72b:c6a80080 -- Wed Feb 27 09:26:03 2019

crtime: 0x5c75e72b:c6a80080 -- Wed Feb 27 09:26:03 2019

Size of extra inode fields: 28

EXTENTS:

[root@mylnx06 resource]# vi test.txt

it is only a test

[root@mylnx06 resource]# debugfs -R 'stat <13>' /dev/sdb1

debugfs 1.42.9 (28-Dec-2013)

Inode: 13   Type: regular    Mode:  0644   Flags: 0x80000

Generation: 3202520017    Version: 0x00000000:00000001

User:     0   Group:     0   Size: 0

File ACL: 0    Directory ACL: 0

Links: 0   Blockcount: 0

Fragment:  Address: 0    Number: 0    Size: 0

ctime: 0x5c75e766:924da674 -- Wed Feb 27 09:27:02 2019

atime: 0x5c75e757:dfe24bb0 -- Wed Feb 27 09:26:47 2019

mtime: 0x5c75e72b:c6a80080 -- Wed Feb 27 09:26:03 2019

crtime: 0x5c75e72b:c6a80080 -- Wed Feb 27 09:26:03 2019

dtime: 0x5c75e766 -- Wed Feb 27 09:27:02 2019

Size of extra inode fields: 28

EXTENTS:

[root@mylnx06 resource]# cat test.txt

it is only a test

[root@mylnx06 resource]# debugfs -R 'stat <13>' /dev/sdb1

debugfs 1.42.9 (28-Dec-2013)

Inode: 13   Type: regular    Mode:  0644   Flags: 0x80000

Generation: 3202520017    Version: 0x00000000:00000001

User:     0   Group:     0   Size: 0

File ACL: 0    Directory ACL: 0

Links: 0   Blockcount: 0

Fragment:  Address: 0    Number: 0    Size: 0

ctime: 0x5c75e766:924da674 -- Wed Feb 27 09:27:02 2019

atime: 0x5c75e757:dfe24bb0 -- Wed Feb 27 09:26:47 2019

mtime: 0x5c75e72b:c6a80080 -- Wed Feb 27 09:26:03 2019

crtime: 0x5c75e72b:c6a80080 -- Wed Feb 27 09:26:03 2019

dtime: 0x5c75e766 -- Wed Feb 27 09:27:02 2019

Size of extra inode fields: 28

EXTENTS:

若是对应的设备为VG,一用也可使用这个命令。以下所示:

# debugfs -R 'stat <131075>' /dev/mapper/vg_gettestlnx02-datalv

debugfs 1.41.12 (17-May-2010)

Inode: 131075Type: directoryMode:0710Flags: 0x80000

Generation: 2892073157Version: 0x00000000:0000004c

User:27Group:27Size: 4096

File ACL: 0Directory ACL: 0

Links: 2Blockcount: 8

Fragment:Address: 0Number: 0Size: 0

ctime: 0x5b778fdf:2276fe98 -- Sat Aug 18 11:17:51 2018

atime: 0x5bc83c23:eb973518 -- Thu Oct 18 15:54:11 2018

mtime: 0x5aab2921:49ff497c -- Fri Mar 16 10:17:05 2018

crtime: 0x5aab3b03:b31acdd0 -- Fri Mar 16 11:33:23 2018

Size of extra inode fields: 28

Extended attributes stored in inode body:

selinux = "unconfined_u:object_r:mysqld_db_t:s0\000" (37)

EXTENTS:

(0): 532514

另外对于xfs类型的文件系统,测试发现,这种方式无效的,以下所示:

# debugfs -R 'stat <73281772>' /dev/sda2

debugfs 1.42.9 (28-Dec-2013)

/dev/sda2: Bad magic number in super-block while opening filesystem

stat: Filesystem not open

由于Linux文件系统种类繁多,本文不可能测试各类文件系统,这个超出了个人技术能力范围。其实,总结这篇文章,只是一个网友在群里咨询了这样问题。后面发现只有ext4文件系统才能找到准确的文件建立时间(固然,不排除还有其它文件类型也能够。)

参考资料:

https://askubuntu.com/questions/470134/how-do-i-find-the-creation-time-of-a-file

https://unix.stackexchange.com/questions/24441/get-file-created-creation-time

http://www.answers.com/Q/Why_doesn%27t_Linux_store_file_creation_time

https://wiki.archlinux.org/index.php/File_systems_(%E7%AE%80%E4%BD%93%E4%B8%AD%E6%96%87)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值