umask命令详解

基础命令学习目录首页

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

umask命令用得相对不多, 而umask函数则用得相对较多。 下面, 我们先来看看umask命令, 它主要用来设置权限屏蔽, 说白了, 就是间接地设置权限。

我们先打开一个linux shell终端, 执行一些命名, 得到如下的结果:

[[email protected] learn_c]$ umask
0002
[[email protected] learn_c]$ touch a.txt
[[email protected] learn_c]$ ls -l
total 0
-rw-rw-r-- 1 taoge taoge 0 May  5 06:57 a.txt
[[email protected] learn_c]$ umask 022
[[email protected] learn_c]$ umask
0022
[[email protected] learn_c]$ touch b.txt
[[email protected] 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
[[email protected] learn_c]$ mkdir zzz
[[email protected] 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
[[email protected] learn_c]$

我们看到, 在我的系统中, umask的默认值是002(当然, 在你系统中, 很可能就不是酱紫的)。 002是个什么意思呢? 意思是说, 如果创建文件, 那么它的默认权限是664, 如果是创建目录, 那么它的权限是775.
      好, 我们创建一个文件a.txt, 然后查看一下, 发现该文件的权限果然是664.
      下面, 我们来改一下umask的默认值, 改为022, 并检验一下, 发现确实是修改成功的, 这意味着:创建文件的默认权限是644, 创建目录的默认权限是755, 我们实践一下, 发现果真如此。
    
      由此可见, umask就是为控制默认权限而生的。

还没完, 我们再打开另一个终端, 进行操作, 结果为:
[[email protected] learn_c]$ umask
0002
[[email protected] 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;}
      结果为:

[[email protected] learn_c]$ umask 000
[[email protected] learn_c]$ gcc test.c
[[email protected] 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
[[email protected] learn_c]$ umask
0000
[[email protected] 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?

  当我们登录系统之后创建一个文件总是有一个默认权限的,那么这个权限是怎么来的呢?这就是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!

原文地址:https://www.cnblogs.com/machangwei-8/p/10354563.html

时间: 2024-08-02 10:51:27

umask命令详解的相关文章

Linux umask命令详解

Linux umask命令 Linux umask命令指定在建立文件时预设的权限掩码.一般来说,umask命令是在/etc /profile文件中设置的 umask可用来设定[权限掩码].[权限掩码]是由3个八进制的数字所组成,将现有的存取权限减掉权限掩码后,即可产生建立文件时预设的权限. 用法: umask [-p] [-S] [mode] 参数: -p 显示命令名称 -S 以文字的方式来表示权限掩码 实例: 1.显示当前的权限掩码: [[email protected] ~]# umask

FTP命令详解

转载自http://www.edu.cn/20010830/210045.shtml FTP命令是Internet用户使用最频繁的命令之一,不论是在DOS还是UNIX操作系统下使用FTP,都会遇到大量的FTP内部命令.熟悉并灵活应用FTP的内部命令,可以大大方便使用者,并收到事半功倍之效. FTP的命令行格式为:ftp -v -d -i -n -g [主机名],其中-v显示远程服务器的所有响应信息:-n限制ftp的自动登录,即不使用:.n etrc文件:-d使用调试方式:-g取消全局文件名. f

linux mkdir 命令详解及使用方法实战【初级】

mkdir命令详解及使用方法实战 名称 MKDIR 是 make directories 的缩写 使用方法 mkdir [选项(如-p)] ...目录名称(及子目录注意用分隔符隔开)...    如使用mkdir建立一个多级目录则要使用-P命令 如: mkdir /lcp 是在根(/)目录下建立一个名为lcp的文件夹 mkdir -p /lcp/abc 则是在根(/)目录下建一个名为lcp的文件夹同时在此文件夹中建立名为abc的文件夹 描述 创建目录(IES),如果他们不存在. 长选项必须用的参

jar打包命令详解

:如何把 java 程序编译成 .exe 文件.通常回答只有两种,一种是说,制作一个可执行的 JAR 文件包,就可以像.chm 文档一样双击运行了:而另一种回答,则是使用 JET 来进行编译.但是 JET 是要用钱买的,而且,据说 JET 也不是能把所有的 Java 程序都编译成执行文件,性能也要打些折扣.所以,使用制作可执行 JAR 文件包的方法就是最佳选择了,何况它还能保持 Java 的跨平台特性.先来看看什么是 JAR 文件包: 1. JAR 文件包 JAR 文件就是 Java Archi

Linux压缩与解压缩命令详解

简介:常用的压缩命令有gzip.bzip2.tar 提示:gzip与bzip2工具不可以对目录做打包压缩操作,gzip与bzip2解压都是用-d参数(decompress=uncompress) tar命令详解: 用法:tar 模式 [选项][路径]... 模式:    -c 创建打包文件 -delete -r --append -t --list内容 -x --extract 选项:    -C --directory -f 打包后的文件名称 -j bzip格式压缩 --remove-file

(转)Linux下PS命令详解

(转)Linux下PS命令详解 整理自:http://blog.chinaunix.net/space.php?uid=20564848&do=blog&id=74654 要对系统中进程进行监测控制,查看状态,内存,CPU的使用情况,使用命令:/bin/ps (1) ps :是显示瞬间进程的状态,并不动态连续: (2) top:如果想对进程运行时间监控,应该用 top 命令: (3) kill 用于杀死进程或者给进程发送信号: (4) 查看文章最后的man手册,可以查看ps的每项输出的含义

Linux上的free命令详解

Linux上的free命令详解 转自: http://www.cnblogs.com/coldplayerest/archive/2010/02/20/1669949.html 解释一下Linux上free命令的输出. 下面是free的运行结果,一共有4行.为了方便说明,我加上了列号.这样可以把free的输出看成一个二维数组FO(Free Output).例如: FO[2][1] = 24677460 FO[3][2] = 10321516 1          2          3    

Find命令详解

find命令详解 格式 find pathname -options [ -print -exec -ok ... ] 功能 在磁盘中查找文件,并作相应处理 参数 pathname         所查找的目录,可以是相对/绝对路径 options -print 将结果输出到标准输出 -exec 'command' {} \; 对结果执行该参数所给的shell命令 -ok 与-exec作用相同,不过需要用户确认是否执行命令 -name 按照文件名查找 -perm [+-]mode 按照文件权限查

iftop命令命令详解

iftop命令命令详解 作者:尹正杰 在Linux命令中有很多内置命令,和外置命令,但是内部命令的功能毕竟是有限的,比如ifconfig,它就不能看到网卡流量的 实时发送情况,尽管咱们知道可以用watch命令去查看网卡的发送接收流量的情况,但是还是不够细致,因为它仅仅能看到我们的 接受和发送的总流量,因此,我们今天来介绍一个比较好使的实施查看网络流量信息的软件---iftop,其实他的工作模式和top很像. 废话不多说~让我们直接进入正题吧: 1.想必大家都会在linux命令行上敲击ifconf