1.简介:
  a.作用:
    是为了防止权限不够用的情况,一般的权限有所有者、所属组、其他人这三种,当这三种满足不了我们的需求的时候就可以使用ACL权限
  
  b.故事背景:
    一个老师,给一个班的学员上课,他在linux的根目录下面建立了一个文件夹,只允许本班级的学员对该目录进行读写执行操作,其他人都不行,这时该目录的权限一般是770(一般我们设置权限都是所有者的权限大于所属组的权限,所属组的权限大于其他人的权限,依次往下),此时有个同学想试听我们的课程,他们只有读和执行的权限,没有写的权限,那么此时该怎么分配权限呢?此时的话所属组、所有者、其他人都不满足,这是就用到ACL权限

2.使用条件
  a.只需硬盘开启对ACL的支持即可,现在Linux上都是默认开启的
  b.查看是否支持acl权限
    1.查看自己linux上的硬盘信息
      df -h
        Filesystem Size Used Avail Use% Mounted on
        /dev/mapper/VolGroup-lv_root 6.5G 1.6G 4.7G 26% /
        tmpfs 246M 0 246M 0% /dev/shm
        /dev/sda1 477M 28M 425M 7% /boot
    2.根据硬盘信息,查询是否开启了acl
      dumpe2fs -h /dev/sda1 | grep "Default mount options"
        dumpe2fs 1.41.12 (17-May-2010)
        Default mount options: user_xattr acl
    3.如果没有开启
      临时开启:
        重新挂载跟分区,并加入acl权限
        mount -o remount,acl /
      永久开始:
        编辑开机挂载文件/etc/fstab
        将文件中的:
        UUID=546c4e25-7b06-468b-89a1-e66280c4ee98 /boot ext4 defaults 1 2
        修改为:
        UUID=546c4e25-7b06-468b-89a1-e66280c4ee98 /boot ext4 defaults,acl 1 2
        重新挂载根分区:
        mount -o remount /

3.设置ACL权限
  setfacl 选项 文件名
    -m 设定ACL权限
    -x 删除指定的ACL权限
    -b 删除所有的ACL权限
    -d 设定默认ACL权限
    -k 删除默认ACL权限
    -R 递归设定ACL权限

  设置用户权限:
    setfacl -m u:用户名:权限 文件

  设置组权限:
    setfacl -m g:组名称:权限 文件

  设置最大有效权限:
    setfacl -m m:权限 文件
    说明:
      acl权限中有个"mask"的选项,它就是ACL权限的最大权限,现在是rwx,当你设置某个用户或组的ACL权限时,要跟mask的权限“相与”之后产生的权限才是该用户的最终权限,也就是加入mask的最大权限是rx,但是你给st用户设置的是rwx权限,此时st用户它的权限只有rx的权限,因为与最大权限“相与”得出的结果就是rx

4.删除权限
  删除用户权限:
    setfacl -x u:用户名 文件名
  删除组权限:
    setfacl -x g:组名称 文件名
  删除整个权限:
    setfacl -b 文件名

5.设置默认权限和递归权限
  递归权限:
    setfacl -m u:用户名:权限 -R 文件
    说明:
      递归只对该目录下面现有的子文件或目录有用,对于该目录下面新添加的子文件或目录没用
  默认权限:
    setfacl -m d:u:用户名:权限 文件
    说明:
      默认权限只对该目录下面新建的文件或目录有效,对已经存在的子文件无效

试验:
准备环境:
  [root@localhost temp]# useradd student1
  [root@localhost temp]# useradd student2
  [root@localhost temp]# useradd visitor1
  [root@localhost temp]# passwd student1
  [root@localhost temp]# passwd student2
  [root@localhost temp]# passwd visitor1
  [root@localhost temp]# groupadd student_group
  [root@localhost temp]# groupadd other_student
  [root@localhost temp]# mkdir project
  [root@localhost temp]# chown root:student_group project/
  [root@localhost temp]# chmod 770 project/
  [root@localhost temp]# gpasswd -a student1 student_group
  [root@localhost temp]# gpasswd -a student2 student_group

  student1有权限:
  [student1@localhost ~]$ cd /xiaol/temp/project/
  [student1@localhost project]$ touch a.txt

  visitor1没有权限
  [visitor1@localhost ~]$ cd /xiaol/temp/project/
  -bash: cd: /xiaol/temp/project/: 权限不够

