0

0

Linux系统用户默认Umask值设置及文件权限基线

冷炫風刃

冷炫風刃

发布时间:2026-03-13 20:58:31

|

872人浏览过

|

来源于php中文网

原创

umask值通过终端执行umask命令查看,输出为八进制掩码(如0002),需与默认基线权限(文件666、目录777)按位取反运算得出实际权限;其生效位置取决于shell类型:登录shell读/etc/profile等,非登录shell读~/.bashrc;scp等工具不继承本地umask,需配置远端sshd的Umask或PAM;脚本内修改umask不影响父shell。

linux系统用户默认umask值设置及文件权限基线

umask 值怎么查?别只看 umask 命令输出

终端里敲 umask 看到的八进制数(比如 0002)不是最终文件权限,它只是“掩码”,真正起作用的是它和系统默认基线权限的按位取反运算。普通文件默认基线是 666,目录是 777umask 会从这些值里“砍掉”对应位的权限。

  • 执行 umask 显示 0002 → 新建文件权限为 664(即 -rw-rw-r--),目录为 775drwxrwxr-x
  • 如果显示 0027 → 文件变成 640-rw-r-----),目录是 750drwxr-x---
  • 注意:umask 输出带前导 0 表示八进制,但部分 shell(如 zsh)可能省略——统一按八进制理解最稳妥

/etc/profile 和 ~/.bashrc 里改 umask,哪个才生效?

用户登录时,shell 会按顺序读取多个配置文件,umask 设置位置错了就白改。关键看你是交互式登录 shell 还是非登录 shell:

  • 登录时(比如 SSH 进系统):优先加载 /etc/profile/etc/profile.d/*.sh~/.bash_profile~/.bash_login~/.profile(按存在顺序取第一个)
  • 非登录 shell(比如在已登录终端里新开个 bash):通常只读 ~/.bashrc,除非显式用 --login 启动
  • 所以:全局策略写 /etc/profile.d/umask.sh;仅当前用户调整,写进 ~/.bashrc 并确保它被 source 过(检查是否有 source ~/.bashrc 或等效逻辑)

umask 设成 077 后,为什么 scp 传上来的文件还是 644

scp、rsync、ftp 等工具上传文件时,**不走本地 shell 的 umask**,而是由远端服务进程(如 sshd)决定权限。sshd 默认用 PAM 模块或自身配置控制,和用户 shell 的 umask 无关。

一点PPT
一点PPT

一句话生成专业PPT,AI自动排版配图

下载
  • 验证方法:在目标机器上手动 touch testfile,对比权限是否和 scp 上传的一致
  • 要统一 scp 权限,得改远端 /etc/ssh/sshd_config,加上 Umask 0077(OpenSSH 7.9+ 支持),然后 systemctl restart sshd
  • 老版本 OpenSSH 不支持 Umask 配置项,只能靠 PAM:在 /etc/pam.d/sshd 加一行 session optional pam_umask.so umask=0077

脚本里临时改 umask,exit 后会不会影响父 shell?

不会。子进程(包括 shell 脚本)对 umask 的修改仅作用于自身及其子进程,退出后父 shell 的 umask 完全不受影响。

  • 常见误操作:在脚本开头写 umask 0077,以为能保护后续所有操作,结果脚本一结束就失效
  • 正确做法:若需长期限制权限,必须在 shell 初始化文件中设置;若只是某次命令需要,直接在命令前加 umask 0077; touch sensitive.txt,或用子 shell:(umask 0077; touch sensitive.txt)
  • 注意:某些语言运行时(如 Python 的 os.umask())也只影响当前进程,和 shell 行为一致

真正麻烦的是混合环境:既有 cron 任务、又有 systemd service、还有 web server 调用的 CGI 脚本——它们各自继承的 umask 来源不同,得一个个确认启动上下文。别假设“我设了 ~/.bashrc 就万事大吉”。

相关标签:

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

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

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

336

2023.10.17

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

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

776

2023.10.18

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

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

97

2025.08.19

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

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

1564

2023.06.21

如何安装LINUX
如何安装LINUX

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

716

2023.06.29

linux find
linux find

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

300

2023.06.30

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

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

800

2023.07.05

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

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

588

2023.07.06

TypeScript类型系统进阶与大型前端项目实践
TypeScript类型系统进阶与大型前端项目实践

本专题围绕 TypeScript 在大型前端项目中的应用展开,深入讲解类型系统设计与工程化开发方法。内容包括泛型与高级类型、类型推断机制、声明文件编写、模块化结构设计以及代码规范管理。通过真实项目案例分析,帮助开发者构建类型安全、结构清晰、易维护的前端工程体系,提高团队协作效率与代码质量。

26

2026.03.13

热门下载

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

精品课程

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

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