首页 > 系统相关 >如何在 Linux 中使用 ACL、chmod 和 chown 进行文件权限控制

如何在 Linux 中使用 ACL、chmod 和 chown 进行文件权限控制

时间:2024-07-07 18:26:35浏览次数:23  
标签:文件 权限 chmod ACL chown Linux test txt

在 Linux 系统中,ACL(访问控制列表)、chown 和 chmod 是管理文件和目录权限的主要工具。本文将详细介绍如何在 CentOS 中使用这些工具进行权限控制,并对它们的区别和具体用法进行说明。

1. 基本概念

ACL(Access Control List)
ACL(Access Control List)是一种用于控制文件和目录访问权限的机制,允许更细粒度的权限设置。可以为多个用户和组设置不同的权限,而不仅仅是传统 Unix 文件系统的拥有者、组和其他用户的三种权限级别。

chown(Change Owner)
chown 命令用于改变文件或目录的所有者和所属组。

chmod(Change Mode)
chmod 命令用于改变文件或目录的访问权限。它使用三种基本权限(读、写、执行)和三种角色(所有者、组、其他人)。

2. 使用场景

ACL:适用于需要复杂权限管理的场景,例如同一文件需要不同用户和组具有不同权限的情况。
chown:用于改变文件或目录的所有者或组,例如将文件的所有权转移给另一个用户。
chmod:适用于设置基本权限的场景,例如简单的读写执行权限设置。

3. ACL 命令
3.1 ACL 基本概念
  • 用户(User):特定用户的权限。
  • 组(Group):特定组的权限。
  • 掩码(Mask):限制所有用户和组的最大权限。
  • 默认(Default):新文件和目录继承的默认权限。
3.2 权限类型
  • 读(r):允许读取文件内容或列出目录内容。
  • 写(w):允许修改文件内容或在目录中创建、删除文件。
  • 执行(x):允许执行文件或进入目录。
3.3 使用指南

确保你的文件系统支持 ACL。如果使用的是 ext4 文件系统,需要挂载时加上 acl 选项:

sudo tune2fs -o acl /dev/sda1

重启后确保挂载选项中包含 acl:

sudo mount -o remount,acl /dev/sda1
3.3.1 安装 ACL 工具

在 CentOS 上,ACL 工具通常默认安装。如果未安装,可以通过以下命令安装:

sudo yum install acl
3.3.2 设置 ACL 权限

首先,创建一个示例文件:

echo "This is a test file." > test.txt

设置用户权限
使用 setfacl 命令为特定用户设置权限。例如,为用户 kinlon 设置读写权限:

sudo setfacl -m u:kinlon:rw test.txt

设置组权限
使用 setfacl 命令为特定组设置权限。例如,为组 test 设置读取权限:

sudo setfacl -m g:test:r test.txt

设置掩码
掩码限制所有用户和组的最大权限。例如,设置掩码为读写权限:

sudo setfacl -m m::rw test.txt

查看 ACL 权限
使用 getfacl 命令查看文件的 ACL 配置:

getfacl test.txt

输出如下:

# file: test.txt
# owner: root
# group: root
user::rw-
user:kinlon:rw-
group::r--
group:test:r--
mask::rw-
other::r--

删除 ACL 权限
如果需要删除某个用户或组的 ACL 权限,可以使用 setfacl 命令的 -x 选项。例如,删除用户 kinlon 的权限:

sudo setfacl -x u:kinlon test.txt
4. chown、chmod命令
4.1使用 chown 修改文件所有者

chown 命令用于改变文件或目录的所有者和所属组。例如,将文件 test.txt 的所有者改为 kinlon,所属组改为 test:

sudo chown kinlon:test test.txt

查看更改后的文件信息:

sudo chown kinlon:test test.txt

输出示例:

-rw-r--r-- 1 kinlon test 1234 Jun 28 12:34 test.txt
4.2使用 chmod 修改文件权限

chmod 命令用于改变文件或目录的访问权限。例如,将文件 test.txt 的权限设置为所有者可读写,组用户和其他用户只读:

sudo chmod 644 test.txt

查看更改后的文件信息:

ls -l test.txt

输出示例:

-rw-r--r-- 1 kinlon test 1234 Jun 28 12:34 test.txt
总结
  • ACL 提供了更细粒度的权限控制,适用于复杂权限管理。
  • chown 用于更改文件或目录的所有者和组。
  • chmod 用于设置基本的读、写、执行权限。
    选择哪种工具取决于你的具体需求。如果需要为多个用户和组设置不同的权限,ACL 是最佳选择。如果只需要简单地改变所有权或基本权限,chown 和 chmod 就足够了。通过灵活使用这些工具,可以实现高效且安全的权限管理。

