zoukankan      html  css  js  c++  java
  • 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却不一定发生改变。

    6.最后一列文件名不算是文件属性,所以它并不在inode里面,而是存放在block中。

  • 相关阅读:
    AngularJS依赖注入
    transclude 嵌入
    收藏的文章
    mysql
    jquery的deferred对象
    restrict取值
    AngularJs碎片笔记
    js工具函数
    canvas解决画图模糊
    去体湿
  • 原文地址:https://www.cnblogs.com/randolf/p/10309765.html
Copyright © 2011-2022 走看看