Linux权限修改教程:chmod与chown详解
时间:2026-05-07 11:21:54 413浏览 收藏
本文深入剖析Linux文件权限管理的核心命令chmod与chown,破除“死记755”等常见误区,揭示数字法本质是r=4、w=2、x=1的二进制加权逻辑,强调目录必须含x位才能访问、普通文件不应随意添加执行权限,并对比字母法在增量修改中的安全优势;同时厘清chown命令中冒号用法、递归选项及属组修改陷阱,最后点明权限失效常源于umask掩码或父目录缺失执行位等隐蔽因素——帮你避开线上故障雷区,真正掌握精准、可靠、可维护的权限控制之道。

chmod 数字法怎么算对:别硬背 755,先看 rwx 对应关系
数字法本质是二进制位加权和,不是记忆口诀。r=4、w=2、x=1 是固定映射,rwx 就是 4+2+1=7,rw- 是 4+2+0=6,r-x 是 4+0+1=5。错在把数字当随机码——比如看到 644 就该立刻反应:所有者有 rw-(6),组和其他人只有 r--(4)。
常见误操作:
- 给普通文本文件设
755:文本不需要执行权限,x位多余,还可能被安全扫描误报 - 目录权限设成
644:目录必须有x才能进入,644实际等价于rw-r--r--,会导致cd: Permission denied - 用
777开放临时目录:只要不是共享服务场景,777几乎总是过度授权,尤其当目录里有可执行脚本时
chmod 字母法什么时候比数字法更安全
字母法适合做“微调”,避免覆盖已有权限。比如你只想让组用户也能执行某个脚本,但不确定当前权限是什么,用 chmod g+x script.sh 比先 ls -l 查再换算成数字再 chmod 755 更直接、不易出错。
关键点:
u/g/o/a明确作用对象,不会误改其他身份权限+和-是增量操作,=是全量覆盖——比如chmod o=rw file会清空其他人原有权限,只留读写X(大写 X)很实用:只对目录或已带x的文件添加执行权限,避免给一堆 .txt 加上x位
chown 修改属主和属组的常见陷阱
chown 命令格式容易混淆:chown user:group file 是同时改属主和属组;chown user file 只改属主;chown :group file(注意冒号开头)只改属组。漏掉冒号或写反顺序,就会改错。
典型问题:
- 想只改属组却写了
chown groupname file:这实际改的是属主,不是属组,正确写法是chown :groupname file - 递归修改目录时没加
-R:chown www-data:www-data /var/www只改目录本身,子文件仍属 root,网站可能 500 错误 - 属组名拼错或不存在:命令不报错,但属组不会生效,
ls -l里会显示数字 ID 而非组名,比如drwxr-xr-x 2 root 1001
权限改完还是没效果?检查 umask 和父目录执行位
新建文件权限不对,往往不是 chmod 没用,而是 umask 在起作用。比如 umask 是 002,那 touch 出来的文件默认就是 644(666 & ~002),不是你想的 664。
更隐蔽的问题是父目录缺少 x 权限。即使目标文件本身是 777,如果它的上级目录是 644(即无 x),用户依然无法 cd 进入或 ls 查看内容——Linux 认为“没有执行权限的目录 = 不可访问”。
排查建议:
- 用
ls -ld /path/to/parent看父目录权限,确认至少有r-x(即对应数字位 ≥5) - 用
umask命令查当前掩码,临时调整可用umask 002 - 不要依赖
chmod -R一键修复:它会把目录和文件混着改,比如把所有.log文件也加上x,应分两步:find /path -type d -exec chmod 755 {} \;和find /path -type f -exec chmod 644 {} \;
今天带大家了解了的相关知识,希望对你有所帮助;关于文章的技术知识我们会一点点深入介绍,欢迎大家关注golang学习网公众号,一起学习编程~
相关阅读
更多>
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
最新阅读
更多>
-
227 收藏
-
413 收藏
-
396 收藏
-
451 收藏
-
137 收藏
-
252 收藏
-
454 收藏
-
399 收藏
-
240 收藏
-
123 收藏
-
469 收藏
-
118 收藏
课程推荐
更多>
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 500次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 485次学习