linux命令之--umask

umask:反掩码或者默认权限

系统中默认的权限:

文件: 644     也就是说文件默认式没有执行权限的, 即使设置umask  默认权限,还是不会给执行权限

目录:755      目录默认权限是有执行权限的

umask: 

文件权限:666-umask   

目录:777-umask

[root@localhost ~]# touch a

[root@localhost ~]# mkdir b

[root@localhost ~]# ll

total 56

-rw-r--r--. 1 root root    0 Mar  1 15:06 2017-03-01

-rw-r--r--. 1 root root    0 Mar  1 15:04 3647.a

-rw-r--r--. 1 root root    0 Mar  6 15:23 a

-rw-------. 1 root root  1313 Jan  8 18:46 anaconda-ks.cfg

drwxr-xr-x. 2 root root  4096 Mar  6 15:23 b

-rw-r--r--. 1 root root    0 Mar  1 15:07 file-2017-03-01

-rw-r--r--. 1 root root 28352 Jan  8 18:46 install.log

-rw-r--r--. 1 root root  5890 Jan  8 18:44 install.log.syslog

-rwxr-xr-x. 1 root root    37 Mar  6 15:01 jurchens.sh

drwxr-xr-x. 2 root root  4096 Mar  1 15:27 test

[root@localhost ~]#


修改umask测试,发现即使我我们给了c 执行权限,但是最后发现自动加1,变成没有执行权限了,这是linux 内置法则

[root@localhost ~]# umask 023

[root@localhost ~]# touch c

[root@localhost ~]# mkdir d

[root@localhost ~]# ll

total 60

-rw-r--r--. 1 root root    0 Mar  1 15:06 2017-03-01

-rw-r--r--. 1 root root    0 Mar  1 15:04 3647.a

-rw-r--r--. 1 root root    0 Mar  6 15:23 a

-rw-------. 1 root root  1313 Jan  8 18:46 anaconda-ks.cfg

drwxr-xr-x. 2 root root  4096 Mar  6 15:23 b

-rw-r--r--. 1 root root    0 Mar  6 15:26 c

drwxr-xr--. 2 root root  4096 Mar  6 15:26 d

-rw-r--r--. 1 root root    0 Mar  1 15:07 file-2017-03-01

-rw-r--r--. 1 root root 28352 Jan  8 18:46 install.log

-rw-r--r--. 1 root root  5890 Jan  8 18:44 install.log.syslog

-rwxr-xr-x. 1 root root    37 Mar  6 15:01 jurchens.sh

drwxr-xr-x. 2 root root  4096 Mar  1 15:27 test


扩展:

1.修改umask  只对当前shell 环境起作用,退出再登录后失效,如果永久生效,休要修改 /etc/profile 文件/etc/profile 是经常用来设置环境变量的的文件,在这里也可以直接写命令或执行shell脚本,当登录系统时,会自动执行命令或脚本,当然一般不建议这么做,一般的做法是把脚本放在 /etc/profile.d 下

2.如果想再开机启动时,自动执行命令或脚本,可以将 命令或文件放入到 /etc/rc.local 下

你可能感兴趣的:(linux命令之--umask)