体验- 目录的默认ACL<?xml:namespace prefix = o ns = "urn:schemas-microsoft-com:office:office" />

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

[root@FC3-vm mnt]# setfacl --set u::rw,u:testu1:rw,g::r,o::- dir1

[root@FC3-vm mnt]# cat test.acl

user:testu1:rw-

user:testu2:rw-

group:testg1:r--

group:testg2:r--

mask::rw-

other::---

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

file1自动继承了dir1testg1设置的ACL。只是由于mask的存在使得testg1只能获得rw-权限。

体验- 备份和恢复ACL

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

[root@FC3-vm mnt]# setfacl -d --set g:testg1:rwx dir1

[root@FC3-vm mnt]# getfacl dir1

# file: dir1

# owner: root

# group: root

user::rwx

group::r-x

other::r-x

default:user::rwx

default:group::r-x

default:group:testg1:rwx

default:mask::rwx

default:other::r-x

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

[root@FC3-vm mnt]# getfacl -R dir1 > dir1.acl

[root@FC3-vm mnt]# ls -l dir1.acl

total 16

-rw-r--r--  1 root root   310 Dec 12 21:10 dir1.acl

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

[root@FC3-vm mnt]# setfacl -R -b dir1

[root@FC3-vm mnt]# getfacl -R dir1

# file: dir1

# owner: root

# group: root

user::rwx

group::r-x

other::r-x

# file: dir1/file1

# owner: root

# group: root

user::rw-

group::r--

other::r--

[root@FC3-vm mnt]# setfacl --restore dir1.acl

[root@FC3-vm mnt]# getfacl -R dir1

# file: dir1

# owner: root

# group: root

user::rwx

group::r-x

other::r-x

default:user::rwx

default:group::r-x

default:group:testg1:rwx

default:mask::rwx

default:other::r-x

# file: dir1/file1

# owner: root

# group: root

user::rw-

group::r-x                      #effective:r--

group:testg1:rwx                #effective:rw-

mask::rw-

other::r--

ACL 的引入使得大规模的复杂权限管理可以很容易的在 Linux 上实现。对于 /home 这样存放大量用户文件的分区,可以做到更有效的管理。但是我们也看到在备份工具等方面的欠缺,好在 FC2 中已经开始包含了 star 这样的支持 ACL 的备份工具,虽然还是 alpha 版。

在单个文件的 ACL 条目的数量上,不同的文件系统有不同的限制。Ext2 和 Ext3 只能支持每个文件 25 个 ACL 条目。ReiserFS 和 JFS 可以支持超过 8,000 个条目。这个方面 Ext* 文件系统还需要加强。

无论多么复杂的系统中,文件系统的权限管理都是最基础的内容。而 Linux 对 ACL的支持,无疑是一把管理海量用户系统的利器,对 Linux 在大规模的企业级应用中更方便的发挥更大的作用添了一把火。