在运维的日常工作中,服务器是很常见的。而服务器的操作系统因linux系统的优势80%都在用它。不论你用的是centos,Redhat,ubuntu等,这些都是用的Linux内核,所以都是Linux操作系统,区别在于各家公司的封装和优化调整不一样,就造成了不同的发行版本。我们经常听到的都是不同的发行版本而已。而对于Linux系统而言,一切皆文件,对文件的时间表述有3个,分别是:atime,mtime,ctime。很多同学对这3个时间比较困惑且很容易混淆,这里就这个问题以centos为例详细品味。
Linux time
可能有些同学理解下就知道,我们先来说下结论,后面再一一验证。
[root@localhost ~]# ll总用量 8-rw-------. 1 root root 1290 9月 30 10:19 anaconda-ks.cfg-rw-r--r--. 1 root root 4 1月 2 11:22 wandouduoduo[root@localhost ~]# stat wandouduoduo总用量 8-rw-------. 1 root root 1290 9月 30 10:19 anaconda-ks.cfg-rw-r--r--. 1 root root 4 1月 2 11:22 wandouduoduo[root@localhost ~]# stat wandouduoduo 文件:"wandouduoduo" 大小:4 块:8 IO 块:4096 普通文件设备:fd00h/64768dInode:33577049 硬链接:1权限:(0644/-rw-r--r--) Uid:( 0/ root) Gid:( 0/ root)环境:unconfined_u:object_r:admin_home_t:s0最近访问:2020-01-02 11:29:07.301204037 +0800最近更改:2020-01-02 11:22:39.952908458 +0800最近改动:2020-01-02 11:22:39.952908458 +0800创建时间:-[root@localhost ~]# ls -l #默认的ls -l显示的是mtime 总用量 8-rw-------. 1 root root 1290 9月 30 10:19 anaconda-ks.cfg-rw-r--r--. 1 root root 4 1月 2 11:22 wandouduoduo[root@localhost ~]# ls -l --time=atime #指定选项,列出文件的atime总用量 8-rw-------. 1 root root 1290 9月 30 10:19 anaconda-ks.cfg-rw-r--r--. 1 root root 4 1月 2 11:29 wandouduoduo[root@localhost ~]# ls -l --time=ctime #指定选项,列出文件的ctime总用量 8-rw-------. 1 root root 1290 9月 30 10:19 anaconda-ks.cfg-rw-r--r--. 1 root root 4 1月 2 11:22 wandouduoduo
[root@localhost ~]# stat wandouduoduo #获取3个时间 文件:"wandouduoduo" 大小:4 块:8 IO 块:4096 普通文件设备:fd00h/64768dInode:33577048 硬链接:1权限:(0644/-rw-r--r--) Uid:( 0/ root) Gid:( 0/ root)环境:unconfined_u:object_r:admin_home_t:s0最近访问:2020-01-02 11:57:01.410659319 +0800最近更改:2020-01-02 11:57:01.410659319 +0800最近改动:2020-01-02 11:57:01.410659319 +0800创建时间:-[root@localhost ~]# cat wandouduoduo #读取下文件Sun[root@localhost ~]# stat wandouduoduo #再查看时间 文件:"wandouduoduo" 大小:4 块:8 IO 块:4096 普通文件设备:fd00h/64768dInode:33577048 硬链接:1权限:(0644/-rw-r--r--) Uid:( 0/ root) Gid:( 0/ root)环境:unconfined_u:object_r:admin_home_t:s0最近访问:2020-01-02 11:57:23.616643436 +0800最近更改:2020-01-02 11:57:01.410659319 +0800最近改动:2020-01-02 11:57:01.410659319 +0800创建时间:-
结果描述:可以看出来,使用cat读取文件后,文件的atime发生了改变,其他的没有改变。
[root@localhost ~]# stat wandouduoduo #获取3个时间 文件:"wandouduoduo" 大小:4 块:8 IO 块:4096 普通文件设备:fd00h/64768dInode:33577048 硬链接:1权限:(0644/-rw-r--r--) Uid:( 0/ root) Gid:( 0/ root)环境:unconfined_u:object_r:admin_home_t:s0最近访问:2020-01-02 11:57:23.616643436 +0800最近更改:2020-01-02 11:57:01.410659319 +0800最近改动:2020-01-02 11:57:01.410659319 +0800创建时间:-[root@localhost ~]# echo "hello world" >>wandouduoduo #文件写入内容[root@localhost ~]# stat wandouduoduo #再查看时间 文件:"wandouduoduo" 大小:16 块:8 IO 块:4096 普通文件设备:fd00h/64768dInode:33577048 硬链接:1权限:(0644/-rw-r--r--) Uid:( 0/ root) Gid:( 0/ root)环境:unconfined_u:object_r:admin_home_t:s0最近访问:2020-01-02 11:57:23.616643436 +0800最近更改:2020-01-02 11:59:54.107480965 +0800最近改动:2020-01-02 11:59:54.107480965 +0800创建时间:-
结果描述:可以看出,写操作不会对atime(访问时间)有任何影响,但mtime和ctime都发生了修改。mtime修改了我们是可以理解的,毕竟我们修改了文件。那为何ctime也修改了呢? 仔细观察,我们发现文件的大小也发生了变化,也就是元数据发生了变化,所以ctime也是要变化的。
[root@localhost ~]# stat wandouduoduo #获取3个时间 文件:"wandouduoduo" 大小:16 块:8 IO 块:4096 普通文件设备:fd00h/64768dInode:33577048 硬链接:1权限:(0644/-rw-r--r--) Uid:( 0/ root) Gid:( 0/ root)环境:unconfined_u:object_r:admin_home_t:s0最近访问:2020-01-02 11:57:23.616643436 +0800最近更改:2020-01-02 11:59:54.107480965 +0800最近改动:2020-01-02 11:59:54.107480965 +0800创建时间:-[root@localhost ~]# chown sun wandouduoduo #修改文件权限[root@localhost ~]# stat wandouduoduo #再查看时间 文件:"wandouduoduo" 大小:16 块:8 IO 块:4096 普通文件设备:fd00h/64768dInode:33577048 硬链接:1权限:(0644/-rw-r--r--) Uid:( 1000/ sun) Gid:( 0/ root)环境:unconfined_u:object_r:admin_home_t:s0最近访问:2020-01-02 11:57:23.616643436 +0800最近更改:2020-01-02 11:59:54.107480965 +0800最近改动:2020-01-02 12:06:29.115867565 +0800创建时间:-
结果描述:可以看出,修改了权限后,文件ctime发生了变化。
通过上面的实验,我们也对这三个时间有了清晰的认识。如有疑问,欢迎留言评论。