1.ACL简介

2.前期准备

3.ACL的基本操作:添加和修改

4.ACL的其他功能:删除和覆盖

5.目录的默认ACL

6.备份和恢复ACL

7.结束语

1.ACL简介

用户权限管理始终是Linux系统管理中最重要的环节。大家对Linux/Unix的UGO权限管理方式一定不陌生,还有最常用的chmod命令。为了实现一些比较复杂的权限管理,往往不得不创建很多的组,并加以详细的记录和区分。有一种方法可以实现灵活的权限管理(文件的额外赋权机制)除了文件的所有者,所属组和其他人,可以对更多的用户设置权限,这就是访问控制列表(Access Control List)。

2.前期准备

支持ACL需要内核和文件系统的支持。现在2.6内核以上版本配合EXT3/EXT4, JFS, XFS, ReiserFS等文件系统都是可以支持ACL。下面我们使用CentOS6.8和Ext4文件系统开始对Linux的ACL的体验。

首先创建一个1M的空白文件:

[root@anonymous mnt]#dd if=/dev/zero of=testacl bs=1024 count=1000

1000+0 records in

1000+0 records out

1024000 bytes (1.0 MB) copied, 0.00832275 s, 123 MB/s

[root@anonymous mnt]#du -sh testacl

1000K testacl

和一个loop设备联系在一起:

[root@anonymous mnt]#losetup /dev/loop1 testacl

创建一个ext4文件系统:

[root@anonymous mnt]#mkfs.ext4 /dev/loop1

mke2fs 1.41.12 (17-May-2010)

Discarding device blocks: done

Filesystem label=

OS type: Linux

Block size=1024 (log=0)

Fragment size=1024 (log=0)

Stride=0 blocks, Stripe width=0 blocks

128 inodes, 1000 blocks

50 blocks (5.00%) reserved for the super user

First data block=1

Maximum filesystem blocks=1048576

1 block group

8192 blocks per group, 8192 fragments per group

128 inodes per group

Writing inode tables: done

Filesystem too small for a journal

Writing superblocks and filesystem accounting information: done

This filesystem will be automatically checked every 37 mounts or

180 days, whichever comes first.  Use tune2fs -c or -i to override.

挂载新建的文件系统:

[root@anonymous mnt]#mount -o rw,acl /dev/loop1 /mnt/testdir

[root@anonymous mnt]#cd testdir/

[root@anonymous testdir]#ls

lost+found

现在我已经得到了一个小型的文件系统。而且是支持ACL的。并且即使彻底损坏也不会影响硬盘上其他有价值的数据。因此可以开始我们的ACL体验了。

3.ACL的基本操作:添加和修改

首先新建一个文件作为实施ACL的对象:

[root@anonymous testdir]#touch file1

[root@anonymous testdir]#ll

total 13

-rw-r–r–. 1 root root     0 Mar 11 15:48 file1

drwx——. 2 root root 12288 Mar 11 15:42 lost+found

然后看一下这个文件缺省的ACL,这时这个文件除了通常的UGO的权限之外,并没有ACL:

[root@anonymous testdir]#getfacl file1

# file: file1

# owner: root

# group: root

user::rw-

group::r–

other::r–

下面添加几个用户和组,待会儿我将使用ACL赋予它们不同的权限:

[root@anonymous testdir]#groupadd grp1

[root@anonymous testdir]#useradd user1

[root@anonymous testdir]#useradd user2

[root@anonymous testdir]#usermod -G grp1 user1

我们将用户切换到user1,发现并不能在此目录下创建文件:

[root@anonymous testdir]#su user1

[user1@anonymous testdir]$echo “test” >> file1

bash: file1: Permission denied

失败了,由于file1并不允许除了root以外的用户写,现在我们通过修改file1的ACL赋予user1足够的权限:

[root@anonymous testdir]#setfacl -m u:user1:rw file1

[root@anonymous testdir]#su user1

[user1@anonymous testdir]$echo “test” >> file1

[user1@anonymous testdir]$cat file1

test

修改成功了,用户user1可以对file1做读写操作了。再次查看file1的ACL:

