如果你在谈论一个挂载的文件系统,我不知道有什么内在的方法来判断 ACL 是否可行。请注意“是否支持 ACL?” 不是一个非常精确的问题,因为有几种类型的 ACL(Solaris/Linux/not-POSIX-after-all、NFSv4、OSX 等)。请注意,这getfacl作为测试是无用的,因为如果仅此而已,它会很高兴地报告 Unix 权限:您需要尝试设置ACL 进行测试。
仍然在挂载的文件系统上,您可以检查acl挂载选项中是否存在(您可以在 中找到/proc/mount)。请注意,这还不够:您还需要考虑内核版本和文件系统类型。无论挂载选项如何,某些文件系统类型始终具有可用的 ACL;tmpfs、xfs 和 zfs 就是这种情况。除非明确排除,否则某些文件系统具有 ACL;从内核 2.6.39 开始,ext4就是这种情况。
如果您使用 ext2/3/4 或 btrfs,则应默认启用 acl。
检查:
tune2fs -l /dev/sdXY | grep "Default mount options:"
如果它不在输出中,请执行以下操作:
tune2fs -o acl /dev/sdXY
要了解 ACL 是否可用,您可以:
检查当前内核版本和文件系统:
uname -r
df -T或mount | grep root
最近的发行版默认包含 ACL 挂载选项(自内核 2.6 起)。因此,不必在 /etc/fstab (或类似文件)中重新定义它。相关文件系统的非详尽列表: ext3、ext4、tmpfs、xfs 和 zfs 。
如果您有较旧的设置,那么您可能必须重新编译内核和/或在/etc/fstab.
fstab 示例: /dev/root / ext4 acl,errors=remount-ro 0 1
查找现有的 ACL 设置(“通常”配置位置位于 /boot 上):
sudo mount | grep -i acl #optionnal
cat /boot/config* | grep _ACL
根据系统的不同,您可以在其中找到设置/proc。以下是从 .gz 存档中提取配置然后搜索 acl 设置的方法:
cat /proc/config.gz | gunzip > running.config && grep -i 'acl' running.config
cat running.config | grep _ACL
您应该看到类似以下内容:
CONFIG_EXT3_FS_POSIX_ACL=y
CONFIG_EXT2_FS_POSIX_ACL=y
CONFIG_XFS_POSIX_ACL=y
对于文件系统,您可以尝试使用以下方式获取更多信息:(
sudo tune2fs -l /xxx/xxx| grep 'Default mount options:'
将 xxx/xxx 替换为您的文件系统)
--
可以在以下位置找到有用的信息:
- superuser.com、
- serverfault、
- bencane.com、
- wiki.archlinux.org