Linux系统中的权限管理是保障系统安全的核心机制,通过控制用户、组对文件和目录的访问权限,防止未授权操作,掌握权限修改方法对日常运维至关重要,本文将详细讲解Linux下修改权限的操作步骤、命令用法及注意事项。

Linux权限基于“用户(User)、组(Group、其他(Others)”三类身份,每类身份拥有“读(r)、写(w)、执行(x)”三种基本权限,分别用数字4、2、1表示,例如权限“755”表示“所有者(rwx=7)、组(r-x=5)、其他(r-x=5)”,修改权限主要通过chmod、chown、chgrp命令实现,具体操作如下:
使用chmod修改文件/目录权限
chmod(Change Mode)是修改权限的核心命令,支持数字法和符号法两种表达方式。
数字法(推荐)
通过数字组合直接设置权限,格式为chmod [权限数字] [文件/目录]。
chmod 644 file.txt:设置所有者读写(rw-)、组只读(r–)、其他只读(r–),适用于普通文本文件。chmod 755 script.sh:设置所有者读写执行(rwx)、组和其他读执行(r-x),适用于可执行脚本。chmod 600 secret.key:仅所有者可读写(rw-),组和其他无权限(—),适用于敏感文件。
符号法(灵活调整)
通过u(用户)、g(组)、o(其他)、a(所有)+(添加)、(移除)、(设置)操作符调整权限,格式为chmod [ugoa][+-=][rwx] [文件/目录]。
chmod u+x script.sh:为所有者添加执行权限。chmod g-w project_dir:移除组的写权限。chmod o=r file.txt:设置其他用户仅可读。
数字法权限对应表
| 权限组合 | 数字 | 含义 |
|---|---|---|
| rwx | 7 | 读+写+执行 |
| rw- | 6 | 读+写 |
| r-x | 5 | 读+执行 |
| r– | 4 | 读 |
| -wx | 3 | 写+执行 |
| -w- | 2 | 写 |
| –x | 1 | 执行 |
| 0 | 无权限 |
修改文件/目录所有者与所属组
权限与所有者强相关,若需彻底解决权限问题,有时需调整文件所有者(chown)或所属组(chgrp)。

chown(Change Owner)
格式为chown [所有者]:[组] [文件/目录],仅修改所有者时省略“:组”。
chown alice file.txt:将文件所有者改为用户alice。chown alice:dev_group project_dir:将目录所有者设为alice,所属组设为dev_group。chown -R alice:dev_group /var/www:递归修改目录及其子目录的所有者和组(-R表示递归)。
chgrp(Change Group)
若仅需修改所属组,可用chgrp,格式为chgrp [组] [文件/目录]。
chgrp dev_group file.txt:将文件所属组改为dev_group。
特殊权限与高级设置
除基本权限外,Linux还支持SUID、SGID、Sticky Bit等特殊权限,用于特定场景(如提权、共享目录)。
- SUID(4):仅对可执行文件有效,执行时以文件所有者权限运行(如
/usr/bin/passwd)。
chmod 4755 suid_file - SGID(2):对文件/目录有效,目录下新建文件继承所属组(如团队共享目录)。
chmod 2775 sgid_dir - Sticky Bit(1):仅对目录有效,防用户删除他人文件(如
/tmp)。
chmod 1775 sticky_dir
权限检查与常见问题排查
修改权限后,通过ls -l查看权限详情(如-rwxr-xr-- 1 alice dev_group 0 10月1 10:00 file.txt),或用stat命令查看详细元数据。
常见问题:

- 权限不足:使用
sudo提权执行(如sudo chmod 755 /root/secret_file)。 - 目录无法进入:检查目录执行权限(x),如
chmod u+x /home/alice/docs。
相关问答FAQs
Q1:为什么chmod 777不推荐使用?
A:chmod 777赋予所有用户读写执行权限,会破坏系统安全性,若重要配置文件设为777,任何用户均可篡改内容,可能导致系统异常或数据泄露,建议遵循最小权限原则,仅开放必要的权限(如普通文件644,可执行文件755)。
Q2:如何批量修改目录及其子目录的权限?
A:使用chmod的-R(递归)选项,但需谨慎操作,避免误改系统文件。
chmod -R 755 /path/to/dir:递归修改目录及其子目录权限为755(注意:会覆盖所有子文件权限)。- 若需仅修改目录权限(保留文件权限),可通过
find命令实现:find /path/to/dir -type d -exec chmod 755 {} ; # 仅修改目录 find /path/to/dir -type f -exec chmod 644 {} ; # 仅修改文件
原创文章,发布者:酷番叔,转转请注明出处:https://cloud.kd.cn/ask/27592.html