[user1@anonymous testdir]$getfacl file1

# file: file1

# owner: root

# group: root

user::rw-

user:user1:rw-

group::r–

mask::rw-

other::r–

ls一下:

[root@anonymous testdir]#ls -l file1

-rw-rw-r–+ 1 root root 5 Mar 11 15:59 file1

可以看到一个”+”,就在通常我们看到的权限位的旁边。这说明了file1设置了ACL, 接下来我们修改一下grp1的权限,同时给tgrp1这个组以读的权限:

[root@anonymous testdir]#setfacl -m u:user1:rwx,g:grp1:r file1

[root@anonymous testdir]#getfacl file1

# file: file1

# owner: root

# group: root

user::rw-

user:user1:rwx

group::r–

group:grp1:r–

mask::rwx

other::r–

这个时候user1已经有了执行的权限,而grp1这个组也获得了读取文件内容的权限。有人可能已经注意到了两个问题:首先,file1的组权限从r–变成了rw-。其次,mask是什么?为什么也变化了呢?我们先从mask说起。如果说ACL的优先级高于UGO,那么mask就是最后一道防线。它决定了一个用户或组能够得到的最大的权限。这样我们在不破坏已有ACL的定义的基础上,可以临时提高或是降低安全级别:

[root@anonymous testdir]#setfacl -m mask::r file1

[root@anonymous testdir]#getfacl file1

# file: file1

# owner: root

# group: root

user::rw-

user:user1:rwx   #effective:r–

group::r–

group:grp1:r–

mask::r–

other::r–

[root@anonymous testdir]#ls -l file1

-rw-r–r–+ 1 root root 5 Mar 11 15:59 file1

在user1对应的ACL项的后边出现了effective的字样,这是实际user1得到的权限。Mask只对其他用户和组的权限有影响,对owner和other的权限是没有任何影响的。执行ls的结果也显示UGO的设置也有了对应的变化。因为在使用了ACL的情况下,group的权限显示的就是当前的mask。

4.ACL的其他功能:删除和覆盖

如何删除已有的ACL项呢?

[root@anonymous testdir]#setfacl -x g:grp1 file1

[root@anonymous testdir]#getfacl file1

# file: file1

# owner: root

# group: root

user::rw-

user:user1:rwx

group::r–

mask::rwx

other::r–

我们看到grp1的权限已经被去掉了。如果需要去掉所有的ACL可以用-b选项。所有的ACL项都会被去掉。

[root@anonymous testdir]#setfacl -b  file1

[root@anonymous testdir]#getfacl file1

# file: file1

# owner: root

# group: root

user::rw-

group::r–

other::r–

我们可以用–set 设置一些新的ACL项,并把原有的ACL项全部都覆盖掉。和-m不同,-m选项只是修改已有的配置或是新增加一些。–set选项会把原有的ACL项都删除,用新的替代,需要注意的是一定要包含UGO的设置,不能象-m一样只是添加ACL就可以了。比如下边这一段:

[root@anonymous testdir]#setfacl –set u::rw,u:user1:rw,g::r,o::- file1

[root@anonymous testdir]#getfacl file1

# file: file1

# owner: root

# group: root

user::rw-

user:user1:rw-

group::r–

mask::rw-

other::—

o::-是另一个需要注意的地方。其实完整的写法是other::—,正如u::rw的完整写法是user::rw-。通常我们可以把”-“省略,但是当权限位只包含”-“时,必须至少保留一个。如果写成了o::,就会出现错误。

5.目录的默认ACL

如果我们希望在一个目录中新建的文件和目录都使用同一个预定的ACL,那么我们可以使用默认(Default) ACL。在对一个目录设置了默认的ACL以后,每个在目录中创建的文件都会自动继承目录的默认ACL作为自己的ACL。用setfacl的-d选项就可以做到这一点:

[root@anonymous mnt]#setfacl -d –set g:grp1:rwx testdir

[root@anonymous mnt]#getfacl testdir

# file: testdir

# owner: root

# group: root

user::rwx

group::r-x

