umask命令

 

  linux常用的命令

 

  umask命令的一般格式:

 

  umask [选项] [掩码]

 

  该命令用来设置限制新文件权限的掩码。当新文件被创建时,其最初的权限由文件创建掩码决定。用户每次注册进入系统时,umask命令都被执行,并自动设置掩码改变默认值,新的权限将会把旧的覆盖。

 

  选项及其含义如下。

 

  -S:显示当前的掩码。

 

  umask是从权限中“拿走”相应的位,且文件创建时不能赋予执行权限

umask使用方法

  A 什么是umask?

 

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

 
 

  B 如何计算umask值

 
 

  该命令的一般形式为:

 

  umask nnn

 

  其中nnn为umask置000-777。

 

  让我们来看一些例子。

 

  计算出你的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

 
 

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

 

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

 
 

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

 

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

 

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

 

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

 

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

 
 

  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-

 
 

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

 

  C 常用的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--

 
 

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

 

 

以上内容来自百度百科。。。