给visitor1设置权限:
  [root@localhost temp]# setfacl -m u:visitor1:rx project/

  查看权限:
  [root@localhost temp]# getfacl project/
  # file: project/  
  # owner: root
  # group: student_group
  user::rwx
  user:visitor1:r-x
  group::rwx
  mask::rwx
  other::---

  visitor1有权限了
  [visitor1@localhost ~]$ cd /xiaol/temp/project/
  [visitor1@localhost project]$

给other_student组设置权限:
  [root@localhost temp]# setfacl -m g:other_student:rx project/

  查看权限:
  [root@localhost temp]# getfacl project/
  # file: project/
  # owner: root
  # group: student_group
  user::rwx
  user:visitor1:r-x
  group::rwx
  group:other_student:r-x
  mask::rwx
  other::---

设置最大权限:
  [root@localhost temp]# setfacl -m m:rx project/

  查看权限
  [root@localhost temp]# getfacl project/
  # file: project/
  # owner: root
  # group: student_group
  user::rwx
  user:visitor1:r-x
  group::rwx #effective:r-x
  group:other_student:r-x
  mask::r-x
  other::---

删除权限:
  删除visitor1权限
  [root@localhost temp]# setfacl -x u:visitor1 project/

  删除other_student权限
  [root@localhost temp]# setfacl -x g:other_student project/

  查看权限:
  [root@localhost temp]# getfacl project/
  # file: project/
  # owner: root
  # group: student_group
  user::rwx
  group::rwx
  mask::rwx
  other::---

设置递归权限
  [root@localhost temp]# setfacl -m u:visitor1:rx -R project/

  进入project查看内部文件权限
  [root@localhost project]$ getfacl a.txt
  # file: a.txt
  # owner: student1
  # group: student1
  user::rw-
  user:visitor1:r-x
  group::rw-
  mask::rwx
  other::r--

  新建文件并查看权限
  [root@localhost project]# touch b.txt
  [root@localhost project]# getfacl b.txt
  # file: b.txt
  # owner: root
  # group: root
  user::rw-
  group::r--
  other::r--

设置默认权限
  [root@localhost temp]# setfacl -m d:u:visitor1:rx project/

  新建文件并查看权限
  [root@localhost project]# touch c.txt
  [root@localhost project]# getfacl c.txt
  # file: c.txt
  # owner: root
  # group: root
  user::rw-
  user:visitor1:r-x #effective:r--
  group::rwx #effective:rw-
  mask::rw-
  other::---

清理试验环境
  [root@localhost temp]# userdel -r student1
  [root@localhost temp]# userdel -r student2
  [root@localhost temp]# userdel -r visitor1
  [root@localhost temp]# groupdel student_group
  [root@localhost temp]# groupdel other_student
  [root@localhost temp]# rm -rf project/

