linux中umask

发布时间:2014-04-09 22:04:01 阅读:893次

转:http://blog.163.com/fan_yishan/blog/static/476922132009515415493/

一 权限掩码umask
umaskchmod配套的,总共为4位(gid/uid,属主,组权,其它用户的权限),不过通常用到的是后3个,例如你用chmod 755 file(此时这文件的权限是属主读(4)+(2)+执行(1),同组的和其它用户有读写权限)

 umask的作用
   默认情况下的umask值是022(可以用umask命令查看),此时你建立的文件默认权限是644(6-0,6-2,6-2)建立的目录的默认权限是755(7-0,7-2,7-2)可以用ls -l验证一下哦 现在应该知道umask的用途了吧,它是为了控制默认权限,不要使默认的文件和目录具有全权而设的。

如何计算umask

umask命令允许你设定文件创建时的缺省模式,对应每一类用户(文件属主、同组用户、其他用户)存在一个相应的umask值中的数字。对于文件来说,这一数字的最大值分别是6系统不允许你在创建一个文本文件时就赋予它执行权限,必须在创建后用chmod命令增加这一权限。目录则允许设置执行权限,这样针对目录来说,umask中各个数字最大可以到 7

计算u m a s k值的方法:我们只要记住u m a s k是从权限中拿走相应的位即可。

                                           umask值与权限表

Umask中的某位

文件

目录

0

6

7

1

6

6

2

4

5

3

4

4

4

2

3

5

2

2

6

0

1

7

0

0

如果umask023,则对于文件所有者,不拿去任何权限,而新建的文件默认没有执行权限,故对文件所有者的权限位rw-6);对组所有者,拿去写权限,原本没有执行权限,故为r--4);对其他用户,拿去写和执行权限,原本没有执行权限,故为r--4);

如果umask023,因为没有新建目录没有执行权限的限制。则对于目录所有者,不拿去任何权限,故对目录所有者的权限为rwx7);对组所有者,拿去写权限,故为r-x5);对其他用户,拿去写和执行权限,故为r--4);

 

四 常用的u m a s k值及对应的文件和目录权限

umask

目录

文件

0 2 2

7 5 5

6 4 4

0 2 7

7 5 0

6 4 0

0 0 2

7 7 5

6 6 4

0 0 6

7 7 1

6 6 0

0 0 7

7 7 0

6 6 0

 

五 修改umask
知道了umask的作用后,你可以修改umask的值了,例如:umask 024则以后建立的文件和目录的默认权限就为642753了。

 

六 将umask值保存到环境文件
若要长期修改umask的值,可以把它写进/etc/profile~/.profile~/.bash_profile中。

我们在创建文件时

如果是普通用户,那么权限为-rw-rw-r-- 664

如果是root,那么权限为-rw-r--r--   644

在创建文件夹时

如果是普通用户,那么权限为drwxrwxr-x 775

如果是root,那么权限为drwxr-xr-x 755 

转:http://blog.csdn.net/lmh12506/article/details/7281910

umask使用方法

A 什么是umask?

 

当我们登录系统之后创建一个文件总是有一个默认权限的,那么这个权限是怎么来的呢?这就是umask干的事情。umask设置了用户创建文件的默认 权限,它与chmod的效果刚好相反,umask设置的是权限“补码”,而chmod设置的是文件权限码。一般在/etc/profile、$ [HOME]/.bash_profile或$[HOME]/.profile中设置umask值。

 

你的系统管理员必须要为你设置一个合理的 umask值,以确保你创建的文件具有所希望的缺省权限,防止其他非同组用户对你的文件具有写权限。在已经登录之后,可以按照个人的偏好使用umask命 令来改变文件创建的缺省权限。相应的改变直到退出该shell或使用另外的umask命令之前一直有效。一般来说,umask命令是在/etc /profile文件中设置的,每个用户在登录时都会引用这个文件,所以如果希望改变所有用户的umask,可以在该文件中加入相应的条目。如果希望永久 性地设置自己的umask值,那么就把它放在自己$HOME目录下的.profile或.bash_profile文件中。

 

