linux文件属性及 ls -l 命令输出结果详解
linux文件属性及 ls -l 命令输出结果详解
目录
一、ls -l 输出的内容概略
注:本图片转自:https://blog.51cto.com/13447608/2151610 ,图画的很好,我就懒得画了,直接转过来啦
二、ls -l 输出内容详解
1、命令
一般使用ls -l命令,更全的输出信息使用,a表示全部,h表示文件大小以人类易读的形式给出,i表示索引节点,l表示长列表形式。
ls -ahil
2、inode索引节点编号
- inode中存放了文件的创建者、创建时间、文件大小、文件存放的块的位置等信息,总之除了文件名和文件内容外其他的信息都存在这个inode中。
- 每个文件都有一个inode号码。
- inode号码相同,说明这些文件是硬连接的关系。
- 其他inode知识这里不再详述。
3、文件类型
该列表示文件的类型,文件类型有:
- “-” 表示普通文件,如*.txt,*.c,*.h
- “d” 表示目录,directory
- “l” 表示软链接文件(ln -s 创建的),link file
- “p” 表示pipe管道文件
- “b” 表示块设备文件,block device
- “c” 表示字符设备文件,char device
- “s” 表示socket套接字文件,用于实现两个进程间通信
4、文件属性
红框中圈出来的部分,共9个字符来表示,3个一组,共3组,拿最后一个test目录来说:[rwx][r-x][r-x],这3组分别表示文件所有者的权限,组的权限和其他用户的权限。
- r(read,读权限) :对文件来说,具有读取文件内容的权限;对目录来说,具有浏览目录及子目录的权限。
- w(write,写权限):对文件来说,具有修改、删除文件内容的权限;对目录来说,具有删除、移动目录内文件的权限。
- x(execute,执行权限):对文件来说,具有执行文件的权限;对目录来说,该用户具有进入目录的权限。
- - :表示无任何权限。
- -----------------------------------------------------------------------------------------------------------------
- 还有3个特殊权限,分别是set uid(suid),set gid(sgid),粘滞位sticky(t);它们分别用来设置文件所有者(属主)的权限、组的权限,其他权限;这样文件权限共有9+3=12位(bits)来表示,但是显示到具体的字符上,文件权限只用9个字符来表示,因为3个特殊权限位合并到前面已有的普通权限位上了,这样就形成了复合权限的9个/位字符表示方式。
- set uid(suid):只针对命令和二进制程序。
- 只在执行时权限才有效。
- 二进制程序需要有x可执行权限配合使用,即x位是s才可以。
- 属主x权限位上有x权限,增加suid权限后,x变为s【小写s】。
- 属主x权限位上无x权限,增加suid权限后,x变为S【大写S】。
- 增加suid权限后,原来没有属主权限(如root等)的其他普通用户也拥有了属主的权限,这样普 通用户就可以像属主一样操作这个程序或命令,类似与把这个命令或程序的属主权限共享出来了 一样,所有用户都可以使用,是不是有点危险感,比sudo还要可怕。
- set gid(sgid):针对用户组的权限位。
- 可针对命令、二进制程序、目录等文件,比suid范围要广。
- 二进制程序需要有x可执行权限配合使用,即x位是s才可以。
- 属组x权限位上有x权限,增加sgid权限后,x变为s【小写s】。
- 属组x权限位上无x权限,增加sgid权限后,x变为S【大写S】。
- 增加sgid权限后,执行命令的任意用户可以获得该命令执行期间所属组的所有权限。
- 粘滞位sticky(t):针对除了属主和属组外其他用户的权限位。
- 只针对目录有效,其他文件即使设置了也没用,直接被内核忽略了。
- 其他用户x权限位上有x权限,增加sticky权限后,x变为t【小写t】。
- 其他用户x权限位上无x权限,增加sticky权限后,x变为T【大写T】。
- 目录增加sticky权限后,目录下的所有文件都可以被任何人读写,所有文件都是共享的。
- 目录增加sticky权限后,只有属主和root用户才可以删除该目录下的文件,其他人不能。
- 目录增加sticky权限后,用户自建的目录不会继承sticky权限。
下面演示了3个特殊的权限,详细的关于权限修改等问题,请看我的关于权限修改的博文。
5、目录或链接的个数
- 对于普通文件来说,该值表示的是链接数目,即硬链接或软链接的数据。
比如:copy_my.sh和my.sh的inode号相同,说明这2个文件互为硬链接,故他们的链接数均为2。
- 对于目录来说,该值表示该目录下所有目录的总数,即该值=2+该目录下所有目录数目。注:不含该目录下目录的子目录。
其中2表示的是当前目录下的“.目录”和“..目录”这2个目录,所有目录下都会自动创建这2个目录,所以这个2是常数。linux下凡是名字以点'.'开头的文件都是隐藏文件。“.目录”表示的是当前目录,“..目录”表示上一级目录。
“.目录”的目录个数为3,因为当前目录下有1个test目录,所以该值=2+1=3;“..目录”的值是43,说明上一级目录除了2个固定目录外还有43-2=41个目录。
test目录的目录数目为2,因为它下面无目录,所以该值=2+0=2。
6、所有者及组
- 第一个book,即文件的所有者或创建者(owner),修改属主可以用命令:chown
- 第二个book,即文件所在的组(group),修改属组可以用命令:chown
7、文件大小
- 单位为字节(byte),加入-h参数后会把字节数转换成KB或MB或GB等容易感性认识的值。
- 对于普通文件来说,表示该文件的大小。
- 对于目录来说,仅仅表示该目录(可以认为是一个空文件夹,不含里面其他文件的大小)占用的磁盘空间大小,一般都是4096或4K。
8、文件最后修改时间
表示该文件或目录最后的修改时间。
9、文件名及颜色
- 文件名,文件的名字。linux不是以文件名中文件的后缀来判断文件的类型的,但是一般专用文件还是用专用的后缀较好,这样容易识别文件的格式。
- 文件名的颜色:一般不同类型的文件名的颜色是不同的,一般默认有如下的约定:【修改了shell配色的情况除外】
1)蓝色代表目录/文件夹
2)浅蓝色代表链接文件
3)绿色代表可执行文件
4)灰白色代表一般文件
5)红色代表压缩文件
6)黄色代表设备文件
本文前几天前就一直想写了,想着直接转载一篇完事,但是当写起来后,发现还是自己一步一步的做,一点一点的写比较好,主要是文件权限部分内容较多,涉及的知识要查找许多资料,这一查一写就是两天多时间,回头看看,这样做还是很值得的。
2020-02-21~2020-02-23@北京
开放原子开发者工作坊旨在鼓励更多人参与开源活动,与志同道合的开发者们相互交流开发经验、分享开发心得、获取前沿技术趋势。工作坊有多种形式的开发者活动,如meetup、训练营等,主打技术交流,干货满满,真诚地邀请各位开发者共同参与!
更多推荐
所有评论(0)