文件的权限、扩展属性以及facl

大纲:
一、前言
二、普通权限
三、特殊权限
四、ext文件的扩展属性
五、文件的访问控制列表(facl)

一、前言

linux中常见的权限有读(r)、写(w)、执行(x),还有3个特殊的权限。因此下面就从普通权限开始介绍起

二、普通权限

rwx:读 写 执行

blob.png

rwxr-xr-x : 读写执行 读_执行 读_执行  (分别对应)属主 属组 其他组

111101101:对应上述位转化成10进制就是755(因此在赋予权限时就可以用 chmod 755 FILE )

在linux里面,有目录及目录中的文件,而上述权限相对应的目录及文件有所不同,如下:

目录:

r:能用ls查看目录中的文件名列表
w:可以在目录中添加/删除文件
x:能够cd进目录,以及使用ls -l 命令查看文件列表

文件:

r:能查看文件内容
w:可以修改文件内容
x:使文件可以启动为一个进程

权限的修改:

1、使用八进制来进行

chmod [-R] MODE FILE  :如 chmod 777 /tmp/123.txt

blob.png

[-R]递归修改:修改一个目录及里面文件的权限,仅对当前文件生效,后追加的不生效 

2、指定一个或多个类别

chmod 类别 = MODE  :如 chmod u=rw /tmp/123.txt

blob.png

同理:chmod ug=rw /tmp/123.txt
    chomd o=  /tmp/123.txt   等同于 chmod o=--- /tmp/123.txt
    chomd a=r /tmp/123.txt   等同于 chmod ugo=r /tmp/123.txt

3、指定类别的权限的+/-

 chmod 类别+/- MODE : 如 chmod u+x /tmp/123.txt

blob.png

注意 chmod +w 仅对u生效 ,r x 是对a生效

4、参考其他文件的权限

chmod --reference=FILE  :如 chmod --reference=/tmp/file

blob.png

三、特殊权限

特殊权限有三类:suid sgid sticky

suid: 

修改方式:chmod u[+/-]s FILE

当进程执行此文件时,将以此文件的属主进行执行,当然前提是此类文件都是可执行程序。

比如:/etc/shadow 是没有权限访问的,但是任何用户都可以修改自己密码,

blob.png

blob.png

当用户(ubuntu)访问这个文件时,实际上是以此文件的属主root发起这个进程,所以可以修改shadow这个文件。

guid:

修改方式:chmod g[+/-]s FILE

类似于sgid

blob.png

那当上图这种情况下,是否可以修改用户的密码?

要回答这个问题,我们先要知道进程访问文件的次序,如下:

进程的属主,是否与被访问的文件属主相同;
进程的属主所属于的组当中,是否有一个与被访问的文件的属组相同;
以other的权限进行访问;

假设我们以ubuntu这个普通用户访问/etc/shadow 时,相当于属主所属的组是root(/usr/bin/passwd 的属组root),去访问/etc/shadow,但是shadow 的属组虽然为root,但是却没有任何可执行权限,因此不能修改用户的密码。

blob.png

那这个guid有什么用呢?

好处如下:如果将目录的属组设置SGID权限之后,所有用户在此目录创建文件的属组不再是用户的基本组,而是目录的属组

blob.png

这样几个用户就可以加入一个附加组,创建一个目录,将其属组改成相同的附加组;从而可以实现在同一目录下,多用户可以进行文件共享的操作了

如: 用户ubuntu 、007的附加组都有一个share,/tmp/share 的属主属组为 root share 

因此 在/tmp/share 里面ubuntu  007 建立的文件可以互相访问以及修改

blob.png

但是用户可以删除其他用户建立的文件,要避免这个问题,需要用到以下的sticky位功能。

sticky

修改方式:chmod o[+/-]t FILE

使用了这个权限,则用户不能删除其他用户创建的文件。如007 删除不了ubuntu用户创建的文件。

blob.png

当然以上三个权限又可以组成一个八进制数值,我们赋值的时候也可以这样做

chmod 7111 FILE  如:chmod 7111 /tmp/share

blob.png

如果是 7000 FILE   如:chmod 7000 /tmp/share

blob.png

这就是权限位大小写字母的区别

四、ext文件的扩展属性

lsattr 查看属性

blob.png

上面有个e,只要能看到这个文件,肯定都存在e属性,表示支持这个扩展属性格式的。

