要为Linux新用户设置默认umask,最直接的方法是修改/etc/login.defs文件中的UMASK参数,或通过编辑/etc/profile、/etc/bash.bashrc等全局shell配置文件实现。修改/etc/login.defs适用于系统级默认设置,影响新用户创建时的初始权限;而修改shell配置文件可实现更灵活的全局或特定shell控制,但优先级更高,会覆盖前者设置。umask值决定新文件和目录的默认权限,如022产生644/755权限,保障安全性;002产生664/775权限,便于组内协作。设置后需创建测试用户并检查umask值及新建文件目录权限,确保配置生效。优先级顺序为:/etc/login.defs < /etc/profile < /etc/profile.d/*.sh < /etc/bash.bashrc < ~/.bash_profile < ~/.bashrc,高优先级配置会覆盖低优先级。

在Linux系统中,要为新用户设置默认的umask,最直接且系统级的方法是修改
/etc/login.defs
UMASK
/etc/profile
/etc/bash.bashrc
要为Linux系统中的新用户设置默认的umask,通常有两种主要的策略,每种都有其适用场景和优先级。
方法一:修改 /etc/login.defs
这是设置新用户默认umask最常见且影响最广的方式。
/etc/login.defs
打开文件进行编辑: 使用你喜欢的文本编辑器(比如
vim
nano
/etc/login.defs
sudo vim /etc/login.defs
查找并修改 UMASK
UMASK
022
002
UMASK 022
644
755
UMASK 002
664
775
根据你的需求,修改或取消注释这一行,并设置你想要的umask值。例如,如果你希望新用户默认的文件和目录权限更宽松,允许组内成员写入,可以设置为:
UMASK 002
如果你更倾向于严格的权限,只允许文件所有者写入:
UMASK 022
保存并退出: 保存对
/etc/login.defs
方法二:修改 Shell 配置文件 (适用于特定 Shell 或更灵活的设置)
这种方法通过修改用户的shell初始化脚本来设置umask。它通常在用户登录时执行。
修改 /etc/profile
/etc/profile
sudo vim /etc/profile
在文件末尾添加或修改:
umask 002
或者:
umask 022
保存并退出。
修改 /etc/bash.bashrc
/etc/bash.bashrc
sudo vim /etc/bash.bashrc
在文件末尾添加或修改:
umask 002
保存并退出。
优先级说明:
当一个新用户登录时,系统会按照一定的顺序读取这些配置:
/etc/login.defs
UMASK
/etc/skel
/etc/profile
/etc/bash.bashrc
/etc/login.defs
~/.profile
~/.bashrc
所以,如果你在
/etc/login.defs
UMASK 022
/etc/profile
UMASK 002
002

我个人觉得,umask这东西,初看挺不起眼的,但它实实在在是系统安全的第一道防线。很多人在部署应用或者配置服务器的时候,往往把重心放在防火墙、加密、认证这些“大”安全措施上,却忽略了文件权限这种基础中的基础。但你想想看,如果一个敏感文件被创建出来,默认就是所有人可读写,那你的防火墙再严密,也挡不住本地的误操作或者被入侵后的权限滥用。
umask,全称是“user file creation mode mask”,顾名思义,它是一个掩码,用来“屏蔽”掉新创建文件或目录的一些权限位。它不是直接设定权限,而是从一个“最大可能权限”中减去(或者说是屏蔽掉)某些权限,从而得到最终的默认权限。
文件权限,我们都知道有读(r)、写(w)、执行(x)这三种,分别对应数字4、2、1。把它们组合起来,就有了我们常见的八进制权限表示,比如
644
755
umask的重要性就在于,它在文件或目录诞生的一瞬间,就给它们打上了权限的烙印。如果umask设置得过于宽松(比如
000
666
777
022
002

这地方,我刚开始接触Linux的时候,也老是犯迷糊,umask这四个数字到底怎么算出来的?它跟我们平时看到的
644
755
umask的计算逻辑是这样的:
666
777
umask值就是从这些最大权限中“减去”的权限位。这里的“减去”更准确的理解是“屏蔽”或“不允许”。
我们来具体看看
0022
0002
1. umask 0022
umask值:
0
2
2
计算方式:
666
022
644
6 - 0 = 6
6 - 2 = 4
6 - 2 = 4
777
022
755
7 - 0 = 7
7 - 2 = 5
7 - 2 = 5
含义: 当umask是
0022
适用场景: 这是最常见的默认umask值,尤其在单用户环境或对安全性要求较高的服务器上。它确保了用户创建的文件默认是相对私密的,只有文件所有者有完整的控制权。
2. umask 0002
umask值:
0
0
2
计算方式:
666
002
664
6 - 0 = 6
6 - 0 = 6
6 - 2 = 4
777
002
775
7 - 0 = 7
7 - 0 = 7
7 - 2 = 5
含义: 当umask是
0002
适用场景: 这种umask值通常用于团队协作环境,比如一个开发团队共享一个项目目录。它允许同组的成员对新创建的文件和目录有写入权限,方便协作,减少权限管理的麻烦。当然,这就意味着你需要信任你的组内成员。
简单来说,
0022
0002

你可能会发现,即便你在
/etc/login.defs
UMASK 022
0002
/etc/login.defs
~/.bashrc
除了
/etc/login.defs
/etc/profile
UMASK
/etc/login.defs
*/etc/bash.bashrc
/etc/bash.bashrc
UMASK
/etc/profile.d/
.sh
/etc/profile
umask.sh
locale.sh
用户主目录下的配置文件 (~/.profile
~/.bash_profile
~/.bashrc
~/.cshrc
~/.profile
~/.bash_profile
~/.bashrc
~/.bashrc
优先级顺序(从低到高,高优先级会覆盖低优先级):
/etc/login.defs
/etc/profile
/etc/profile.d/*.sh
/etc/bash.bashrc
~/.bash_profile
~/.profile
~/.bashrc
实际操作中的考量:
/etc/login.defs
/etc/profile
/etc/bash.bashrc
~/.bashrc
~/.profile
UMASK
所以,当你发现umask不符合预期时,需要从这些文件中由高到低地排查,看看是哪个配置最终生效了。有时候,一个用户在自己的
~/.bashrc
验证嘛,这是个好习惯,我经常看到有人改了配置,信心满满,结果一测发现没生效,白忙活一场。验证umask是否设置成功,需要几个步骤,确保我们修改的配置确实应用到了新用户身上。
创建新的测试用户: 这是最关键的一步。因为umask的设置通常影响的是新创建的用户。如果你只修改了配置,然后用现有用户登录,它可能不会立即生效(除非你修改的是用户自己的
~/.bashrc
sudo adduser testuser
按照提示设置密码和其他信息。
切换到新用户或以新用户身份登录: 你可以使用
su - testuser
testuser
testuser
su - testuser
检查当前用户的umask值: 在新用户的shell中,直接运行
UMASK
umask
如果显示的是你期望的值(比如
0022
0002
创建文件和目录并检查其权限: 这是验证umask是否真正按预期工作的最直观方法。umask的目的是影响新创建的文件和目录的默认权限。
# 创建一个文件 touch testfile.txt # 创建一个目录 mkdir testdir
然后,检查它们的权限:
ls -l testfile.txt ls -ld testdir
期望结果示例:
如果你设置的umask是 0022
ls -l testfile.txt
-rw-r--r--
644
ls -ld testdir
drwxr-xr-x
755
如果你设置的umask是 0002
ls -l testfile.txt
-rw-rw-r--
664
ls -ld testdir
drwxrwxr-x
775
如果这些权限与你通过umask计算出的预期值一致,那么恭喜你,你的umask设置成功了!如果不一致,就需要回到前面提到的优先级部分,仔细排查是哪个配置文件最终覆盖了你的设置。记得,验证是调试过程中不可或缺的一环。
以上就是Linux如何设置新用户默认的umask的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号