深入浅出 Linux 权限管理

1. Linux 权限管理概述

在 Linux 系统中,权限是非常重要的概念,它决定了用户对文件和目录的访问权限。任何一个文件或目录都有三种不同的权限设置:用户权限,群组权限和其他人权限。

用户权限是针对文件或目录所有者设置的,群组权限是针对文件或目录所属群组的用户设置的,而其他人权限是指除了所有者和所属群组以外的其他用户。

2. 文件权限

2.1 权限表示法

文件权限可以用符号表示法或者数字表示法来表示。

符号表示法:r 表示可读,w 表示可写,x 表示可执行。每个位置上可以用 - 表示无权限。

数字表示法:用数字 0-7 分别表示 r、w、x 的权限,其中 4 表示可读, 2 表示可写, 1 表示可执行。

2.2 修改文件权限

可以使用 chmod 命令来修改文件的权限。其语法为:

chmod 权限 设置 文件名

其中,权限可以用符号或数字表示,设置可以是 + 或 -,表示添加或移除权限。

3. 目录权限

3.1 目录权限对比文件权限

对于目录而言,x 权限代表可以进入此目录。r 权限代表可以读取此目录的文件列表,w 权限代表可以在此目录下创建或删除文件。

3.2 修改目录权限

修改目录权限的方法与修改文件权限的方法相同,可以使用 chmod 命令。

4. 用户和群组管理

4.1 用户管理

Linux 系统中的每个用户都有一个唯一的用户 ID(UID),可以使用 useradd 命令来创建新用户,使用 userdel 命令来删除用户。

4.2 群组管理

群组可以方便地管理用户,多个用户可以属于同一个群组。可以使用 groupadd 命令来创建新群组,使用 groupdel 命令来删除群组。

5. SUID、SGID 和 Sticky 位

5.1 SUID

SUID 是一种特殊的权限,可以使得在执行文件时,以文件所有者的权限来执行,而不是当前用户的权限。它可以通过 chmod 命令的 u+s 参数设置。

5.2 SGID

SGID 类似于 SUID,但是作用于目录上时,可以使得新创建的文件继承目录的群组所有者。可以通过 chmod 命令的 g+s 参数设置。

5.3 Sticky 位

Sticky 位主要用于目录,如果一个目录拥有 Sticky 位,那么只有目录所有者才能删除或重命名该目录下的文件。可以通过 chmod 命令的 o+t 参数设置。

6. ACL(Access Control Lists)权限

6.1 传统权限与 ACL 权限

传统的 Linux 权限只能设置一个用户和一个群组,而 ACL 权限可以为一个文件或目录设置多个用户和群组的权限。

6.2 修改 ACL 权限

可以使用 setfacl 命令来修改 ACL 权限,其语法如下:

setfacl -m u:用户:权限 目录或文件名

7. SELinux 安全模块

7.1 SELinux 简介

SELinux 是一个安全子系统,可以对进程和文件进行访问控制,提供更细粒度的权限管理。

7.2 SELinux 权限

SELinux 针对每个进程和文件提供三种权限:执行权限(x)、写权限(w)和读权限(r)。可以使用 chcon 命令来修改 SELinux 权限。

8. 总结

Linux 权限管理是一个非常重要的概念,掌握好权限管理的方法可以提高系统的安全性。我们需要了解文件权限和目录权限的含义和修改方式,以及用户和群组管理、特殊权限(SUID、SGID 和 Sticky 位)、ACL 权限和 SELinux 的使用。

操作系统标签