Linux文件属性,类型,ls -lhi解释行列

Linux文件属性(描述信息)

-i inode节点号
-h 人类可读

ls -lhi
1703938 drwxr-xr-x 2 rsync rsync 4.0K Jun  7 07:24 gameserver1
第一列:文件的索引节点号(人的身份证,linux系统唯一)
系统读取文件时首先通过文件名找到inode,然后才能读取文件内容。

第二列:文件的类型和权限,第一个字符文件的类型,后九个字符是文件的权限,最后一个字符.是和selinux相关的标识

第三列:硬链接的数量,同一个文件的不同的访问路口

第四列:文件或目录所属的用户,属主
linux里面文件和程序的存在必须要有用户和组满足的存在需求

第五列:文件或目录所属的组

第六列:文件大小

第七列:第八列:第九列:文件的修改时间 对应的是-mtime时间,默认是月日时分
ctime是属性的改变,atime访问

第十列:文件名称
文件名不算文件的属性

第一列:索引节点inode

inode 索引节点,英文就是 index node
硬盘要存储数据,首先要分区,然后格式化创建文件系统,最后存储数据

每个linux存储设备或存储设备的分区被格式化为ext4文件系统后(管理文件的一种机制),一般生成2部分,inode和block

block是用来存储数据的用的。
inode就是用来存储数据属性信息的(相当于ls -l的结果),inode属性信息包括不限于文件大小,属主,归属的用户组,文件权限,文件类型,修改时间,还包含指向文件实体的指针,但是inode里面唯独不包含文件名,还会为每个文件进行信息索引,就是inode的数值。

书的目录索引就相当于inode,每一页相当于block,整本书就是一个扇区

stat 显示文件,文件系统状态(查看文件属性)
stat /etc/hosts 也可以查看inode,详细的查看文件信息

[root@Poppy ~]# stat /etc/hosts
  File: ‘/etc/hosts’
  Size: 204             Blocks: 8          IO Block: 4096   regular file
Device: fd01h/64769d    Inode: 1183348     Links: 1
Access: (0644/-rw-r--r--)  Uid: (    0/    root)   Gid: (    0/    root)
Access: 2018-06-19 14:10:17.421425118 +0800
Modify: 2018-06-14 14:05:07.713140443 +0800
Change: 2018-06-14 14:05:07.716140534 +0800
 Birth: -

因为inode要存放文件的属性,所以每个inode本身是有大小的,centos5默认大小事128字节,centos6是256字节,inode的大小在文件系统被格式化创建文件系统之后定下来的,格式化以后就无法更改inode大小,格式化之前可以通过参数指定inode的大小,但是一般不需要改

文件系统的默认inode大小
[root@Poppy ~]# dumpe2fs /dev/vda1|grep -i "inode size"
dumpe2fs 1.42.9 (28-Dec-2013)
Inode size:               256

文件系统inode总量以及剩余量
[root@Poppy ~]# df -i
Filesystem      Inodes  IUsed   IFree IUse% Mounted on
/dev/vda1      2621440 151967 2469473    6% /
devtmpfs        233122    320  232802    1% /dev
tmpfs           235465      1  235464    1% /dev/shm
tmpfs           235465    406  235059    1% /run
tmpfs           235465     16  235449    1% /sys/fs/cgroup
tmpfs           235465      1  235464    1% /run/user/0

磁盘空间是否满了,第一个是inode是否满了,第二个事block满了 
磁盘满了的特征 no space device left on

我们总结一下inode节点

1. 磁盘被分区并格式化为ext3/ext4文件系统后会生成一定数量的inode和block
2. inode称为索引节点,它的作用就是存放文件的属性信息以及作为文件的索引(指向文件的实体)
3. ext3/ext4文件系统的block存放的是文件的实际内容
4. inode是磁盘上的一块存储空间,centos6非启动分区inode默认大小256字节,centos5是128字节
5. inode的表现形式是一串数字,不同的文件对应的inode(一串数字)在文件系统里是唯一的。
6. inode相同的文件,互为硬链接文件
7. ext3/ext4文件系统下,一个文件被创建后至少要占用一个inode和一个block
8. ext3/ext4文件系统下,正常情况下一个文件占用且只能占用一个inode
9. block是用来存储数据的,每个block大小一般有1k,2k,4k几种,其中引导分区等为1k,其他普通分区为4k
10. 如果一个文件很大,可能占多个block,如果文件很小,至少也要占一个block,并且这个block的剩余空间就浪费了,即无法在存储其他数据了
11. inode大小和block总量查看
[root@Poppy ~]# dumpe2fs /dev/vda1 |egrep -i "block size|inode size"
dumpe2fs 1.42.9 (28-Dec-2013)
Block size:               4096
Inode size:               256

[root@Poppy ~]# dumpe2fs /dev/vda1 |egrep -i "block count|inode count"   
dumpe2fs 1.42.9 (28-Dec-2013)
Inode count:              2621440
Block count:              10485248
Reserved block count:     524262
默认block count一般会大于inode count的数量

12. 查看inode的总量和使用量命令 df -i

13. 查看文件的inode
ls -li 或 stat /etc/hosts

14. 改变inode大小
格式化的时候: mkfs.ext4 -b 2048 -I 256 /dev/sda

15. lsof|grep deleted
找到对应的进程,重启。因为的有时间程序日志输出占用空间

1. block块

1. 磁盘读取数据是按block为单位读取的
2. 一个文件可能占用多个block。但是每读取一个block就会消耗一次磁盘i/o
3. 如果要提升磁盘io性能,那么就要尽可能一次性读取数据尽量的多
4. 一个block只能存放一个文件的内容,无论内容有多小。如果blcok默认是4K大小,那么存放一个1K的文件,剩余3K就不能存放别的文件,只能浪费了
5. block太大,例如4k,文件都是0.1k,浪费磁盘空间,但是访问性能高
6. block太小,例如1k,文件都是1000k,消耗大量磁盘I/O
7. block的大小设置十四载格式化分区时候确定的,mkfs.ext4 -b 2048 -I 256 /dev/vda/
8. 企业里文件都比较大(一般大于4K),block设置大一些会提升磁盘访问效率
9. ext3/ext4文件系统,一般都是设置为4k

2. inode和block的总结

1. 磁盘被分区格式化文件系统后,会分为inode和block俩部分内容
2. inode存放文件的属性以及指向文件实体的指针,文件名不在inode里,一般上级目录的block里
3. 访问文件,通过文件名---inode---blocks
4. inode一般情况下大小是256b,block大小1,2,4k,默认是4k,注意,引导分区等特殊分区除外
5. 通过df -i查看inode的数量以及使用情况,dumpe2fs /dev/vda1 查看inode及block的大小及数量
6. 一个文件至少要占用一个inode及一个block,多个文件可以占用同一个inode(硬链接),相同文件
7. 一个block只能被一个文件使用,如果文件很小block很大,剩余空间浪费,无法继续被其他文件使用
8. block不是越大越好,要根据业务的文件大小进行选择,一般默认4k 
9. 可以在格式化的时候改变inode及block的大小

第二列:文件类型,权限,点

ls -lhi
1703938 drwxr-xr-x 2 rsync rsync 4.0K Jun  7 07:24 gameserver1

一 文件类型

在inux系统中,一切皆文件

普通文件的创建:touch cp > tar 

1. 普通文件包括:

2. 目录文件

[root@Poppy joker]# tree -Ld 1 /joker    显示目录结构
/joker
├── gameserver1
├── gameserver2
├── scripts
└── tools

4 directories 
-L layer层数, -d目录

3. 字符设备文件

字符设备或块设备
[root@Poppy joker]# ls -al /dev/tty
crw-rw-rw- 1 root tty 5, 0 Jun 12 11:33 /dev/tty

4. 块设备文件

什么是块设备,就是存放数据的,就是磁盘
[root@Poppy ~]# find /dev -type b|xargs ls -l
brw-rw---- 1 root disk 253, 0 Jun  6 14:09 /dev/vda
brw-rw---- 1 root disk 253, 1 Jun  6 14:10 /dev/vda1

5. 套接字文件

用于网络通信的,数据库mysql.sock

[root@Poppy ~]# find /dev -type s |xargs ls -l
srw-rw-rw- 1 root root 0 Jun  6 22:09 /dev/log

6. 符号链接文件

快捷方式,指向文件的实体

[root@Poppy ~]# find /application/ -type l|xargs ls -l
lrwxrwxrwx 1 root  root  26 Jun 13 10:30 /application/apache -> /application/apache2.4.33/

7. 管道文件

特殊的文件类型,主要是解决多个程序同时访问一个文件所造成的错误,第一个字符为p

8. 扩展名文件

linux中的文件是不需要扩展名的,为了 兼容window,便于我们大多数习惯了windows的用户区分文件的不同

如何查看文件类型

[root@Poppy joker]# file a
a: ASCII text
[root@Poppy joker]# file /bin/ls
/bin/ls: ELF 64-bit LSB executable, x86-64, version 1 (SYSV), dynamically linked (uses shared libs), for GNU/Linux 2.6.32, BuildID[sha1]=3d705971a4c4544545cb78fd890d27bf792af6d4, stripped
[root@Poppy joker]# file /var/log/wtmp 
/var/log/wtmp: data

二 权限位

- 没有权限 0 , r 4 w 2 x 1
前三位 属主权限位(用户权限位),中三位 属组权限位(用户组),后三位 其它用户权限位

三 关于.

.与selinux相关的状态,如果把selinux关闭,目录文件将不会有这个.

第三列:链接数量 

一种是硬链接,还有一种是软连接或符号链接

1. 硬链接
通过ln命令创建的硬链接,而通过ln -s创建的链接是软链接

命令演示
ln 源文件    目标文件
ln -s 源文件 目标文件,不能事先存在

硬链接是通过inode来进行链接,在linux系统中,多个文件名指向同一个索引节点是正常允许的,这种情况的文件就称为硬链接文件。硬链接文件就相当于文件的另外一个入口。作用之一是允许一个文件拥有多个有效路径名,以防止误删除。

[root@Poppy joker]# echo 1 > a
[root@Poppy joker]# ln a b
[root@Poppy joker]# ls -lhi
total 744K
1717994 -rw-r--r-- 2 root  root     2 Jun 20 14:06 a
1717994 -rw-r--r-- 2 root  root     2 Jun 20 14:06 b
所以即使你删除了a,还能通过b来恢复重定向

linux下文件删除的原理

只要文件的inode还有一个以上的硬链接,只删除其中一个硬链接并不影响inode本身和其它的链接,只有当文件的最后一个链接被删除后,被删除的文件的数据块才会被释放。
i_link(硬链接数量),为0,文件就被删除。
i_count(进程引用计数),为0,文件就被删除。
文件的删除条件为,i_link和i_count都为0,才可删除文件,虽然删除还是删除的inode节点,并不是真正删除内容,但是后面产生的新数据会覆盖这些数据
如果你删除文件,但是磁盘还是没有释放空间,多数因为进程还在调用这个文件,可以重启服务,或者通过重定向清空文件

硬链接知识小结:

1. 具有相同inode节点号的多个文件是互为硬链接文件
2. 删除硬链接文件或者删除源文件任意之一,文件实体并未被删除
3. 只有删除了源文件及所有对应的硬链接文件,文件实体才会被删除
4. 当所有的硬链接文件及源文件被删除后,再存放新的数据会占用这个文件的空间,或者磁盘fsck检查的时候,删除的数据也会被系统回收
5. 硬链接文件就是文件的另一个入口
6. 可以通过给文件设置硬链接文件,来防止重要文件被误删除
7. 通过执行命令“ln 源文件 硬链接文件”,即可完成创建硬链接
8. 硬链接文件是普通文件,因此可以用rm命令删除
9. 对于静态文件来讲,当对应硬链接数为0,文件就被删除,ls -l第三列就是

2. 软链接

快捷方式,就是一个指向

[root@Poppy joker]# ls -lhi a b
1717994 -rw-r--r-- 1 root root 0 Jun 20 14:50 a
1717995 lrwxrwxrwx 1 root root 1 Jun 20 14:50 b -> a
访问软链接的时候其实软链接保存了源文件的路径地址

软连接知识小结

创建软连接源文件是需要存在的,要创建的软连接文件是不能存在的,是要用ln命令创建的
1. 软连接类似windows的快捷方式(可以通过readlink查看其指向)
2. 软连接类似一个文件文件,里面存放的是源文件的路径,指向源文件实体
3. 删除源文件,软连接文件依然存在,但是无法访问指向的源文件路径内容了
4. 失效的时候一般是白字红底闪烁提示
5. 执行命令“ln -s 源文件 软连接文件”,即可完成创建软链接(目标不能存在)
6. 软连接和源文件是不同类型的文件,也是不同的文件。inode号也不相同
7. 软连接文件的文件类型为l,可以用rm命令删除

目录软连接知识

.为什么是当前目录,因为它与当前目录互为硬链接
[root@Poppy joker]# ls -aldi gameserver1 gameserver1/.
1703938 drwxr-xr-x 3 rsync rsync 4096 Jun 20 15:19 gameserver1
1703938 drwxr-xr-x 3 rsync rsync 4096 Jun 20 15:19 gameserver1/.


..为什么是上级目录,因为它与上级目录互为硬链接
[root@Poppy joker]# ls -aldi gameserver1 gameserver1/. gameserver1/2/..
1703938 drwxr-xr-x 3 rsync rsync 4096 Jun 20 15:19 gameserver1
1703938 drwxr-xr-x 3 rsync rsync 4096 Jun 20 15:19 gameserver1/.
1703938 drwxr-xr-x 3 rsync rsync 4096 Jun 20 15:19 gameserver1/2/..

1. 对于目录,不可以创建硬链接,但是可以创建软链接
2. 对于目录的软连接是生产场景运维中的常用的技巧
3. 目录的硬链接不能跨越文件系统
4. 每个目录下面都有一个硬链接“.”号,和对应上级目录的硬链接”..“
5. 再敷目录里创建一个子目录,父目录的连接数增加1(每个子目录里都有..来指向父目录),但是再父目录里创建文件,父目录的连接数不会增加

第四列,五列:用户和用户组

linux是一个多用户,多任务的操作系统

用户的角色是通过uid和gid识别的,特别是uid,在linux系统运维工作中,一个uid是唯一标识一个系统用户的账号(相当于我们的身份证),用户系统账号的名称其实给人看的,linux系统能识别仅仅是uid和gid这样的数字

1. 超级用户

root是超级用户,uid和gid都是0,拥有最高的管理权限

2. 普通用户

500-65535 普通用户
su -root  角色切换
sudo ls   授权

3. 虚拟用户

1-499 虚拟用户
安装软件时候自带的用户,不能登录的用户

4. 用户相关的文件

# /etc/passwd        用户的配置文件
账号名称 账号密码 账号uid 账号gid 用户说明 用户家目录 shell解释器
[root@Poppy conf]# cat /etc/shells 
/bin/sh
/bin/bash
/sbin/nologin
/usr/bin/sh
/usr/bin/bash
/usr/sbin/nologin

# /etc/shadow        用户口令文件
账号名称 账号密码 最近更改密码的时间 禁止修改密码的天数 用户必须更改口令的天数 警告更改密码的期限 不活动时间 失效时间 标志

# /etc/group         组的配置文件
用户组名 用户组密码 gid 用户组成员
# /etc/gshadow       组的口令文件

第六列:大小

文件或者目录的大小

第七列 ,八列, 九列:时间

modify修改时间 mtime 一般修改文件内容的时候
change改变时间 ctime 文件的属性改变,大小,权限等
access访问时间 atime 访问文件内容的时候

[root@Poppy conf]# ls -l --time-style=long-iso 
total 124
drwxr-xr-x 2 root root  4096 2018-06-13 16:46 extra
-rw-r--r-- 1 root root 18566 2018-06-13 16:05 httpd.conf
-rw-r--r-- 1 root root 18410 2018-06-13 15:07 httpd.conf.bak
-rw-r--r-- 1 root root 13077 2018-06-13 10:24 magic
-rw-r--r-- 1 root root 60847 2018-06-13 10:24 mime.types
drwxr-xr-x 3 root root  4096 2018-06-13 10:24 original

查看文件的时间属性
stat 后面接文件或者属性
[root@Poppy conf]# stat /joker/
  File: ‘/joker/’
  Size: 4096            Blocks: 8          IO Block: 4096   directory
Device: fd01h/64769d    Inode: 1703937     Links: 6
Access: (0755/drwxr-xr-x)  Uid: ( 1000/   rsync)   Gid: ( 1000/   rsync)
Access: 2018-06-20 14:55:54.246604690 +0800
Modify: 2018-06-20 14:55:53.766590115 +0800
Change: 2018-06-20 14:55:53.766590115 +0800
 Birth: -

第10列:文件名

不在inode里,而是在上级目录的block里

 

posted @ 2018-06-05 10:11  liqianlong  阅读(943)  评论(0编辑  收藏  举报