other::r-x

default:user::rwx

default:group::r-x

default:group:grp1:rwx

default:mask::rwx

default:other::r-x

可以看到默认ACL已经被设置了。建立一个文件试试:

[root@anonymous mnt]#touch testdir/file2

[root@anonymous mnt]#getfacl testdir/file2

# file: testdir/file2

# owner: root

# group: root

user::rw-

group::r-x   #effective:r–

group:grp1:rwx   #effective:rw-

mask::rw-

other::r–

file2自动继承了testdir对grp1设置的ACL。只是由于mask的存在使得grp1只能获得rw-权限。

6.备份和恢复ACL

主要的文件操作命令cp和mv都支持ACL,只是cp命令需要加上-p参数。但是tar等常见的备份工具是不会保留目录和文件的ACL信息的。如果希望备份和恢复带有ACL的文件和目录,那么可以先把ACL备份到一个文件里。以后用–restore选项来回复这个文件中保存的ACL信息:

[root@anonymous mnt]#getfacl -R testdir > test.acl

[root@anonymous mnt]#ls -l test.acl

-rw-r–r–. 1 root root 649 Mar 11 16:29 test.acl

我们用-b选项删除所有的ACL数据,来模拟从备份中回复的文件和目录:

[root@anonymous mnt]#setfacl -R -b testdir

[root@anonymous mnt]#getfacl -R testdir

# file: testdir

# owner: root

# group: root

user::rwx

group::r-x

other::r-x

# file: testdir/file1

# owner: root

# group: root

user::rw-

group::r–

other::—

现在我们从test.acl中恢复被删除的ACL信息:

[root@anonymous mnt]#setfacl –restore test.acl

[root@anonymous mnt]#getfacl -R testdir

# file: testdir

# owner: root

# group: root

user::rwx

group::r-x

other::r-x

default:user::rwx

default:group::r-x

default:group:grp1:rwx

default:mask::rwx

default:other::r-x

# file: testdir/file2

# owner: root

# group: root

user::rw-

group::r-x    #effective:r–

group:grp1:rwx   #effective:rw-

mask::rw-

other::r–

7.结束语

刚开始学习ACL的时候感觉非常的痛苦,因为对原理及概念的理解有误,造成了很大的困惑,好在从网上参考了很多资料以及下了很大功夫将其消化吸收。学习Linux唯有多练多记才能达到自己所预想的目标。

8.参考资料

http://www.bestbits.at/richacl/?cm_mc_uid=29552251466514872527098&cm_mc_sid_50200000=1489219374

http://www.cnblogs.com/dkblog/archive/2011/10/21/2219765.html

原创文章,作者:mrlapulga,如若转载,请注明出处:http://www.178linux.com/70972

