Linux下 FACL详解
1. 什么是ACL
ACL即Access Control List 主要的目的是提供传统的owner,group,others的read,write,execute权限之外的具体权限设置
ACL可以针对单一用户、单一文件或目录来进行r,w,x的权限控制,对于需要特殊权限的使用状况有一定帮助。
如,某一个文件,不让单一的某个用户访问。或者只让某个用户访问
2. ACL的使用
ACL使用两个命令来对其进行操作
getfacl:查看某个文件/目录的ACL设置
setfacl:设置某个文件/目录的ACL设置
2.1 getfacl的使用
getfacl:查看某个文件/目录的ACL设置
getfacl + 文件或目录的路径
2.2 setfacl的使用
setfacl:设置某个文件/目录的ACL设置
-m:设置后续acl参数 (设定额外的ACL)
-x:删除后续acl参数 (删除额外的ACL)
-b:删除全部的acl参数
-k:删除默认的acl参数
-R:递归设置acl,包括子目录
-d:设置默认acl
3. 为文件配置ACL
问题:
oldboy.txt 文件 希望oldboy用户对这个文件有读写权限
www用户只能进行读取 其他用户没有权限
oldboy.txt
3.1 创建环境
首先创建三个测试用户 [root@oldboyedu-50 oldboy]# useradd oldboy [root@oldboyedu-50 oldboy]# useradd www [root@oldboyedu-50 oldboy]# useradd LH [root@oldboyedu-50 oldboy]# touch oldboy.txt 创建测试文件 [root@oldboyedu-50 oldboy]# ll oldboy.txt 查看默认权限 -rw-r--r-- 1 root root 0 Aug 8 19:42 oldboy.txt [root@oldboyedu-50 oldboy]# getfacl oldboy.txt 查看acl权限 # file: oldboy.txt # owner: root # group: root user::rw- group::r-- other::r--
3.2 配置 其他用户没有权限
chmod 640 oldboy.txt 达成其他用户没有权限 LH此处代表的是其他用户 所以用LH用户测试
[root@oldboyedu-50 oldboy]# chmod 640 oldboy.txt 先将权限改为 其他用户都没有权限 [root@oldboyedu-50 oldboy]# ll oldboy.txt 检查 已修改 -rw-r----- 1 root root 0 Aug 8 19:42 oldboy.txt 登录LH用户测试 [LH@oldboyedu-50 ~]$ ll /oldboy/ LH用户看不到oldboy.txt这个文件 total 20 -rw-r--r-- 1 root root 66 Aug 8 17:09 ett.txt -rw-r-----. 1 root root 292 Aug 6 13:51 id.txt -rw-r--r-- 1 root root 27 Aug 6 13:37 info.txt -rw-r--r-- 1 root root 24 Aug 6 12:51 nginx.log -rw-r----- 1 root root 0 Aug 8 19:42 oldboy.txt d-wxr-xr-x 2 oldboy oldboy 4096 Aug 7 13:01 test
3.3 配置oldboy用户
setfacl -m u:oldboy:rw oldboy.txt
-m 表示 配置额外的ACL u:oldboy 表示为oldboy用户配置 :rw 表示配置rw(读写权限)
-m u:oldboy:rw 所以连起来 此处表示 额外为oldboy用户赋予rw权限 配置完后可以getfacl查看
退出到root用户 修改oldboy的权限 [root@oldboyedu-50 oldboy]# setfacl -m u:oldboy:rw oldboy.txt [root@oldboyedu-50 oldboy]# getfacl oldboy.txt # file: oldboy.txt # owner: root # group: root user::rw- user:oldboy:rw- group::r-- mask::rw- other::--- 进入到oldboy用户测试 [oldboy@oldboyedu-50 oldboy]$ vim oldboy.txt 可以读取 可以修改
3.4 配置www用户
继续 退出到root用户 修改www的权限 [root@oldboyedu-50 oldboy]# setfacl -m u:www:r oldboy.txt 修改www用户的权限 使其可读 [root@oldboyedu-50 oldboy]# getfacl oldboy.txt # file: oldboy.txt # owner: root # group: root user::rw- user:oldboy:rw- user:www:r-- group::r-- mask::rw- other::--- 进入到www权限 [www@oldboyedu-50 ~]$ vim /oldboy/oldboy.txt 使用vim 进入编辑模式 底部会显示红字Warning: Changing a readonly file (要修改一个只读文件) 到此处全部完成
4. ACL常见问题
4.1 MASK值的问题
如果getfacl查看文件有MASK值 那么ls查看位于用户组的权限代表的就是mask值 而不再是group用户组了
我们举个例子
新建一个文件 linux.txt 查看下权限 新文件默认权限为644
[root@oldboyedu-50 oldboy]# touch linux.txt [root@oldboyedu-50 oldboy]# echo "123" >> linux.txt [root@oldboyedu-50 oldboy]# cat linux.txt 123 [root@oldboyedu-50 oldboy]# ll linux.txt ll查看文件属性信息 -rw-r--r-- 1 root root 0 Aug 8 21:49 linux.txt [root@oldboyedu-50 oldboy]# getfacl linux.txt getfacl查看下linux,txt的默认权限 # file: linux.txt # owner: root # group: root user::rw- group::r-- other::r--
模拟一下环境
我们把linux,txt所属的用户组换成LH (LH的用户组包含用户LH)
方便等下测试
[root@oldboyedu-50 oldboy]# chown .LH linux.txt [root@oldboyedu-50 oldboy]# ll linux.txt -rw-r--r-- 1 root LH 0 Aug 8 21:49 linux.txt [root@oldboyedu-50 oldboy]# getfacl linux.txt # file: linux.txt # owner: root # group: LH user::rw- group::r-- other::r--
修改下权限 给oldboy用户加上一个单独的rwx权限
[root@oldboyedu-50 oldboy]# setfacl -m u:oldboy:rwx linux.txt 增加额外的权限 [root@oldboyedu-50 oldboy]# getfacl linux.txt 查看权限 # file: linux.txt # owner: root # group: LH user::rw- user:oldboy:rwx group::r-- mask::rwx 多出了一个MASK other::r-- [root@oldboyedu-50 oldboy]# ll linux.txt -rw-rwxr--+ 1 root LH 0 Aug 8 21:49 linux.txt ll查看文件属性 用户组所属位置的权限也变成了rwx
我们测试一下现在用户组的权限到底是一开始的r 还是现在的rwx
用LH用户测试 现在用户组是LH的
[LH@oldboyedu-50 oldboy]$ ll linux.txt 先查看下权限 -rw-rwx---+ 1 root LH 4 Aug 9 08:33 linux.txt [LH@oldboyedu-50 oldboy]$ cat linux.txt 可以读取 因为用户组默认有r权限 123 [LH@oldboyedu-50 oldboy]$ /oldboy/linux.txt 无法执行 -bash: /oldboy/linux.txt: Permission denied [LH@oldboyedu-50 oldboy]$ echo " >> linux.txt 无法修改 -bash: linux.txt: Permission denied
所以测试可以发现 虽然用户组位置权限变成了rwx但是用户组实际的权限并没有变 还是原来的r
所以getfacl查看文件有MASK值 那么ls查看位于用户组的权限代表的就是mask值 而不再是group用户组了
也可以理解为修改了ACL后 ls查看的文件权限就不是全部显示的了
更改了ACL 权限应该以getfacl查看的为准。
Linux下 FACL详解的更多相关文章
- Linux 下crontab 详解转
http://yaksayoo.blog.51cto.com/510938/162062 Linux计划任务工具cron用法详解 linux下大名鼎鼎的计划任务工具crontab的使用介绍baidu. ...
- 12 Linux下crontab详解
1. 概述: crond是linux下用来周期性的执行某种任务或等待处理某些事件的一个守护进程,与windows下的计划任务类似,当安装完成操作系统后,默认会安装此服务工具,并且会自动启动crond进 ...
- 【转载】Linux下makefile详解--跟我一起写 Makefile
概述 —— 什么是makefile?或许很多Winodws的程序员都不知道这个东西,因为那些Windows的IDE都为你做了这个工作,但我觉得要作一个好的和professional的程序员,makef ...
- Linux下crontab详解
1.crond介绍 crond是Linux下的任务调度命令,让系统定期执行指定程序.crond命令每分钟都会检查是否有要执行的工作,若有要执行的程序便会自动执行. linux下任务调度工作主要分两类: ...
- Linux下lampp详解 (转)
重要文件解释: ProFTPD:一个Unix平台上或是类Unix平台上(如Linux, FreeBSD等)的FTP服务器程序,它是在自由软件基金会的版权声明(GPL)下开发.发布的免费软件,可以随意修 ...
- LINUX下 Udev详解
如果你使用Linux比较长时间了,那你就知道,在对待设备文件这块,Linux改变了几次策略.在Linux早期,设备文件仅仅是是一些带有适当的属性集的普通文件,它由mknod命令创建,文件存放在/dev ...
- Linux下Samba详解及安装配置
1.简介 2.安装配置 3.在windows和linux系统上验证 一.简介 早期网络想要在不同主机之间共享文件大多要用FTP协议来传输,但FTP协议仅能做到传输文件却不能直接修改对方主机的资料数据, ...
- Linux下mknod详解
mknod - make block or character special filesmknod [OPTION]... NAME TYPE [MAJOR MINOR] option 有用的就是 ...
- Linux 下DNS详解
配置之前先了解一下bind DNS服务器软件:BIND是一种开源的DNS(Domain Name System)协议的实现,包含对域名的查询和响应所需的所有软件.它是互联网上最广泛使用的一种DNS服务 ...
随机推荐
- //……关于TCP三次握手与四次挥手
TCP的概述 TCP把连接作为最基本的对象,每一条TCP连接都有两个端点,这种断点我们叫作套接字(socket),它的定义为端口号拼接到IP地址即构成了套接字,例如,若IP地址为192.3.4.16 ...
- NioEventLoop.run select处理IO事件(boss/worker)流程:
NioEventLoop.run select处理IO事件(boss/worker)流程:processSelectedKeysprocessSelectedKeysOptimizedprocessS ...
- Notepad++ 连接远程 FTP 进行文件编辑
一.下载安装 Notepad++ 1.下载 Notepad++ : https://pan.baidu.com/s/1o7VrS4y 密码 : ck8a 2.安装 Notepad++ 2.1.勾选所有 ...
- POJ 1679 判最小生成树的不唯一性 或 利用次小生成树求解
题目大意: 给定一个无向图,寻找它的最小生成树,如果仅有一种最小生成树,输出所有边的和,否则输出unique! 根据kruscal原理来说,每次不断取尽可能小的边不断添加入最小生成树中,那么可知如果所 ...
- CSU 1214 找最大异或值
题目大意: 给定一堆数,从中找2个数异或得到的最大值 直接暴力会超时,我们要考虑对于每一个数去匹配找到异或的最大值,我们希望2进制越前面的数尽可能都为1 所以我们用 0-1 字典树保存这些数,因为一个 ...
- next_permitation
了解一个C++ STL的函数 next_permitation 可用于生成全排列 如下例子 #include <iostream> #include <stdio.h> #in ...
- 【HDOJ6118】度度熊的交易计划(费用流)
题意: 度度熊参与了喵哈哈村的商业大会,但是这次商业大会遇到了一个难题: 喵哈哈村以及周围的村庄可以看做是一共由n个片区,m条公路组成的地区. 由于生产能力的区别,第i个片区能够花费a[i]元生产1个 ...
- Codeforces713D. Animals and Puzzle
$n<=1000,m<=1000$,$n*m$的01矩阵,给$t<=1000000$个询问,每次问一个矩形中最大的1正方形的边长. 先想想不考虑“一个矩形中”的限制,那记$f(i,j ...
- [bzoj3238][Ahoi2013]差异_后缀数组_单调栈
差异 bzoj-3238 Ahoi-2013 题目大意:求任意两个后缀之间的$LCP$的和. 注释:$1\le length \le 5\cdot 10^5$. 想法: 两个后缀之间的$LCP$和显然 ...
- Divide Two Integers(模拟计算机除法)
Divide two integers without using multiplication, division and mod operator. 由于不能用乘号,除号,和取余.那么一个数除另外 ...