Linux文件、目录属性
文件、目录属性
可能有人觉得,文件这东西这么普通有什么好讲的,,,其实不然,在linux中一切皆文件,搞清楚文件的本质,将对我们大有裨益。
文件、目录属性简介
举个例子
randolf@localhost:~/pytest/pythondemo $ ls -lih
总用量 16K
105674 drwxrwxr-x. 4 randolf randolf 160 1月 21 17:58 appium
33870718 drwxrwxr-x. 2 randolf randolf 235 1月 21 17:58 beautifulsoup
16800015 drwxrwxr-x. 2 randolf randolf 110 1月 21 17:58 cnki
先说一下命令的选项,-i: inode(节点) -h: human-readable(人眼易读的) -l: 显示长信息(详细信息)
第一列:索引节点号(系统通过inode找到文件内容,类似于我们通过身份证号查找个人信息)
第二列:类型及权限属性(第1个字符为文件类型,后9个字符是权限信息),如果一个目录,具有可执行权限,则意味着可以进入这个目录。 第三列:硬链接数
第四列:文件或者目录所属用户
第五列:文件或者目录所属用户
第六列:文件或者目录的大小
第七八九列:文件或者目录的修改时间;按照月、时、分钟的顺序
第十列:实际的文件名或者目录名(不算文件属性)
属性深入解读
1. 索引节点(index node)与block数据存储
一块新的硬盘 ->分区(打隔断)->格式化系统 ->存数据
格式化文件系统(ext4、xfs)后,一般会有两部分:inode与block.
1.inode就是用来存放属性信息的,即
ls -l
的内容(不包括最后一列的文件名,文件名不算属性)2.流程:inode(ls -l) -->文件属性,是否具有对文件或者目录的相应权限 -->block中文件的数据内容
3.也可以通过
stat filename
查看文件详细信息4.inode大小:centos5 中128字节,centos7中默认256字节
格式化以后inode大小无法改变(格式化后inode和blocK分配的数量固定,所以磁盘满了有两种情况:inode用完了,block不够用)。
5.inode具有唯一性,inode相同的文件互为硬链接文件,其实就是同一个文件的不同入口。
1.block存储实际数据,单个block大小一般为1k、2k,4k等几种。其中引导分区一般1k,其他普通分区一般为4k.
2.一个block只能存放一个文件的内容,无论文件有多小。如果一个block为4k存放的文件是1k,那么剩余的3k就浪费了。所以说,block并不是越大越好。
3.根据实际需求设置block大小,大文件多就设置block大一些,小文件多一些,就设置block小一点。
4.block的大小在格式化分区时设置:
mkfs.ext4 -b 2048 -I 256 /dev/sdb
-b设置block大小,-I设置inode大小。5.centos5和centos6文件系统为ext3/ext4,centos7文件系统为xfs.
2.文件类型
文件类型 | 描述 |
---|---|
d(directory) | 目录文件,目录是一个特殊的文件 |
-(regular file) | 表示这是一个普通的文件 |
l(link) | 符号链接文件,实际上指向另一个文件 |
b(block) | 块设备和其他外围设备,特殊类型文件 |
c(character) | 字符设备文件 |
s(socket) | 表示socket文件 |
p(named pipe) | 表示管道文件 |
前四个是重点,也是常见文件类型,后面三个基本用不到。
3.权限属性
以rwxr-xr-x
为例,三位为一组,前三位为用户权限位,中间三位是属组权限位,后三位是其他人权限。
r :read 读 4;w :write 写 2;x :excute 执行 1; - 没有权限 0
4.用户与组属性简介
Linux中角色决定权限,角色不同,权限和完成的任务也不同;在linux中由UID唯一标记一个用户,由GID唯一标记一个用户组。
用户简单分类
-
超级用户:即root用户(系统管理员),拥有至高无上的权限,其UID和GID都为0。
-
普通用户:通过
useradd
创建,只能操作自己家目录下的文件,要想做超越权限的事情,可以利用sudo
进行提权或者直接切换到管理员身份su - root
-
虚拟用户 : 安装系统后默认存在的,这些傀儡用户大多不能登录系统,他们存在的意义主要在于方便系统管理,满足相应的系统进程对属主的要求,如下,以nologin结尾的就是所谓的虚拟用户。
randolf@localhost:~ $ cat /etc/passwd|head -4 root:x:0:0:root:/root:/bin/bash bin:x:1:1:bin:/bin:/sbin/nologin daemon:x:2:2:daemon:/sbin:/sbin/nologin adm:x:3:4:adm:/var/adm:/sbin/nologin
与用户[组]相关的文件
-
/etc/passwd
randolf@localhost:/ $ sudo cat /etc/passwd |head -2 root:x:0:0:root:/root:/bin/bash bin:x:1:1:bin:/bin:/sbin/nologin
各个字段分别代表:用户名、密码(x)、UID、GID、注释、用户的家目录、用户所使用的默认shell
用户密码被重定向到了shadow文件,所以用x来表示。
-
/etc/shadow
randolf@localhost:/ $ sudo cat /etc/shadow | tail -2 randolf:$6$./CktF0O$giEudjhAawSmBjkt.opCVs2Q3ERXNJWsZZnGvQ4QEkbK5nGRkKH1PrAa4HuRwCDPYTAUrdvZOPSzlW1Jm0M.W/:17912:0:99999:7::: bash:$6$nhdotNEp$cufcTHgYi.9OjPI6ky1zh1EPbAGH7hWZjodfSlzAdeV5R1AKefxIifceFr/R6lskGkw1nemBTH422o9x14wOK.:17912:0:99999:7:::
各个字段分别表示:1.用户名、2.密码、3.时间戳、4.过多久可以修改密码(为0则表示可以立即修改密码)、5.密码使用期限、6.距离到达最长使用时间多久提示修改密码 、7.到达使用期限后的多少天仍然可以登录,但是必须修改密码
密码是经过加密的,如果密码位显示!!,则表示该用户未设置密码,禁止登录。
时间戳是指,从1970-01-01到最近一次修改密码所经过的时间。
-
/etc/group
randolf@localhost:/ $ cat /etc/group|head -3 root:x:0: bin:x:1: daemon:x:2:
-
/etc/gshadow
randolf@localhost:/ $ sudo cat /etc/gshadow|head -3 [sudo] randolf 的密码: root::: bin::: daemon:::
5.时间属性
1.这个可说的东西不多,首先看看显示格式
#一般的长格式显示
randolf@localhost:/tmp $ ls -l
总用量 8
-rw-r--r--. 1 root root 43 1月 17 03:45 date.txt
-rw-r--r--. 1 root root 28 1月 22 17:40 file2.txt
#控制时间的格式,使用--time选项
randolf@localhost:/tmp $ ls -l --time-style=long-iso
总用量 8
-rw-r--r--. 1 root root 43 2019-01-17 03:45 date.txt
-rw-r--r--. 1 root root 28 2019-01-22 17:40 file2.txt
似乎好看一点,,哈哈,其实有时候筛选字段会用到他的。
2.使用stat
命令查看文件的时间属性
randolf@localhost:/tmp $ stat date.txt
File: 'date.txt'
Size: 43 Blocks: 8 IO Block: 4096 regular file
Device: fd00h/64768d Inode: 16777289 Links: 1
Access: (0644/-rw-r--r--) Uid: ( 0/ root) Gid: ( 0/ root)
Context: unconfined_u:object_r:user_tmp_t:s0
Access: 2019-01-17 03:45:02.645805264 +0800
Modify: 2019-01-17 03:45:01.155796938 +0800
Change: 2019-01-17 03:45:01.155796938 +0800
Birth: -
从这里我们可以查看到文件包括访问时间、修改时间,改变时间在内的详细信息。如果是小白看到这里可能要蒙圈了,“修改时间和改变时间有区别???”,其实这里“修改时间”指的是我们对文件做了修改,“改变时间”则是指文件的状态发生了变化,比如文件大小,再比如文件拥有者或属组发生变化,概括来说就是我们文件的属性发生变化,则这个ctime就发生变化。下面举个栗子:
#当前目录下有个叫做date.txt的文件,来看一下他们的初始时间属性
[root@localhost tmp]# stat date.txt | tail -4
Access: 2019-01-17 03:45:02.645805264 +0800
Modify: 2019-01-17 03:45:01.155796938 +0800
Change: 2019-01-17 03:45:01.155796938 +0800
Birth: -
#向文本中追加内容
[root@localhost tmp]# echo `date` >> date.txt
#再次查看文件时间属性
[root@localhost tmp]# stat date.txt | tail -4
Access: 2019-01-17 03:45:02.645805264 +0800
Modify: 2019-01-23 15:58:07.939618364 +0800
Change: 2019-01-23 15:58:07.939618364 +0800
Birth: -
我们向文本中追加内容后,其大小也发生变化,因此mtime与ctime同时发生变化。
再举个例子:
[root@localhost tmp]# chown randolf:randolf date.txt
[root@localhost tmp]# stat date.txt | tail -4
Access: 2019-01-17 03:45:02.645805264 +0800
Modify: 2019-01-23 15:58:07.939618364 +0800
Change: 2019-01-23 16:16:30.692778301 +0800
Birth: -
我们改变其拥有者和数组,发现只改变了ctime,而mtime并未发生改变,可见mtime改变了ctime一定改变(文件大小属性变化),而ctime改变时,mtime却不一定发生改变。