Linux ACL基本概念及典型用法
ACL 是什么
ACL的全称是 Access Control List (访问控制列表) ,一个针对文件/目录的访问控制列表。它在UGO权限管理的基础上为文件系统提供一个额外的、更灵活的权限管理机制。它被设计为UNIX文件权限管理的一个补充。
ACL允许你给任何的用户或用户组设置任何文件/目录的访问权限。
ACL有什么用
既然是作为UGO权限管理的补充,ACL自然要有UGO办不到或者很难办到的本事,例如:
1.可以针对用户来设置权限
2.可以针对用户组来设置权限
3.子文件/目录继承父目录的权限
检查是否支持ACL
ACL需要Linux内核和文件系统的配合才能工作,当前我们能见到的大多数Linux发行版本默认都是支持的。但最好还是能够先检查一下:
sudo tune2fs -l /dev/sda1 |grep “Default mount options:” Default mount options: user_xattr acl
我们能够看到默认情况下(Default mount options:)已经加入 acl 支持了。
如何设置ACL
我们可以使用setfacl和getfacl命令来设置或观察文件/目录的acl权限。
setfacl
参数不多,直接列出来了:
setfacl [-bkRd] [{-m|-x} acl参数] 文件/目录名 -m :配置后面的 acl 参数给文件/目录使用,不可与 -x 合用; -x :删除后续的 acl 参数,不可与 -m 合用; -b :移除所有的 ACL 配置参数; -k :移除默认的 ACL 参数; -R :递归配置 acl; -d :配置“默认 acl 参数”,只对目录有效,在该目录新建的数据会引用此默认值;
getfacl
getfacl 文件/目录名
实例
针对用户来设置权限
先创建一个测试文件test,然后查看其默认的权限:
touch test ll test -rw-r--r-- 1 root root 0 May 28 09:04 test getfacl test # file: test # owner: root # group: root user::rw- group::r-- other::r—
给apache用户设置读写执行test文件的权限:
setfacl –m u:apache:rwx test
查看test文件属性的变化:
ll test -rw-rwxr--+ 1 root root 0 May 28 09:04 test
权限部分多个了 “+”, 并且与原来(644)也不一样了。
查看ACL权限的变化:
getfacl test ... user:apache:rwx ... mask::rwx ...
和设置前相比多了user:apache:rwx和 mask::rwx,此时用户apache已经拥有了读写执行test文件的权限。
针对用户组来设置权限
和针对用户的设置几乎一样,只是把小写的u换成小写的g就行了。
子文件/目录继承父目录的权限
这是一个很棒的例子,它能让我们创建的子文件或者子文件夹继承父文件夹的权限设置!
mkdir mydir ll -d mydir drwxr-xr-x 2 root root 4096 May 28 09:35 mydir setfacl –m d:u:apache:rwx mydir
注意参数 d 在这里起到了决定性的作用。
查看下属性的变化:
getfacl mydir ... default:user::rwx default:user:apache:rwx default:group::r-x default:mask::rwx default:other::r-x
多了些 default开头的项,在mydir下创建一个新文件试试:
touch mydir/abc getfacl mydir/abc ... user:apache:rwx #effective:rw- group::r-x #effective:r-- mask::rw- ...
OK, 看上去还不赖,默认情况下apache用户是可以对这个文件进行读写执行操作的。
这里只是简介的介绍了ACL的概念和一些典型的用法,更多的使用方式请参考帮助文档。
相关文章
- 这篇文章主要介绍了Linux中用于更改访问控制的chacl命令,某些方面来说chacl命令的功能比chmod命令更加强大,需要的朋友可以参考下2016-01-22
- 通过重启oracle数据库进行处理,而重启oracle数据库的方法有好多种,可登陆数据库进行操作,也可在终端操作,下面为大家一一介绍下2015-06-18
- oracle数据库能够事项分布式处理功能,那么Linux服务器要如何启动oracle数据库呢?下面以图文的形式为大家介绍下Linux使用命令启动oracle数据库的步骤2015-01-14
如何在Linux下设置访问控制列表(ACL)来控制用户的权限
Linux下的访问控制列表(ACL)可以做到不同用户对同一文件有不同的权限,那么具体要如何操作呢?下面以图文的形式为大家介绍下如何在Linux下设置访问控制列表来控制用户的权2014-12-12Linux系统配置 Linux访问控制列表(ACL)的权限控制方法
这篇文章主要为大家介绍了Linux有一种被称为访问控制列表(ACL)的权限控制方法,如果你不确定你的文件系统是否支持ACL,请参考下文有Linux配置访问控制列表(ACL)过程,需要2014-10-12- 这篇文章主要介绍了Linux中限制用户访问权限的3种方法,着重讲解了Linux ACL的使用,需要的朋友可以参考下2014-04-26
RedHat Linux5.5下Oracle 11g安装图解教程
Linux下安装Oracle系统最好是1G内存,2G的swap空间,硬盘至少需要4.5G空间2013-07-28- 这系列文章主要是一刀写的linux相关学习资料,这篇文章主要介绍了linux下的学习账号管理与ACL权限设置相关知识,需要的朋友可以参考下2013-04-15
linux oracle 乱码 Linux环境Oracle显示乱码解决犯法
故障现象:所有出现汉字的地方,都以?替代,或者是直接乱码,本文介绍详细解决方法,需要的朋友可以参考下2012-12-06
最新评论