chattr修改属性

chattr [+-=][FILE]

a:只能增加,不能修改。 
c:压缩格式,将会自动的压缩文件。 
d:尚未备份 
i:无法修改

以下以i属性作为介绍,设置而了i属性后,即使root也无法修改文件。

blob.png

五、文件的访问控制列表(facl)

facl也是用到了文件的扩展属性,但是和以上的文件扩展属性没有相关,只是有点近似。

作用:让普通用户透过文件的扩展属性,为其添加额外的用户访问授权机制而无须改变其属主、属组,也不用更改other的权限

命令:     

 设置    setfacl -m   u:USERNAME/UID:MODE FILE
                g:GROUPNAME/GID:MODE FILE
 取消    setfacl  -x  u:USERNAME/UID   FILE                                      g:GROUPNAME/GID  FILE   
 查看    getfacl

举个例子:

用户ubuntu对一个属主是自己的文件进行facl授权,让用户007可以对此文件拥有读写权限。但是007本身是个数字,直接使用007会导致授权到UID为7的用户;因此使用007的uid,即4431进行授权

blob.png

用户007进行文件的更改:

blob.png

设置了facl后,权限应用模型是 自上而下的生效的。属主-用户级别facl-属组-组级别facl-其他

以上是一些体会,还有很多扩展功能还没学到,以后再慢慢分享。

原创文章,作者:麦鲸,如若转载,请注明出处:http://www.178linux.com/3838

(0)
麦鲸麦鲸
上一篇 2015-05-04
下一篇 2015-05-04

相关推荐

  • N22-第二周作业

    一.linux上的文件管理命令都有哪些,其常用的使用方法及其相关示例演示     cp复制命令:     -i:若目标文件存在,提示是否覆盖目标文件,此选项为已写入alias里,使用时为默认选项     [root@localhost ~]# ls /tmp/…

    Linux干货 2016-08-20
  • 文本处理:三剑客之sed及vim编辑器

    一、sed的用法详解 sed作为Linux的第二招,有着非常强大的文本处理功能。sed是一种在线编辑器、行编辑器,每次处理一行内容。在处理时,sed首先将行放在内存中的一块临时缓冲区,通常配叫做模式空间(pattern space)。如果模式空间的行符合sed的匹配模式则将该行处理后送到标准输出,如果不匹配则不做任何改动送到标准输出。模式空间中一般情况下只会…

    Linux干货 2016-08-12
  • hadoop安全模式

    hadoop安全模式在分布式文件系统启动的时候,开始的时候会有安全模式,当分布式文件系统处于安全模式的情况下,文件系统中的内容不允许修改也不允许删除,直到安全模式结束。安全模式主要是为了系统启动的时候检查各个DataNode上数据块的有效性,同时根据策略必要的复制或者删除部分数据块。运行期通过命令也可以进入安全模式。在实践过程中,系统启动的时候去修改和删除文…

    Linux干货 2015-04-13
  • Linux基本知识之Vim编辑器

    vim文本编辑器:    vim是Linux系统上的最著名的文本/代码编辑器,也是早年的vi编辑器的加强版,而gVim则是其windows版。它的最大特色是完全使用键盘命令进行编辑,脱离了鼠标操作虽然使得入门变得困难,但上手之后键盘流的各种巧妙组合操作却能带来极大幅度的效率的提升。 (1)打开文件与关闭文件:     …

    Linux干货 2016-08-10
  • 不忘初心,砥砺前行!

    这是本人第一次书写博客,难免有些小心翼翼,手足无措,但每个人都有这样的经历,转念一想也就释怀了。时光飞速,我们已不再年轻,从大学毕业的那天起,我们就再也不是小孩子了。 7月的天气总是那么折磨人,高温让我们步履维艰,在7月只想找一片月淡风轻的乐土,度过一个难熬的夏天,或找一间空调房,调大音量,享受午后时光。但这样的日却离我们很远,这个夏天我们背起行囊,远离故土…

    2017-07-11
  • 面授20-1班 0805课间练习与课后作业

    课间练习 第一阶段 新学的命令文本命令cat tac rev more less head tail cut paste wc sort dif patch 1 、找出ifconfig 命令结果中本机的所有IPv4 地址 [root@IP70-CentOS7 ~]# >>ifconfig | tr&nbsp…

    Linux干货 2016-08-07