Linux中权限管理之ACL权限的更多相关文章

  1. Linux系列教程(十六)——Linux权限管理之ACL权限

    通过前面的两篇博客我们介绍了Linux系统的用户管理,Linux用户和用户组管理之相关配置文件 讲解了用户管理的相关配置文件,包括用户信息文件/etc/passwd,用户密码文件/etc/shadow ...

  2. Linux权限管理之ACL权限

    注:转载自:https://www.cnblogs.com/ysocean/p/7801329.html 目录 1.什么是 ACL 权限? 2.查看分区 ACL 权限是否开启:dump2fs ①.查看 ...

  3. Linux权限管理:ACL 权限

    1.ACL 是什么 ACL的全称是 Access Control List (访问控制列表) ,一个针对文件/目录的访问控制列表.它在UGO权限管理的基础上为文件系统提供一个额外的.更灵活的权限管理机 ...

  4. linux备忘录-账号管理与ACL权限设定

    知识 账号管理中的一些文件结构 /etc/passwd 每一行的内容都为下面结构 账号名称:密码:UID:GID:用户信息说明:家目录:shell ---- UID ---- -- 0 -> 代 ...

  5. Linux 账号管理及ACL权限设置,PAM模块简介

    有效群组与初始群组: groups:有效与支持群组的观察 newgrp:有效群组的切换,后面接群组名称 在passwd文件中记录的GID就是默认的GID,就是初始群组 /etc/passwd文件结构 ...

  6. 【Linux】 Linux权限管理与特殊权限

    Linux权限管理 权限管理这方面,非常清楚地记得刚开始实习那会儿是仔细研究过的,不知道为什么没有笔记留痕..除了一些基本的知识点早就忘光了,无奈只好从头开始学习一遍.. ■ 基本权限知识 这部分实在 ...

  7. 鸟哥的linux私房菜——第十三章学习(Linux 帐号管理与 ACLL 权限设置)

    第十三章.Linux 帐号管理与 ACLL 权限设置 1.0).使用者识别码: UID 与 GID UID :User ID GID :group ID [root@study ~]# ll -d / ...

  8. Android权限管理之Permission权限机制及使用

    前言: 最近突然喜欢上一句诗:"宠辱不惊,看庭前花开花落:去留无意,望天空云卷云舒." 哈哈~,这个和今天的主题无关,最近只要不学习总觉得生活中少了点什么,所以想着围绕着最近面试过 ...

  9. 【Java EE 学习 75 上】【数据采集系统第七天】【二进制运算实现权限管理】【权限分析和设计】

    一.权限计算相关分析 1.如何存储权限 首先说一下权限保存的问题,一个系统中最多有多少权限呢?一个大的系统中可能有成百上千个权限需要管理.怎么保存这么多的权限?首先,我们使用一个数字中的一位保存一种权 ...

随机推荐

  1. STM32在程序运行过程中关闭定时器重新打开后定时器不工作的问题

    问题:数码管显示程序放在定时TIM2中断函数里面扫描,想要实现在关闭某一功能的时候数码管不显示. 刚开始的想法是开关关闭,关闭定时器时钟:开关打开,打开定时器时钟:(但实验证明再次打开开关时定时器2却 ...

  2. window安装rabbitmq

    Rabbit MQ 是建立在强大的Erlang OTP平台上,因此安装Rabbit MQ的前提是安装Erlang.通过下面两个连接可以下载安装最新的版本: 下载并安装Eralng OTP For Wi ...

  3. Lucene4.0 LogMergePolicy

    其特点是给定的段列表顺序归并,不像TieredMergePolicy那样按大小排序之后决定. norm = log(10),levelFloor=log(minMergeSize)/norm,对段列表 ...

  4. Django的自定义标签

    Django提供了自定义标签功能,可以方便常用方法的重复使用. 标签的本质就是函数,标签名就是函数名. 注意点: 1.需要到django.template对象. 2.register = templa ...

  5. 第八章 springboot + mybatis + 多数据源2(解决循环引用)

    解决了循环引用 1.application.properties #the first datasource jdbc.names:1,2 jdbc1.driverClassName = com.my ...

  6. iOS多线程(转)

    关于iOS多线程,你看我就够了 字数8596 阅读28558 评论74 喜欢313 在这篇文章中,我将为你整理一下 iOS 开发中几种多线程方案,以及其使用方法和注意事项.当然也会给出几种多线程的案例 ...

  7. 【LeetCode】 Rotate List 循环链表

    题目:rotate list 解法1: <span style="font-size:18px;">/**LeetCode Rotate List:Given a li ...

  8. 解决Bootstrap 试用手机端 布满全屏

    @media (max-width: 767px) { body{ margin: 0; padding: 0; } } @media (max-width: 970px) { body{ margi ...

  9. 第一百八十五节,jQuery,Ajax 表单插件

    jQuery,Ajax 表单插件 学习要点: 1.核心方法 2.option 参数 3.工具方法 传统的表单提交,需要多次跳转页面,极大的消耗资源也缺乏良好的用户体验.而这款 form.js 表单的 ...

  10. 目标检测之线段检测---lsd line segment detector

    (1)线段检测应用背景 (2)线段检测原理简介 (3)线段检测实例 a line segment detector (4)hough 变换和 lsd 的区别 --------------------- ...