0

0

如何在Linux中配置ACL实现精细权限控制?

舞夢輝影

舞夢輝影

发布时间:2025-11-03 10:59:30

|

378人浏览过

|

来源于php中文网

原创

通过配置ACL可实现Linux文件权限的精细化管理,突破传统用户-组-其他模型限制。启用ACL需确保文件系统挂载时包含acl选项,可通过mount命令查看并修改/etc/fstab实现。使用setfacl -m为特定用户或组设置权限,如u:alice:rwX赋予alice读写执行权,g:developers:rx为组添加读和执行权限。对目录设置默认ACL(setfacl -d)可使新文件自动继承权限。getfacl用于查看当前ACL配置,显示包括所有者、组及其他相关权限条目。删除单个条目用setfacl -x,清除全部扩展ACL则使用-b选项。mask权限决定实际生效的最大权限,修改mask会限制其下所有条目的访问能力;chmod操作会自动更新mask值,可能影响原有ACL效果。合理应用ACL可在不更改文件归属的前提下灵活授权,适用于多用户协作环境,但应定期审计以防权限滥用。

如何在linux中配置acl实现精细权限控制?

在Linux中,传统的权限模型(用户、组、其他)有时无法满足复杂的访问需求。通过配置ACL(Access Control List,访问控制列表),可以实现更精细的文件和目录权限管理。ACL允许为单个文件或目录设置多个用户和组的独立权限,突破标准权限的限制。

启用文件系统的ACL支持

大多数现代Linux发行版默认支持ACL,但需确保文件系统挂载时启用了ACL功能。

检查根分区或目标分区是否已启用ACL:

mount | grep $(df /path/to/target | tail -1 | awk '{print $1}')

输出中应包含 acl 选项。例如:

/dev/sda1 on /home type ext4 (rw,relatime,acl)

若未启用,可在 /etc/fstab 中为对应分区添加 acl 挂载选项:

UUID=xxxx-xxxx /home ext4 defaults,acl 0 2

然后重新挂载:

sudo mount -o remount /home

使用setfacl设置ACL权限

setfacl 命令用于设置ACL规则。常用选项包括:

  • -m:修改ACL规则
  • -x:删除指定ACL条目
  • -R:递归应用到子目录和文件
  • -d:设置默认ACL(仅对目录有效)

为用户alice赋予对/data/project的读写执行权限:

sudo setfacl -m u:alice:rwX /data/project

为组developers添加执行和读取权限:

sudo setfacl -m g:developers:rx /data/project

设置默认ACL,使新创建的文件自动继承权限:

TURF(开源)权限管理系统
TURF(开源)权限管理系统

TURF(开源)权限定制管理系统(以下简称“TURF系统”),是蓝水工作室推出的一套基于软件边界设计理念研发的具有可定制性的权限管理系统。TURF系统充分考虑了易用性,将配置、设定等操作进行了图形化设计,完全在web界面实现,程序员只需在所要控制的程序中简单调用一个函数,即可实现严格的程序权限管控,管控力度除可达到文件级别外,还可达到代码级别,即可精确控制到

下载
sudo setfacl -d -m u:alice:rwX /data/project

查看和删除ACL权限

使用getfacl命令查看文件或目录的ACL设置:

getfacl /data/project

输出示例:

# file: data/project # owner: root # group: root user::rwx user:alice:rwX group::r-x group:developers:r-x mask::rwx other::r-x

删除某个用户的ACL:

sudo setfacl -x u:alice /data/project

清除所有扩展ACL条目:

sudo setfacl -b /data/project

理解ACL中的mask权限

ACL中的mask决定了用户和组条目的最大有效权限。实际生效权限是条目权限与mask的交集。

修改mask值会影响所有受其约束的条目:

sudo setfacl -m mask::r-- /data/project

此时即使设置了u:alice:rwX,实际生效权限也会被限制为只读。

当使用chmod更改文件权限时,会自动更新mask值,因此ACL权限可能随之变化。

基本上就这些。合理使用ACL可以在不改变文件所有者或主组的前提下,灵活授权多个用户和组,适合团队协作或多角色访问场景。注意定期审计ACL设置,避免权限过度累积。

相关专题

更多
python中print函数的用法
python中print函数的用法

python中print函数的语法是“print(value1, value2, ..., sep=' ', end=' ', file=sys.stdout, flush=False)”。本专题为大家提供print相关的文章、下载、课程内容,供大家免费下载体验。

185

2023.09.27

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

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

1349

2023.06.21

如何安装LINUX
如何安装LINUX

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

704

2023.06.29

linux find
linux find

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

294

2023.06.30

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

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

776

2023.07.05

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

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

573

2023.07.06

linux查看文件夹大小
linux查看文件夹大小

Linux是一种自由和开放源码的类Unix操作系统,存在着许多不同的Linux版本,但它们都使用了Linux内核。Linux可安装在各种计算机硬件设备中,比如手机、平板电脑、路由器、视频游戏控制台、台式计算机、大型机和超级计算机。linux怎么查看文件夹大小呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

546

2023.07.20

linux查看ip命令
linux查看ip命令

本专题为大家提供linux查看ip命令相关文章内容,感兴趣的朋友可以免费下载体验试试。

297

2023.07.20

Java JVM 原理与性能调优实战
Java JVM 原理与性能调优实战

本专题系统讲解 Java 虚拟机(JVM)的核心工作原理与性能调优方法,包括 JVM 内存结构、对象创建与回收流程、垃圾回收器(Serial、CMS、G1、ZGC)对比分析、常见内存泄漏与性能瓶颈排查,以及 JVM 参数调优与监控工具(jstat、jmap、jvisualvm)的实战使用。通过真实案例,帮助学习者掌握 Java 应用在生产环境中的性能分析与优化能力。

3

2026.01.20

热门下载

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

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PostgreSQL 教程
PostgreSQL 教程

共48课时 | 7.4万人学习

Git 教程
Git 教程

共21课时 | 2.8万人学习

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

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