标签:文件,权限,chmod,ACL,chown,Linux,test,txt
From: https://blog.csdn.net/jinhope/article/details/140091499

相关文章

  • Linux进程(1)(结构-操作系统-进程)
    目录1.体系结构 2.操作系统(OperatorSystem)1)概念:2)结构示意图(不完整)3)尝试理解操作系统4)系统调用和库函数概念3.认识进程1.启动2.进程创建的代码方式---重操作,轻原理1)创进程2)我们为什么要创建子进程呢? 1.体系结构输入设备:键盘、鼠标、摄像头、话筒、磁盘、......
  • 在Linux中,当你需要给命令绑定⼀个宏或者按键的时候,应该怎么做呢?
    在Linux中,给命令绑定一个宏或者按键通常涉及到使用shell的内置命令或者编辑器(如vim)的宏定义功能。以下是详细的步骤和方法:1.使用bash的bind命令bashshell的bind命令允许你更改bash对键盘上按下的键和键组合的响应方式,从而实现宏或按键的绑定。基本步骤查找按键的字符序列:......
  • 在Linux中,内核调优配置文件名字有哪些?举例几个内核需要优化的参数配置?
    在Linux中,内核调优涉及到对系统内核的各种参数进行优化,以适应不同的工作负载和场景。这些参数主要存储在两个地方:一个是运行时动态可调的/proc/sys目录下的文件,另一个是持久化的配置文件/etc/sysctl.conf。1.内核调优配置文件/etc/sysctl.conf:这是最常用的内核参数配置文件,用......
  • 在Linux中,bash shell 中的 hash 命令有什么作用?
    在bashshell中,hash命令与命令查找和缓存机制紧密相关。当你输入一个命令时,bash需要找到该命令的可执行文件的位置(即其路径)以便执行它。bash有几种方式来完成这个任务,其中之一就是使用哈希表(hashtable)来缓存之前查找过的命令的路径。这就是hash命令发挥作用的地方。1.hash命令......
  • 在Linux中,系统目前有许多正在运行的任务,在不重启机器的条件下,有什么方法可以把所有正
    在Linux中,可以使用kill命令来终止正在运行的进程。要移除所有正在运行的进程,可以结合使用ps命令和xargs命令来实现。首先,我们可以使用ps命令列出所有正在运行的进程,然后通过管道(|)将结果传递给xargs命令,最后使用kill命令终止这些进程。具体操作如下:打开终端。输入以下命令:ps......
  • 在Linux中,哪⼀个bash内置命令能够进行数学运算?
    在Linux中,bashshell提供了多种方式进行数学运算,但严格来说,bash本身并没有一个专门的内置命令专门用于数学运算,而是通过一些特殊的语法和命令组合来实现。以下是一些常见的bash中进行数学运算的方法:1.使用$((expression))进行算术扩展这是bash中推荐的标准处理方法,用于执行基本......
  • 震惊!Linux 常用命令总结,不看必定后悔!!!
    Linux是一个强大的操作系统,拥有大量的命令行工具。以下是一些常用的Linux命令及其基本用法:ls -列出目录内容。ls:列出当前目录下的文件和文件夹。ls-l:以长格式列出详细信息,包括权限、所有者、大小等。ls-a:列出所有文件,包括隐藏文件。cd -改变当前目录。cd/path/......
  • 嵌入式Linux系统编程 — 7.2 进程的环境变量
    目录1什么是进程的环境变量2环境变量的作用3 应用程序中获取环境变量3.1 environ全局变量3.2 获取指定环境变量getenv4 添加/删除/修改环境变量4.1 putenv()函数添加环境变量4.2 setenv()函数4.3 unsetenv()函数1什么是进程的环境变量每一个进程都有一......
  • Oracle死锁解决方式
    死锁是指在Oracle数据库中,两个或多个事务相互等待对方持有的锁资源,导致它们无法继续执行下去,从而形成死锁现象解决方式如下:查询死锁信息:selectSID,USERNAME,LOCKWAIT,STATUS,MACHINE,PROGRAM,EVENTfromV$SESSIONwhereSIDin(selectSESSION_IDfromV$LOCKED_OBJECT)......
  • Linux 基础命令实例教程
    Linux是一个强大的操作系统,掌握其基本命令对任何级别的用户来说都是至关重要的。本文将通过具体的实例来演示一些常用的Linux命令,帮助你更好地理解和运用它们。1.文件和目录操作例:列出当前目录下的所有文件和目录ls-la这会列出当前目录下所有文件和目录的详细信息......