• Linux 文件权限详解


    查看文件详细信息

    参数说明

    权限说明

    文件类型说明

    •  d    目录

    •   -     普通文件

    •    l     连接文件

    •   b    存储设备,例如硬盘,U盘

    •   c    串行接口设备,例如键盘、鼠标

        

    设置文件权限

    命令:chmod  (change mode)

    赋予权限 

        方式一:chmod u=rwx,g=rwx,o=r foo.txt

        方式二:chmod 774 foo.txt

        数字表示法和权限的关系:

            有权限为1,没权限为0,转换成二进制,每三位一组再转换成十进制:

            第一组是文件拥有者的权限,第二组是组用户的权限,第三组是其他人的权限。

            举例:

                rwxrwxrwx  -->  111111111   -->  777

                rw-r--r--     -->  110100100   -->  644

                rw-------     -->  110000000   -->  600

    修改权限

       chmod u-x foo   :取消所有者对foo文件的执行权限。

       chmond  g+w  foo  : 增加组用户对foo文件的写权限。

    一张图搞定:

    权限详解

    权限作用于目录

      r   (read contents in directory):

            当对一个目录具有读(r)的权限时,就可以查看目录内的文件名信息。

            且只能查看文件名不能查看文件的权限等详情信息。

      w  (modify contents of directory)

            当对一个目录有写(w)的权限时,可以执行如下操作:

      •  查看目录中文件的详情信息。

      •  建立新的文件与子目录;

      •  删除已经存在的文件和目录(不管该文件的权限如何!)

      •  修改已存在的文件和目录的名称;

      •   移动该目彔内的文件、目录的位置。

             当具有写(w)一个目录的权限时,就可以重命名| 删除| 移动| 创建子目录和文件。

             与子目录或目录中文件本身的权限无关。

        x   (access directory)

             对目录具有执行(x)权限,表示可以把该目录作为工作目录。也就是可以cd到此目录内,执行命令。

    权限作用于普通文件

        r  (read contents ): 可以读取文件内容。

        w (edit contents)  :    可以编辑文件内容,如文本文件。

        x  (execute file)     :    可以执行文件。         


    如果要设置某个目录可以给任何人浏览,则至少要给予r和x权限,但是w权限要谨慎!看下面的例子。

    root用户:

    #用root用户在/tmp目录下创建testing目录,默认权限755
    [root@master tmp]# mkdir testing
    #修改目录权限为744
    [root@master tmp]# chmod 744 /testing
    drwxr--r--. 2 root   root   4096 Nov 21 17:33 testing
    #在testing目录下创建test2文件 默认权限644
    [root@master tmp]# touch testing/test2
    [root@master tmp]# ls -l testing/
    total 1
    -rw-r--r--. 1 root root 0 Nov 21 17:56 test2

    普通用户下操作上面创建的文件夹和文件

    #切换到普通用户hector
    [root@master tmp]# su hector
    #查看testing目录的内容,因为只具有r权限,所以无法查看详情信息,只显示文件名,其他信息显示为???。
    [hector@master tmp]$ ls -l testing
    ls: cannot access testing/test2: Permission denied
    total 0
    -????????? ? ? ? ?            ? test2
    #没有x权限的目录,不能作为工作路径
    [hector@master tmp]$ cd testing/
    bash: cd: testing/: Permission denied
     
    #使用root用户设置其他用户对testing目录具有rwx权限
    [root@master tmp]# chmod 747 testing
    drwxr--rwx. 2 root   root   4096 Nov 21 18:09 testing
     
    #普通用户对test2文件本身只有r权限,但是可以删除此文件。
    #因为普通用户hector对testing目录具有w权限,所有可以删除tesing目录中的任意文件和子目录,不管对目录中的文件本身具有什么权限。
    [hector@master testing]$ ll
    total 0
    -rw-r--r--. 1 root root 0 Nov 21 17:56 test2
    删除test2
    [hector@master testing]$ rm test2

    一张图搞定:

    默认权限设置

    命令:umas (user mask)

    功能:设置创建文件的预设权限

    参数:-S 查看详细权限

    一般文件主要用于保存数据,所以文件预设都不具有执行(x)权限;

    而对于目录,x权限意味着可以把该目录作为工作空间,所以目录预设都具有执行(x)权限。

    查看用户的默认权限

    权限掩码:由4位数字组成,与一般权限相关的是后3个数字,第一个数字为特殊权限,不做讨论。

    权限掩码,是要减去的权限:例如掩码是022,表示,创建的文件夹默认权限是777- 022=755 即:rwxr-xr-x

    如果是普通文件,还要再减去执行(x)权限即,755 - 111 = 644,即:rw-r--r--

    说明:一次执行多条linux命令,命令之间用;分号隔开。

    修改默认权限掩码

    umask后写上要设置的掩码即可。

    修改用户所有者

    命令:chown  (change owner)

        功能:修改文件的拥有者

        格式:chown [参数] 用户名 文件名

        参数: -R(recursive) 递归修改文件或目录的拥有者

        实例:# chown  user1   f1

        # chown  -R user1   filegroup1    

    命令:chgrp (change group)

        功能:修改文件或目录的所属组

        格式:charp [参数] 用户组名 文件名 

        参数: -R(recursive) 递归修改文件或目录的所属组

        实例:# chgrp users install.log


      Thanks a lot !

      END!

  • 相关阅读:
    13.Query for Null or Missing Fields-官方文档摘录
    海南IT互联网招聘数据简单分析
    Mongo Spark Connector中的分区器(一)
    一、Golang中的反射基本使用
    Golang中的sync.Pool对象
    Golang中的内置函数
    golang单元测试简述
    Spark Streaming数据限流简述
    Golang中类面向对象特性
    在Docker中跑Hadoop与镜像制作
  • 原文地址:https://www.cnblogs.com/lukeguo/p/8824770.html
Copyright © 2020-2023  润新知