Linux下文件内容更新了文件夹时间戳却没变?

Linux下文件内容更新了文件夹时间戳却没变?,第1张

在日常多人协作时,最开始习惯看文件夹更新时间来查看是否有更新,但发现总是不能如实反映情况, 文件夹日期有时变,有时不变。很是困惑,就来探究下。

比如,起始状态:

在 webserver 文件夹下,增加一个文件, record.md

再查看下文件夹日期有没有变化,发生变化了,为我们新增文件的日期。

那么再继续追加内容,还是使用 cat (不同写入方式也有影响,后面会提到)。

这时再看文件夹日期,发现与文件不同步了。文件日期 更新 了,文件夹日期却 没变 。

这是为什么呢? 文件内容更新了,文件夹时间戳却未变。那么件夹的更新日期是什么决定的呢?

我们在使用 less *** 作时,有时会不小心对一个文件夹进行 less *** 作。看上去就像文件夹里的内容变成了一个文本文件。

而文件夹确实是类似文本文件的方式存储的,文件夹可以看做 文件inode:文件名 组成的文本文件 (文件的属性信息存在 inode 的元信息中,可以用 stat file 查看)。只要文件夹内未发生文件的新增、删除、软链或文件夹内文件的 inode (也称为索引节点)未改变,文件夹 (代表文件夹的文本文件)的时间戳就不会发生变化。

而我们每次追加文件内容都未改变 文件名字 和文件的 inode ,所以文件夹的日期未发生变化。

关于文件夹日期更新的问题算是解决了。

另一个问题是,虽然同事的文件更新了,文件夹时间戳一般不改变。但我发现我每次更新完文件内容,文件夹的日期却都会变化,看上去与前面的认知矛盾。想了下,更新时用到的文本编辑器不用,问题是否可能出在 vim 上(我每次都使用它来更新文件),下面看一下。

大家注意这里面 webserver 日期与 webserver/record.md 日期的变化和 ls -i 的输出结果的变化。

确实是 vim 改变了文件的 inode ,也就是说在我们使用 vim 修改文件时, vim 为了避免中间出现意外,先重命名了修改前的文件,修改后的文件以之前文件的名字存储,看上去我们做的是 原位修改 , 实际上是 了新的文件,所以 inode 发生了变化。当然这个 *** 作可以自己配置修改。

在另外一个情况下,如果我们对文件夹 可写权限,但对该文件夹内的文件 有可写权限 时, vim 自动调用另外一个方式修改文件,先把文件做个备份,然后原位修改。这时文件夹的时间戳就不会变了。

设计软件时,需要考虑的问题和情况还是挺多的。看上去挺简单的事情,里面说不准有多少”坑”需要注意,写网站这样,写工具也这样,作分析也是这样。

在Linux中,文件的时间是文件的一个重要的属性,Linux中的文件的时间主要有三个,即修改时间、访问时间和状态时间。

访问时间atime:access

time,读一次文件的内容,atime就会更新。比如对这个文件运用more、cat等命令。另外ls、stat命令都不会修改文件的访问时间。

修改时间mtime:modifiy time,mtime是文件内容最后一次被修改时间。例如vi后保存文件。ls-l列出的时间就是这个时间。

状态改动时间ctime:change

time:ctime是在写入文件、更改所有者、权限或链接设置时随i节点的内容更改而更改的,是该文件的i节点最后一次被修改的时间,通过chmod、chown命令修改一次文件属性,这个时间就会更新。

属性说明:

mtime修改时间,文件内容最后一次修改的时间,我们经常用的ls-l命令显示出来的文件时间就是这个时间,当对文件内容修改后,它的mtime就会相应的改变。

atime访问时间,对文件进行一次读 *** 作,它的访问时间就会改变。例如cat,more等 *** 作,但是stat还有ls命令对atime是不会有影响的。

ctime状态时间,当文件的状态被改变的时候,状态时间就会随之改变。例如当使用chmod、chown等改变文件属性的 *** 作是会改变文件的ctime。

问题现象:

ftp到一台linux系统中,查看一个文件下的文件清单,发现和文件的实际创建时间(以root用户登录查看的时间)不一致,大约相差8个小时左右。

问题处理方法:

Linux 下的时区是通过建立从/etc/localtime 到 /usr/share/zoneinfo 目录下与您所在时区相符的文件的符号链结实现的。例如,由于我在中国的北京,/etc/localtime就是到/usr/share/zoneinfo/Asia/Shanghai的符号链结。要建立这个链结,运行:

ln -sf /usr/share/zoneinfo/yourzone /etc/localtime

替换yourzone 为形如Asia的文件。看看/usr/share/zoneinfo目录都有什么时区。

我这里运行的是:

ln -sf /usr/share/zoneinfo/Asia /etc/localtime

这里假设/usr/share/zoneinfo 是到/etc/localtime 的链结的前提是Redhat Linux

在旧版本的系统里,您会发现使用/usr/lib/zoneinfo而不是/usr/share/zoneinfo。参考后面“一些应用程序中时间错误”。


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/tougao/7955795.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-11
下一篇 2023-04-11

发表评论

登录后才能评论

评论列表(0条)

保存