0

0

Linux umask 对权限的影响

冰川箭仙

冰川箭仙

发布时间:2026-01-25 18:01:04

|

119人浏览过

|

来源于php中文网

原创

umask 通过按位取反后与默认权限(文件666、目录777)做与运算来屏蔽权限,而非直接设置;Linux内核禁止普通文件默认有执行权限,与umask无关。

linux umask 对权限的影响

umask 是怎么“减掉”权限的

umask 不是直接设置权限,而是从默认权限里“屏蔽”掉某些位。文件默认最大权限是 666rw-rw-rw-),目录是 777rwxrwxrwx)。umask 值按位取反后与默认值做与运算(& ~umask),这才是真实创建时的权限。

比如 umask 0022: - 文件:666 & ~0022 = 644-rw-r--r-- - 目录:777 & ~0022 = 755drwxr-xr-x

注意:Linux 禁止新创建的普通文件带执行权限,哪怕 umask 是 0000touch 出来的文件也绝不会自动有 x 位 —— 这是内核级安全限制,和 umask 无关。

临时改 umask 的常见误操作

很多人在终端里输 umask 0077 后立刻 touch test,发现权限是 -rw-------,就以为生效了。但容易忽略三点:

  • 这个设置只对当前 shell 进程有效,新开终端、SSH 登录、脚本子 shell 都不继承
  • 如果用了 sudo -isu -,会加载目标用户的配置,覆盖当前 umask
  • 某些 IDE 或编辑器(如 VS Code Remote)启动的终端可能绕过你的 .bashrc,导致 umask 没被重设

验证是否真生效,别只看 umask 输出值,一定要用 touch + ls -l 实测:

umask 0077
touch afile && mkdir adir
ls -l afile adir

永久设置该写进哪个配置文件

用户级永久生效,优先写入 ~/.bashrc;但要注意 Shell 类型:

Hive权限控制 中文WORD版
Hive权限控制 中文WORD版

Hive从0.10版本(包含0.10版本)以后可以通过元数据来控制权限,Hive-0.10之前的版本对权限的控制主要是通过Linux的用户和用户组来控制,不能对Hive表的CREATE、SELECT、DROP等操作进行控制,当然Hive基于元数据来控制权限也不是完全安全的,目的就是为了防止用户不小心做了不该做的操作。感兴趣的朋友可以过来看看

下载
  • bash 用户:写 ~/.bashrc(交互式非登录 shell 默认读它)
  • zsh 用户:得写 ~/.zshrc,写错文件就白配了
  • 登录 shell(如 SSH)可能先读 ~/.profile,而它默认不 source .bashrc,所以单独加一行 source ~/.bashrc 更稳妥

系统级统一策略(如服务器多用户环境),应改 /etc/pam.d/common-session 并加 session optional pam_umask.so umask=0027,而不是动 /etc/profile —— 后者对非 bash shell 或图形界面登录可能无效。

为什么 umask 002 和 0007 的效果看起来一样

初学者常困惑:umask 002umask 0007 都让组和其他人没写权限,但实际行为不同:

  • umask 002:文件 → 664-rw-rw-r--),目录 → 775drwxrwxr-x
  • umask 0007:文件 → 660-rw-rw----),目录 → 770drwxrwx---

区别在于“其他人(others)”有没有读权限。协作项目中若用 0007,其他用户连 ls 都看不到你的文件 —— 这不是权限太严,而是设计意图错位:umask 控制的是“新建时的起点”,不是事后 ACL 策略。真要精细控制,该用 setgid 目录 + 组管理,而不是靠 umask 把门焊死。

相关专题

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

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

315

2023.10.17

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

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

747

2023.10.18

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

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

88

2025.08.19

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

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

1373

2023.06.21

如何安装LINUX
如何安装LINUX

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

705

2023.06.29

linux find
linux find

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

295

2023.06.30

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

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

777

2023.07.05

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

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

573

2023.07.06

c++ 根号
c++ 根号

本专题整合了c++根号相关教程,阅读专题下面的文章了解更多详细内容。

45

2026.01.23

热门下载

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

精品课程

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

共48课时 | 7.8万人学习

Git 教程
Git 教程

共21课时 | 3万人学习

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

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