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 h2
[root@zaishu ~]# ls -l h2 
-rw-r--r-- 1 root root 0 Nov 26 10:53 h2 //文件最大權限 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命令用途原理和計算方式詳解的文章就介紹到這瞭,更多相關linux下umask命令詳解內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!

推薦閱讀: