Linux 基础知识 | 文件属性以及权限

版权声明:本文为博主原创文章,欢迎转载,转载标明原文地址: https://blog.csdn.net/u012943767/article/details/80196811

Linux 基础知识 | 文件属性以及权限

本文为笔者学习Linux笔记内容。参考了以下文章:

Linux操作系统是一种多用户系统,不同的用户对某个文件拥有不同的权限。

文件属性

Linux中使用ll命令来显示文件的属性

[root@VM_0_14_centos ~]# ll
total 40916
-rw-------. 1 root root     2523 Apr 21  2016 anaconda-ks.cfg
-rw-r--r--  1 root root      208 Mar  3 15:14 dump.rdb
drwxr-xr-x  3 root root     4096 Mar  1 15:40 mongodb-linux-x86_64-3.0.6
-rw-r--r--  1 root root 40282490 Feb 28 15:58 mongodb-linux-x86_64-3.0.6.tgz
drwxrwxr-x  6 root root     4096 Feb 23 14:21 redis-3.2.6
-rw-r--r--  1 root root  1544806 Dec  6  2016 redis-3.2.6.tar.gz

可以看到第一行显示total 40961。这个字段的说明是”所列出的内容的磁盘占用空间总和值”,单位是kbytes

关于这个字段的详细解释,可以看这篇文章

接下来的内容都是一个文件或者目录显示为一行,每一行的格式都相同。

anaconda-ks.cfg文件为例子说明,下面将对每一列进行说明

  • 第一列:-rw-------这里总共10个字符

    • 第一个字符是的说明是文件的类型:
      • d 表示目录
      • - 表示文件
      • i 表示链接文件
      • b 表示存储接口设备(内存等)
      • c 表示串行端口设备(键盘鼠标等)
    • 接下来的9个字符分别分为3组[rw-][---][---]分别代表[文件拥有者用户][文件所属组用户][其他用户]的读/写/执行权限。

      每一组3个字符分别代表不同的权限[rwx]这3个字符分别代表[可读][可写][可执行]权限,如果不具备该权限则显示[-]

      对于例子-rw-------来说,意思是这是一个文件对于拥有者来说拥有可读可写的权限,对于文件所属组的用户没有任何权限,其他用户也没有任何权限

  • 第二列:表示有多少文件名链接到此节点
  • 第三列:表示这个文件或目录的拥有者用户
  • 第四列:表示这个文件所属的用户组
  • 第五列:表示文件的大小,单位为bytes
  • 第六列:表示文件的创建日期或者最后修改日期
  • 第七列:表示文件名

修改文件属性

修改文件属性有以下命令:

  • chgrp 修改文件所属用户组

    语法如下:

    chgrp [-R] 组名 文件名
    

    -R参数是可选的,表示是否递归更改文件属组,如果该文件是一个文件夹,那么该文件夹下面的所有文件属组都会改变

  • chown 修改文件所属用户

    语法如下:

    chown [-R] 用户名 文件名
    

    同时这个命令可以更改所属用户组

    chown [-R] 用户名 所属用户组名 文件名
    

    -R参数和chgrp命令的作用一样

  • chmod 修改文件的权限

    语法如下:

    chmod [-R] 权限分数 文件名
    

    上面命令中的权限分数表示:

    文章上面提到,文件权限分为三组,用户权限,组权限,其他权限,他们的符号都是rwx,那么这三个符号对应的分数分别是421,如果没有该权限则分数为0,同样用上述例子说明:-rw-------这样的权限表示三个组的分数为600,所以如果执行下面命令,则会把权限设置为-rw-------

    chmod 600 anaconda-ks.cfg
    

    chmod命令还有一种语法:

    chmod [作用域][操作符][权限] 文件名
    

    上述命令中解释如下:

  • 作用域

    • u : 所属用户
    • g : 所属用户组
    • o : 其他组
  • 操作符

    • + : 加入
    • - : 减去
    • = : 设定
  • 权限

    • r : 可读
    • w : 可写
    • x : 可执行

    下面通过一些例子来说明:

    chmod u=rwx,g=rx,o=r anaconda-ks.cfg 
    

    表示修改权限为-rwxr-xr--:

    [root@VM_0_14_centos ~]# ll anaconda-ks.cfg
    -rw-------. 1 root root 2523 Apr 21  2016 anaconda-ks.cfg
    [root@VM_0_14_centos ~]# chmod u=rwx,g=rx,o=r anaconda-ks.cfg
    [root@VM_0_14_centos ~]# ll anaconda-ks.cfg
    -rwxr-xr--. 1 root root 2523 Apr 21  2016 anaconda-ks.cfg

    假设要把三个组都添加可执行权限:

    [root@VM_0_14_centos ~]# chmod a+x anaconda-ks.cfg
    [root@VM_0_14_centos ~]# ll anaconda-ks.cfg
    -rwxr-xr-x. 1 root root 2523 Apr 21  2016 anaconda-ks.cfg

    最后我们把权限改回原来的状态

    [root@VM_0_14_centos ~]# chmod 600 anaconda-ks.cfg
    [root@VM_0_14_centos ~]# ll anaconda-ks.cfg
    -rw-------. 1 root root 2523 Apr 21  2016 anaconda-ks.cfg

猜你喜欢

转载自blog.csdn.net/u012943767/article/details/80196811
今日推荐