温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

linux下umask命令用途原理和计算方式是什么

发布时间:2021-11-29 17:27:19 来源:亿速云 阅读:146 作者:iii 栏目:开发技术

这篇文章主要介绍“linux下umask命令用途原理和计算方式是什么”,在日常操作中,相信很多人在linux下umask命令用途原理和计算方式是什么问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”linux下umask命令用途原理和计算方式是什么”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!

    umask umask用途

    umask令新建文件和目录拥有默认权限。

    可以看到root创建的目录是755,文件是644

    [root@zaishu zaishu]# touch test.txt
    [root@zaishu zaishu]# mkdir test
    
    [root@zaishu zaishu]# ls -l
    total 0
    drwxr-xr-x 2 root root 6 Nov 25 16:29 test  
    -rw-r--r-- 1 root root 0 Nov 25 16:28 test.txt

    普通用户

    可以看到普通用户创建的目录是775,文件是664

    [mysql@zaishu ~]$ touch test.txt
    [mysql@zaishu ~]$ mkdir test
    [mysql@zaishu ~]$ ls -l
    total 0
    drwxrwxr-x 2 mysql mysql 6 Nov 25 16:30 test
    -rw-rw-r-- 1 mysql mysql 0 Nov 25 16:30 test.txt

    这些默认的权限值是通过umask设置运算得到。

    原理

    Linux 它是通过使用 umask 默认权限来给所有新建的文件和目录赋予初始权限的。那么,我们如何得知 umask 默认权限的值呢?直接通过 umask 命令即可:

    1. umask值

    [root@zaishu ~]# umask
    0022
    
    [mysql@zaishu ~]$ umask
    0002

    #root用户默认是0022,普通用户默认是 0002

    umask 默认权限确实由 4 个八进制数组成,第 1 个数代表的是文件所具有的特殊权限(SetUID、SetGID、Sticky BIT)先忽略。后 3 位 “022” 对应为 ----w–w-。

    2. 文件目录权限最大值

    Linux 系统中,文件和目录的最大默认权限是不一样:

    文件来讲,可拥有的最大默认权限是 666,即 rw-rw-rw-。x是文件最大权限,新建文件的时候不会给与,只能通过用户手工赋予。

    目录来讲,拥有的最大默认权限是 777,即 rwxrwxrwx。

    3. 常规计算

    文件和目录的初始权限,通过计算得到:

    文件(或目录)的初始权限 = 文件(或目录)的最大默认权限 - umask权限

    [mysql@zaishu ~]$ umask
    0002
    [mysql@zaishu ~]$ mkdir test
    [mysql@zaishu ~]$ ll -d test
    drwxrwxr-x 2 mysql mysql 6 Nov 26 10:50 test  // 目录的默认权限最大可以是 777,777-002 =775
    
    [mysql@zaishu ~]$ touch h.txt
    [mysql@zaishu ~]$ ll h.txt 
    -rw-rw-r-- 1 mysql mysql 0 Nov 26 10:52 h.txt //文件最大权限 666, 666-002(普通用户) 666-002 =664
    [root@zaishu ~]# touch h3
    [root@zaishu ~]# ls -l h3 
    -rw-r--r-- 1 root root 0 Nov 26 10:53 h3 //文件最大权限 666, 666-002(root) 666-022 =644

    4. 严谨计算

    在计算文件或目录的初始权限时,直接使用最大默认权限和 umask 权限的数字形式做减法,是不严谨的。例如,若 umask 默认权限的值为 033,按照数字形式计算文件的初始权限,666-033=633,但我们按照字母的形式计算会得到 (rw-rw-rw-) - (----wx-wx) = (rw-r–r--),换算成数字形式是 644。

    这里的减法,其实是“遮盖”的意思,也就是说,最大默认权限中和 umask 权限公共的部分,通过减法运算会被遮盖掉,最终剩下的“最大默认权限”,才是最终赋予文件或目录的初始权限。

    umask值修改

    1. 临时生效(当前会话)

    umask 权限值可直接修改:

    [root@localhost ~]# umask 002
    [root@localhost ~]# umask
    0002
    [root@localhost ~]# umask 033
    [root@localhost ~]# umask
    0033

    这种方式修改的 umask 只是临时有效,一旦重启或重新登陆系统,就会失效。

    2. 永久生效

    让修改永久生效,则需要修改对应的环境变量配置文件 /etc/profile。

    [root@zaishu~]# vim /etc/profile
    ...省略部分内容...
    if [ $UID -gt 199]&&[ "'id -gn'" = "'id -un'" ]; then
        umask 002
        #如果UID大于199(普通用户),则使用此umask值
    else
        umask 022
        #如果UID小于199(超级用户),则使用此umask值
    fi

    到此,关于“linux下umask命令用途原理和计算方式是什么”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注亿速云网站,小编会继续努力为大家带来更多实用的文章!

    向AI问一下细节

    免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

    AI