ACL权限设置命令setfacl和getfacl命令(6)

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

需要注意的是,每次修改或添加某个用户或组的ACL项的时候,mask都会随之修改以使最新的修改能够真正生效。所以如果需要一个比较严格的mask的话,可能需要每次都重新设置一下mask。

 3. ACL的其他功能:删除和覆盖  何删除已有的ACL项 [root@FC3-vm mnt]# setfacl -x g:testg1 file1 [root@FC3-vm mnt]# getfacl file1 # file: file1 # owner: root # group: root user::rw- user:testu1:rwx group::r-- mask::rwx other::r--

我们看到testg1的权限已经被去掉了。

 去掉所有的ACL可以用-b选项。所有的ACL项都会被去掉。 [root@FC3-vm mnt]# setfacl -b file1 [root@FC3-vm mnt]# getfacl file1 # file: file1 # owner: root # group: root user::rw- group::r-- other::r--

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

 --set设置新acl项  [root@FC3-vm mnt]setfacl --set u::rw,u:testu1:rw,g::r,o::- file1 [root@FC3-vm mnt]getfacl file1filefile1ownerrootgrouproot user::rw- user:testu1:rw- group::r-- mask::rw- other::---

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

 对目录下的所有子目录都设置同样的ACL,可以使用-R参数: [root@FC3-vm mnt]setfacl --set u::rw,u:testu1:rw,g::r,o::- dir1  从一个文件来读入ACL,并修改当前的文件的ACL,可以用-M参数: [root@FC3-vm mnt]cat test.acl user:testu1:rw- user:testu2:rw- group:testg1:r-- group:testg2:r-- mask::rw- other::---  4.目录的默认ACL

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:https://www.heiqu.com/11954.html