能够看到,用ls -l命令查看某一个目录会获得一个7个字段的列表。linux
第1行:总计(total)shell
Total后面的数字是指当前目录下全部文件所占用的空间总和。可使用ls –lh查看,也可以使用ls –alh查看。编程
第1字段: 文件属性字段windows
-rw-r--r--. 1 root root 100 12月 19 19:28 daemon.logspa
文件属性字段总共有10个字母组成;第一个字符表明文件的类型。3d
字母“-”表示该文件是一个普通文件blog
字母“d”表示该文件是一个目录,字母"d",是dirtectory(目录)的缩写it
注意:目录或者是特殊文件,这个特殊文件存放其余文件或目录的相关信息class
字母“l”表示该文件是一个连接文件。字母"l"是link(连接)的缩写,相似于windows下的快捷方式test
字母“b”的表示块设备文件(block),通常置于/dev目录下,设备文件是普通文件和程序访问硬件设备的入口,是很特殊的文件。没有文件大小,只有一个主设备号和一个辅设备号。一次传输数据为一整块的被称为块设备,如硬盘、光盘等。最小数据传输单位为一个数据块(一般一个数据块的大小为512字节)
字母为“c”表示该文件是一个字符设备文件(character),通常置于/dev目录下,一次传输一个字节的设备被称为字符设备,如键盘、字符终端等,传输数据的最小单位为一个字节。
字母为“p”表示该文件为命令管道文件。与shell编程有关的文件。
字母“s”表示该文件为sock文件。与shell编程有关的文件。
第1字符的后面9个字母表示该文件或目录的权限位。
r表是读 (Read) 、w表示写 (Write) 、x表示执行 (eXecute)
其中前三个表示文件拥有者的权限,中间三个表示文件所属组拥有的权限,最后三个表示其余用户拥有的权限。
第2字段:文件硬连接数
-rw-r--r--. 1 root root 100 12月 19 19:28 daemon.log
若是一个文件不是目录,此时这一字段表示这个文件所具备的硬连接数,
第2字段的值为1,说明这个文件只有daemon.log这一个文件名。即只有一个指向该连接的硬连接。。
若是使用ln,作一个指向该文件的硬连接再查看该文件,该文件的第2字段就会变成2
此时daemon.log 和daemon称为互为硬连接。他们指向同一个文件,不管是修改哪个文件,另外一个里也作相应的变化,由于实际上他们指向同一个文件(即同一文件的不一样文件名)
互为硬连接的文件具备相同的文件节点。
能够看出,这两个文件具备相同的文件节点号:162302
能够设置符号连接(软连接),格式以下
ln –s 源文件 目标连接文件
注意:软连接时文件节点号不同:
若是知道一个文件有多个文件名(连接文件)如何查找他的其余文件名分布在什么地方呢?
能够先用ls -i 得到它的节点号,而后用find查找,如 /home/zzw/Desktop/网设大做业/第一次 要查找与它互为硬连接的文件
获得它的节点号为 207131084
再用find查找:
这样就获得了同一个文件的不一样文件名的位置
(此处文件只有一个文件名)
第2字段: 连接占用的节点
-rw-r--r--. 1 root root 100 12月 19 19:28 log ->daemon.log
该字段文件占用一个节点,属于软连接(符号连接)
若是是一个目录,则第2字段表示该目录所含子目录的个数。
新建一个空目录,这个目录的第二字段就是2,表示该目录下有两个子目录。为何新建的目录下面会有两个子目录呢?
由于每个目录都有一个指向它自己的子目录"。" 和指向它上级目录的子目录"。。",这两个默认子目录是隐藏的。ls -a能够看到
每次在目录下新建一个子目录,该目录第2字段的值就增1,可是新建一个普通文件该字段值不增长。
第3字段:文件(目录)拥有者
-rw-r--r--. 1 root root 100 12月 19 19:28 log ->daemon.log
该字段表示此文件是属于哪一个用户。linux类系统都是多用户系统,每一个文件都有它的拥有者。只有文件的拥有者才具备改动文件属性的权利。
固然, root用户具备改动任何文件属性的权利。对于一个目录来讲,只有拥有该目录的用户,或者具备写权限的用户才有在目录下建立文件的权利
若是某一个用户由于某种缘由,被删除,而该用户的文件还存在,那么用ls -l 查看该文件将显示一个表明用户存在前ID号的数字。
先建立一个用户test,将其加入wang用户组,并用su切换,使用ls –l查看文件拥有者,随即删除用户test,用root进入test家目录,查看刚刚建立的文件testing。
能够看到,第三字段成了一个数字,这个数字是原test用户的ID号。由于文件系统对每一个文件记录文件全部者的ID,而非用户名。
第4字段:文件(目录)拥有者所在的组
-rw-r--r--. 1 root root 100 12月 19 19:28 log ->daemon.log
一个用户能够加入不少个组,可是其中有一个是主组,就是显示在第4字段的名称。
能够在useradd的时候用-g指定该用户所在的主组,用-g指定其余组
格式以下:useradd –g 组名 用户名
第5字段: 文件所占用的空间(以字节为单位)
-rw-r--r--. 1 root root 100 12月 19 19:28 log ->daemon.log
第5字段表示文件大小,若是是一个文件夹(目录),则表示该文件夹的大小。请注意是文件夹自己的大小,而不是文件夹以及它下面的文件的总大小。
不少人不能理解文件夹是一个特殊的文件的含义,这样的话理解文件夹大小的含义就比较困难了。
第6字段:文件(目录)最近访问(修改)时间
-rw-r--r--. 1 root root 100 12月 19 19:28 log ->daemon.log
文件建立的时间能够经过touch命令来修改。如:
[root@localhost ~]# touch daemon.log
能够把daemon.log的建立时间修改成当前时间,另外,一个文件还有最后访问时间,最后修改时间等属性。
这些属性能够用ls 的其它参数显示出来。
第7字段:文件名
lrwxrwxrwx 1 root root 4 08-03 08:27 log->daemon.log
若是是一个符号连接,那么会有一个 “->" 箭头符号,后面根一个它指向的文件名
好比: