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
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里