热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

Linux文件ACL权限的设置方法和使用说明

本文介绍了在Linux系统中设置文件ACL权限的方法和使用说明,包括在centos7.3和centos6.9中开启ACL权限的两种方法:在挂载时指定打开ACL权限和修改默认的属性信息。同时提供了对ACL权限的详细解释和应用场景。

工具centos7.3,centos6.9

在设置文件或者目录的权限时,有时候需要设置除了所属人,所属组和其他人之外的权限,这时候就用到了ACL(Access Control List)权限。比方说在一个项目的开发过程中,有两个组参与,并且需要除了这两个组的多个人参加,当然其他人不能访问这个目录。这时候只有所属人,所属组和其他人的权限就不能满足需求了,这时候需要用到ACL权限。

在centos7.3之中,在系统安装时挂载的分区和系统安装过后的手工添加的分区,都默认打开了ACL权限。但是在centos之前的系统中,只有在安装系统时挂载的分区才默认打开了ACL权限,手工添加的分区没有ACL权限,需要手动开启。

一.在centos7之前的系统中开启ACL权限。

在centos6.9中开启ACL权限有两种方法。

方法一:在挂载时指定打开ACL权限。使用命令:mount –o acl  /dev/sdb1 /mnt/test 此命令表示挂载/dev/sdb1 分区到/mnt/test目录下。-o acl表示打开ACL功能。

方法二:修改默认的属性信息。使用命令:tune2fs –o acl /dev/sdb1 此命令表示在默认的属性中将分区/dev/sdb1的ACL权限打开。然后再进行挂载,就可以打开ACL权限了。

二.设置ACL的USER。


三.设置ACL的GROUP。


四.取消ACL权限。


五.彻底删除acl属性。


六.添加完acl权限后各个权限之间的优先级。


不仅如此,对ACL权限还有如下规则:

先判断是否是文件的OWNER,如果是,则执行OWNER的权限后结束,如果不是OWNER,则判断是否是ACL的USER,如果是则执行USER权限后结束,如果不是ACL的USER, 则判断是否属于GROUP或ACL GROUP,如果是,权限取所有组的并集。如果不属于任何GROUP,则执行OTHER。
所有人->所有组->其他人

七.mask的作用。


八.给目录设置默认的ACL。



九.备份和恢复ACL



十.ACl权限对权限的管理比较灵活,在工作中经常碰到,希望读者对acl权限有了进一步的认识。以下是对setfacl的一些总结:

mount -o acl /directory 

挂载时打开acl功能。

getfacl file |directory   

 查看文件或者目录的acl权限

setfacl -m u:liubei:--- f1  设置ACL USER
setfacl -m g:shuguo:rwx f1  设置ACL GROUP
setfacl -M acl.txt f1[dir1]
acl.txt 内容来自getfacl f1 > acl.txt,如下
# file: fstab
# owner: root
# group: root
user::rw-
user:zhangfei:rwx
group::r--
mask::rwx
other::r--
setfacl -Rm u:zhangfei:rwx acltest/   递归设置
setfacl -m mask:rwx f1
或 chmod g=rwx f1 一旦设置了ACL权限后,原有的文件GROUP需要使用setfacl -m g::groupname filename或者dirname,使用chmod g即修改ACL MASK
ACL MASK随着新的ACL设置会被重置,重置的标准是让该文件上的所有ACL及文件原GROUP上的权限都有效。
setfacl -x u:liubei f1  单独去除一条ACL权限
setfacl -X aclrm.txt f1[ f2 f3 *]
aclrm.txt 内容如下
u:liubei
g:shuguo


setfacl -m d:u:wang:rx directory

设置目录的默认acl权限。default


推荐阅读
  • 本文详细介绍如何使用Python进行配置文件的读写操作,涵盖常见的配置文件格式(如INI、JSON、TOML和YAML),并提供具体的代码示例。 ... [详细]
  • CentOS7源码编译安装MySQL5.6
    2019独角兽企业重金招聘Python工程师标准一、先在cmake官网下个最新的cmake源码包cmake官网:https:www.cmake.org如此时最新 ... [详细]
  • 本文详细介绍了Linux系统中init进程的作用及其启动过程,解释了运行级别的概念,并提供了调整服务启动顺序的具体步骤和实例。通过了解这些内容,用户可以更好地管理系统的启动流程和服务配置。 ... [详细]
  • 本文详细记录了在基于Debian的Deepin 20操作系统上安装MySQL 5.7的具体步骤,包括软件包的选择、依赖项的处理及远程访问权限的配置。 ... [详细]
  • 1:有如下一段程序:packagea.b.c;publicclassTest{privatestaticinti0;publicintgetNext(){return ... [详细]
  • 1.如何在运行状态查看源代码?查看函数的源代码,我们通常会使用IDE来完成。比如在PyCharm中,你可以Ctrl+鼠标点击进入函数的源代码。那如果没有IDE呢?当我们想使用一个函 ... [详细]
  • 本文详细介绍了 Dockerfile 的编写方法及其在网络配置中的应用,涵盖基础指令、镜像构建与发布流程,并深入探讨了 Docker 的默认网络、容器互联及自定义网络的实现。 ... [详细]
  • 掌握远程执行Linux脚本和命令的技巧
    本文将详细介绍如何利用Python的Paramiko库实现远程执行Linux脚本和命令,帮助读者快速掌握这一实用技能。通过具体的示例和详尽的解释,让初学者也能轻松上手。 ... [详细]
  • 从 .NET 转 Java 的自学之路:IO 流基础篇
    本文详细介绍了 Java 中的 IO 流,包括字节流和字符流的基本概念及其操作方式。探讨了如何处理不同类型的文件数据,并结合编码机制确保字符数据的正确读写。同时,文中还涵盖了装饰设计模式的应用,以及多种常见的 IO 操作实例。 ... [详细]
  • 基于KVM的SRIOV直通配置及性能测试
    SRIOV介绍、VF直通配置,以及包转发率性能测试小慢哥的原创文章,欢迎转载目录?1.SRIOV介绍?2.环境说明?3.开启SRIOV?4.生成VF?5.VF ... [详细]
  • 本文详细介绍了如何在Linux系统上安装和配置Smokeping,以实现对网络链路质量的实时监控。通过详细的步骤和必要的依赖包安装,确保用户能够顺利完成部署并优化其网络性能监控。 ... [详细]
  • 本文介绍了一款用于自动化部署 Linux 服务的 Bash 脚本。该脚本不仅涵盖了基本的文件复制和目录创建,还处理了系统服务的配置和启动,确保在多种 Linux 发行版上都能顺利运行。 ... [详细]
  • CMake跨平台开发实践
    本文介绍如何使用CMake支持不同平台的代码编译。通过一个简单的示例,我们将展示如何编写CMakeLists.txt以适应Linux和Windows平台,并实现跨平台的函数调用。 ... [详细]
  • 如何配置Unturned服务器及其消息设置
    本文详细介绍了Unturned服务器的配置方法和消息设置技巧,帮助用户了解并优化服务器管理。同时,提供了关于云服务资源操作记录、远程登录设置以及文件传输的相关补充信息。 ... [详细]
  • 本文详细分析了Hive在启动过程中遇到的权限拒绝错误,并提供了多种解决方案,包括调整文件权限、用户组设置以及环境变量配置等。 ... [详细]
author-avatar
3号仔小麦
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有