B 如何计算umask值

 

umask 命令允许你设定文件创建时的缺省模式,对应每一类用户(文件属主、同组用户、其他用户)存在一个相应的umask值中的数字。对于文件来说,这一数字的最 大值分别是6。系统不允许你在创建一个文本文件时就赋予它执行权限,必须在创建后用chmod命令增加这一权限。目录则允许设置执行权限,这样针对目录来 说,umask中各个数字最大可以到7。

 

该命令的一般形式为:

 

umask nnn

 

其中nnn为umask置000-777。

 

让我们来看一些例子。

 

计算出你的umask值:

 

可以有几种计算umask值的方法,通过设置umask值,可以为新创建的文件和目录设置缺省权限。下表列出了与权限位相对应的umask值。

 

在计算umask值时,可以针对各类用户分别在这张表中按照所需要的文件/目录创建缺省权限查找对应的umask值。

 

例如,umask值002 所对应的文件和目录创建缺省权限分别为6 6 4和7 7 5。

 

还有另外一种计算umask值的方法。我们只要记住umask是从权限中“拿走”相应的位即可。

 

umask值与权限

 

umask 文件 目录

 

0 6 7

 

1 6 6

 

2 4 5

 

3 4 4

 

4 2 3

 

5 2 2

 

6 0 1

 

7 0 0

 

例如,对于umask值0 0 2,相应的文件和目录缺省创建权限是什么呢?

 

第一步,我们首先写下具有全部权限的模式,即777 (所有用户都具有读、写和执行权限)。

 

第二步,在下面一行按照umask值写下相应的位,在本例中是0 0 2。

 

第三步,在接下来的一行中记下上面两行中没有匹配的位。这就是目录的缺省创建权限。

 

稍加练习就能够记住这种方法。

 

第四步,对于文件来说,在创建时不能具有执行权限,只要拿掉相应的执行权限比特即可。

 

这就是上面的例子, 其中u m a s k值为0 0 2:

 

1) 文件的最大权限 rwx rwx rwx (777)

 

2) umask值为0 0 2 --- --- -w-

 

3) 目录权限 rwx rwx r-x (775) 这就是目录创建缺省权限

 

4) 文件权限 rw- rw- r-- (664) 这就是文件创建缺省权限

 

下面是另外一个例子,假设这次u m a s k值为0 2 2:

 

1) 文件的最大权限 rwx rwx rwx (777)

 

2 ) u m a s k值为0 2 2 --- -w- -w-

 

3) 目录权限 rwx r-x r-x (755) 这就是目录创建缺省权限

 

4) 文件权限 rw- r-- r-- (644) 这就是文件创建缺省权限

 

C 常用的umask值

 

下表列出了一些umask值及它们所对应的目录和文件权限。

 

常用的umask值及对应的文件和目录权限

 

umask 值 目录 文件

 

0 22 7 5 5 6 4 4

 

0 27 7 5 0 6 4 0

 

0 02 7 7 5 6 6 4

 

0 06 7 7 1 6 6 0

 

0 07 7 7 0 6 6 0

 

D umask命令

 

如果想知道当前的umask 值,可以使用umask命令:

 

$umask

 

如果想要改变umask值,只要使用umask命令设置一个新的值即可:

 

$ umask 002

 

确认一下系统是否已经接受了新的u m a s k值:

 

$umask

 

002

 

$touch testfile

 

$ls -l testfile

 

rw- rw- r--

 

在使用umask命令之前一定要弄清楚到底希望具有什么样的文件/目录创建缺省权限。否则可能会得到一些非常奇怪的结果;例如,如果将umask值设置为6 0 0,那么所创建的文件/目

 

录的缺省权限就是0 6 6!

 

 

如有问题,可以QQ搜索群1028468525加入群聊,欢迎一起研究技术

支付宝 微信

有疑问联系站长,请联系QQ:QQ咨询

转载请注明:linux中umask 出自老鄢博客 | 欢迎分享