0

0

LINUX如何设置文件或目录的默认权限(umask)_Linux默认权限配置技巧

穿越時空

穿越時空

发布时间:2025-11-21 14:40:50

|

993人浏览过

|

来源于php中文网

原创

umask值决定Linux中新建文件和目录的默认权限,通过调整umask可控制权限分配。系统基础权限为文件666、目录777,umask从其减去对应权限位,如umask 022时文件为644、目录为755。临时修改可用umask命令设置当前会话,永久修改需在~/.bashrc添加umask指令并执行source生效。系统级配置需编辑/etc/login.defs中UMASK值,并确保USERGROUPS_ENAB为yes,同时检查/etc/pam.d/common-session包含pam_umask.so模块。特定服务可通过启动脚本单独设置umask,重启服务后验证权限是否符合预期。

linux如何设置文件或目录的默认权限(umask)_linux默认权限配置技巧

如果您在Linux系统中创建新文件或目录时发现权限不符合预期,可能是umask值未正确配置。umask决定了新创建的文件和目录的默认权限。以下是调整和设置umask值的方法:

本文运行环境:Dell XPS 13,Ubuntu 22.04

一、理解umask的作用机制

umask通过屏蔽特定权限位来控制新建文件和目录的默认权限。系统对文件和目录的基础权限分别为666(rw-rw-rw-)和777(rwxrwxrwx),umask值会从这些基础权限中减去对应权限位。

例如,umask值为022时,文件权限为644(rw-r--r--),目录权限为755(rwxr-xr-x)。数值型umask使用四位八进制数表示,第一位代表特殊权限位,后三位分别代表用户、组和其他的权限掩码。

二、临时修改当前会话的umask

可以在终端中直接执行umask命令来临时更改当前shell会话的默认权限设置,该设置仅在当前会话有效,退出后失效。

1、打开终端,输入 umask 查看当前umask值。

2、输入 umask 027 将umask设置为027,此时新创建的文件权限为640,目录权限为750。

3、使用 touch testfile 和 mkdir testdir 创建测试文件和目录,通过 ls -l 验证权限是否符合预期。

三、永久修改用户级别的umask

通过修改用户主目录下的shell配置文件,可以实现每次登录时自动应用指定的umask值。

1、使用文本编辑器打开 ~/.bashrc 文件:nano ~/.bashrc

2、在文件末尾添加一行 umask 027。

3、保存并关闭文件,执行 source ~/.bashrc 使更改立即生效。

发卡宝-卡密寄售系统
发卡宝-卡密寄售系统

发卡宝是一个专业的软件卡密等虚拟商品在线交易平台,拥有多种兑换方式,费率低,结算快,正规企业平台一直稳定运营,24小时不间断提供自动发卡服务。【模板说明】试用版自带一套模板(响应式)【环境支持】PHP环境 / 200M或以上空间大小 / 开启父路径 / 设置index.php为默认首页 / 目录写入权限需要开启【数据库】MySQL【安装步骤】将文件上传至空间目录,运行“http://域名/inst

下载

4、重新登录或新建shell会话后,umask将保持为设定值。

四、系统级全局umask配置

系统管理员可通过修改PAM模块配置文件来统一设置所有用户的默认umask值,适用于需要统一安全策略的场景。

1、编辑 /etc/login.defs 文件,找到 UMASK 行,将其设置为所需值,如 UMASK 027

2、确保该文件中的 USERGROUPS_ENAB 参数设置为 yes,以保证私有用户组机制正常工作。

3、对于使用PAM的系统,还需检查 /etc/pam.d/common-session 是否包含 pam_umask.so 模块调用。

4、添加或确认存在如下行:session optional pam_umask.so umask=027。

五、针对特定服务设置umask

某些守护进程或服务可能需要独立的umask设置,可通过服务启动脚本单独配置。

1、查找服务的启动脚本位置,通常位于 /etc/init.d/ 或 /lib/systemd/system/ 目录下。

2、在脚本的环境变量区域添加 umask 指令,例如 umask 007

3、重启对应服务使配置生效。

4、验证服务创建的文件权限是否符合新的umask规则。

相关专题

更多
session失效的原因
session失效的原因

session失效的原因有会话超时、会话数量限制、会话完整性检查、服务器重启、浏览器或设备问题等等。详细介绍:1、会话超时:服务器为Session设置了一个默认的超时时间,当用户在一段时间内没有与服务器交互时,Session将自动失效;2、会话数量限制:服务器为每个用户的Session数量设置了一个限制,当用户创建的Session数量超过这个限制时,最新的会覆盖最早的等等。

307

2023.10.17

session失效解决方法
session失效解决方法

session失效通常是由于 session 的生存时间过期或者服务器关闭导致的。其解决办法:1、延长session的生存时间;2、使用持久化存储;3、使用cookie;4、异步更新session;5、使用会话管理中间件。

729

2023.10.18

cookie与session的区别
cookie与session的区别

本专题整合了cookie与session的区别和使用方法等相关内容,阅读专题下面的文章了解更详细的内容。

88

2025.08.19

磁盘配额是什么
磁盘配额是什么

磁盘配额是计算机中指定磁盘的储存限制,就是管理员可以为用户所能使用的磁盘空间进行配额限制,每一用户只能使用最大配额范围内的磁盘空间。php中文网为大家提供各种磁盘配额相关的内容,教程,供大家免费下载安装。

1347

2023.06.21

如何安装LINUX
如何安装LINUX

本站专题提供如何安装LINUX的相关教程文章,还有相关的下载、课程,大家可以免费体验。

700

2023.06.29

linux find
linux find

find是linux命令,它将档案系统内符合 expression 的档案列出来。可以指要档案的名称、类别、时间、大小、权限等不同资讯的组合,只有完全相符的才会被列出来。find根据下列规则判断 path 和 expression,在命令列上第一个 - ( ) , ! 之前的部分为 path,之后的是 expression。还有指DOS 命令 find,Excel 函数 find等。本站专题提供linux find相关教程文章,还有相关

294

2023.06.30

linux修改文件名
linux修改文件名

本专题为大家提供linux修改文件名相关的文章,这些文章可以帮助用户快速轻松地完成文件名的修改工作,大家可以免费体验。

776

2023.07.05

linux系统安装教程
linux系统安装教程

linux系统是一种可以免费使用,自由传播,多用户、多任务、多线程、多CPU的操作系统。本专题提供linux系统安装教程相关的文章,大家可以免费体验。

571

2023.07.06

c++主流开发框架汇总
c++主流开发框架汇总

本专题整合了c++开发框架推荐,阅读专题下面的文章了解更多详细内容。

80

2026.01.09

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PostgreSQL 教程
PostgreSQL 教程

共48课时 | 7万人学习

Git 教程
Git 教程

共21课时 | 2.6万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号