umask命令详解

  

基础命令学习目录首页html

 

原文连接:https://blog.csdn.net/stpeace/article/details/45509425linux

       umask命令用得相对很少, 而umask函数则用得相对较多。 下面, 咱们先来看看umask命令, 它主要用来设置权限屏蔽, 说白了, 就是间接地设置权限。
       咱们先打开一个linux shell终端, 执行一些命名, 获得以下的结果:
 [taoge@localhost learn_c]$ umask
0002
[taoge@localhost learn_c]$ touch a.txt
[taoge@localhost learn_c]$ ls -l
total 0
-rw-rw-r-- 1 taoge taoge 0 May  5 06:57 a.txt
[taoge@localhost learn_c]$ umask 022
[taoge@localhost learn_c]$ umask
0022
[taoge@localhost learn_c]$ touch b.txt
[taoge@localhost learn_c]$ ls -l
total 0
-rw-rw-r-- 1 taoge taoge 0 May  5 06:57 a.txt
-rw-r--r-- 1 taoge taoge 0 May  5 06:58 b.txt
[taoge@localhost learn_c]$ mkdir zzz
[taoge@localhost learn_c]$ ls -l
total 4
-rw-rw-r-- 1 taoge taoge    0 May  5 06:57 a.txt
-rw-r--r-- 1 taoge taoge    0 May  5 06:58 b.txt
drwxr-xr-x 2 taoge taoge 4096 May  5 07:00 zzz
[taoge@localhost learn_c]$
      咱们看到, 在个人系统中, umask的默认值是002(固然, 在你系统中, 极可能就不是酱紫的)。 002是个什么意思呢? 意思是说, 若是建立文件, 那么它的默认权限是664, 若是是建立目录, 那么它的权限是775.
      好, 咱们建立一个文件a.txt, 而后查看一下, 发现该文件的权限果真是664.
      下面, 咱们来改一下umask的默认值, 改成022, 并检验一下, 发现确实是修改为功的, 这意味着:建立文件的默认权限是644, 建立目录的默认权限是755, 咱们实践一下, 发现果然如此。
    
      因而可知, umask就是为控制默认权限而生的。
       还没完, 咱们再打开另外一个终端, 进行操做, 结果为:
[taoge@localhost learn_c]$ umask
0002
[taoge@localhost learn_c]$ ls -l
total 4
-rw-rw-r-- 1 taoge taoge    0 May  5 06:57 a.txt
-rw-r--r-- 1 taoge taoge    0 May  5 06:58 b.txt
drwxr-xr-x 2 taoge taoge 4096 May  5 07:00 zzz
      咱们看到, 在另一个shell终端中, umask的值仍然是002,  可见, 一个shell进程中的umask值仅在当前shell进程中才有效。

      好, 咱们接着看umask函数,
它经常使用来控制进程建立文件/目录的默认权限, 代码以下:
#include <stdio.h> int main(){ system("touch test0.txt"); system("mkdir folder0");  umask(022); system("touch test1.txt"); system("mkdir folder1");  umask(066); system("touch test2.txt"); system("mkdir folder2");  system("ls -l");  return 0;}
      结果为:
 
 [taoge@localhost learn_c]$ umask 000
[taoge@localhost learn_c]$ gcc test.c
[taoge@localhost learn_c]$ ./a.out
total 24
-rwxrwxrwx 1 taoge taoge 4925 May  5 07:43 a.out
drwxrwxrwx 2 taoge taoge 4096 May  5 07:43 folder0
drwxr-xr-x 2 taoge taoge 4096 May  5 07:43 folder1
drwx--x--x 2 taoge taoge 4096 May  5 07:43 folder2
-rw-rw-rw- 1 taoge taoge    0 May  5 07:43 test0.txt
-rw-r--r-- 1 taoge taoge    0 May  5 07:43 test1.txt
-rw------- 1 taoge taoge    0 May  5 07:43 test2.txt
-rwxrw-rw- 1 taoge taoge  279 May  5 07:42 test.c
[taoge@localhost learn_c]$ umask
0000
[taoge@localhost learn_c]$
 
     咱们知道,  shell是父进程, ./a.out进程是子进程.  下面来分析一下:
     1. 根据test0.txt可知, 父进程能够影响子进程的默认屏蔽字。
     2. 根据test1.txt可知, 子进程能够改变本身的默认屏蔽字。
     3. 根据最后shell进程的屏蔽字为000可知, 子进程不会改变父进程的屏蔽字。

     实际上, umask命令与函数的用法是一致的。 那一年, 我第一次看到umask, 还使劲琢磨着这个玩意儿是干啥的, 哈哈。
---------------------
做者:stpeace
来源:CSDN
原文:https://blog.csdn.net/stpeace/article/details/45509425
版权声明:本文为博主原创文章,转载请附上博文连接!
 
 
原文连接:https://www.cnblogs.com/zhangchengxiang/p/5196439.html

umask使用方法

  A 什么是umask?shell

 

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

 

  你的系统管理员必需要为你设置一个合理的 umask值,以确保你建立的文件具备所但愿的缺省权限,防止其余非同组用户对你的文件具备写权限。在已经登陆以后,能够按照我的的偏好使用umask命 令来改变文件建立的缺省权限。相应的改变直到退出该shell或使用另外的umask命令以前一直有效。通常来讲,umask命令是在/etc /profile文件中设置的,每一个用户在登陆时都会引用这个文件,因此若是但愿改变全部用户的umask,能够在该文件中加入相应的条目。若是但愿永久 性地设置本身的umask值,那么就把它放在本身$HOME目录下的.profile或.bash_profile文件中。ide

 

  B 如何计算umask值函数

 

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

 

  该命令的通常形式为:学习

 

  umask nnnurl

 

  其中nnn为umask置000-777。spa

 

  让咱们来看一些例子。

 

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

相关文章
相关标签/搜索