linux查看目录acl权限,ACL权限详解相关推荐

  1. linux查看根目录使用率,Linux 查看空间使用情况的实例详解

    Linux 查看空间使用情况的实例详解 在日常的Linux巡检中,我们会遇到文件系统目录使用空间很高的情况,例如如下利用"df -h "查看到根目录空间使用超过80%.而我们仅仅知 ...

  2. linux查看空间使用情况并且清除,科技常识:Linux 查看空间使用情况的实例详解...

    今天小编跟大家讲解下有关Linux 查看空间使用情况的实例详解 ,相信小伙伴们对这个话题应该也很关注吧,小编也收集到了有关Linux 查看空间使用情况的实例详解 的相关资料,希望小伙伴会喜欢也能够帮助 ...

  3. linux查看进程详细信息top,linux查看系统进程信息命令 px,top详解

    linux查看系统进程信息命令 px,top详解 发表于:2011-03-10来源:作者:点击数: linux查看系统进程信息命令 px,top详解 软件测试 ps ax命令是显示一个当前系统进程的列 ...

  4. Linux查看CPU和内存使用情况详解

    在系统维护的过程中,随时可能有需要查看 CPU 使用率,并根据相应信息分析系统状况的需要.在 CentOS 中, 可以通过 top 命令来查看 CPU 使用状况.运行 top 命令后,CPU 使用状态 ...

  5. Linux查看客户端NTP会话,linux_NTP服务详解

    一.安装ntp服务 yum -y install ntp 二.配置ntp服务器端 restrict 0.0.0.0 mask 0.0.0.0  nomodify notrap  noquery res ...

  6. 9个Linux 查看系统硬件信息命令(实例详解)

    在Linux下,我们精要遇到需要查看系统的硬件信息, 这里我罗列了查看系统硬件信息的实用命令,并做了分类,实例解说. 执行环境:ubuntu 16.04 1. cpu lscpu命令,查看的是cpu的 ...

  7. Linux、ubuntu系统下查看显卡型号、显卡信息详解

    本文将介绍Linux系统下查看显卡硬件信息内容如下: 如何在ubuntu系统中查看显卡型号.(其他文章大多只介绍了命令而未介绍如何对应显卡型号) 在ubuntu系统中显卡详细信息,以及所代表的含义. ...

  8. linux系统电脑的权限设置,Linux下的文件权限设置修改详解linux操作系统 -电脑资料...

    在linux中更改所属用户组是使用chgrp,更改文件拥有者, chown,更改9个属性, chmod这三种常用的问题,在linxu中这三个命令就是对文件目录权限的控制命令了,下面我来介绍它们的用法与 ...

  9. linux中groupadd命令详解,linux groupadd命令权限群组详解

    首页 > Linux教程 > 常用命令 > group/user 群组和用户 linux groupadd命令权限群组详解 linux中groupadd命令用于创建一个新的工作组,新 ...

  10. vsftp建立虚拟用户不同目录分配不同权限操作步骤详解

    这篇文章主要介绍了vsftp建立虚拟用户不同目录分配不同权限操作步骤详解,大家参考设置自己的FTP服务器吧vsftpd服务器同时支持匿名用户.本地用户和虚拟用户三类用户账号,使用虚拟用户账号可以提供集 ...

最新文章

  1. 使用Hyperledger Ursa简化区块链安全性
  2. 使用手机企业微信创建自己的企业(公司)
  3. 2021移动游戏生命周期研究玩家洞察报告
  4. javascript 西瓜一期 12 八进制的数数进位解析
  5. 点滴积累【JS】---JS小功能(JS实现多物体缓冲运动)
  6. excel冻结标题栏,让标题栏不滚动的方法
  7. 数据库SQL Server DAC 导入导出数据到SQL Azure问题
  8. 国内主要的ubuntu 源
  9. MySQL登录命令详解
  10. mysql创建视图并加注释_在mysql中为视图创建注释
  11. 前端怎么画三角形_css如何画三角形?
  12. TypeScript 学习笔记(四)--- 泛型(Generics)
  13. Steam游戏—底特律:化身成人,回家章节中女主角上二楼打扫卫生,按L Shift开窗按不动怎么办
  14. 机器学习基础——贝叶斯
  15. 带着问题,再读ijkplayer源码
  16. linux 加路由 网络不可达,无法添加静态路由:SIOADDRT:网络不可达
  17. 简简单单使用Github
  18. matlab 牛顿法 初值,非线性方程的数值解法:牛顿法及牛顿下山法(含Matlab程序)...
  19. 随机字符串解决大问题之腾讯网如何实现手机扫描二维码登录qq功能的
  20. MTK工具sigma的使用

热门文章

  1. P2517 [HAOI2010]订货 (最小费用最大流)
  2. 编写itoa函数,该函数为itoi函数的逆函数。将一个整数转化为字符串的形式。
  3. C++如何测试dll_Win7系统丢失libcurl.dll怎么办
  4. java replaceall正则_String.replaceAll方法详析(正则妙用)
  5. Python17个常用内置模块总结 (运维)
  6. 【每日一题】打卡 11
  7. 使用pyecharts从excel取数建立堆积柱状图
  8. 计算机总线接口规范协议,MIL-STD-1553B航空总线协议开发手册
  9. STM32F103_TIM3输出PWM波实现全彩呼吸灯
  10. STM32 BSRR BRR ODR 寄存器解析