细说linux上的特殊权限位

linux上的文件的权限

linux的哲学思想之一就是一切皆文件。这样说来,每台安装了linux的主机上,就会有大量的文件。而另一方面,linux在安全方面有着极为出色的表现。众所周知,linux是一个多用户的系统,因此为一个文件加上合适的权限为显得非常有必要了。linux上的基本权限我就不一一介绍了,请不熟悉的同学自行百度脑补。我们来说说linux上文件和目录的特殊权限。

这是linux上一个文件的长格式说明:

-rw-r--r--   1 root root 1187 Mar 19 16:30 /etc/passwd
-rw-------   1 root root 2.9K Mar 20 05:29 .bash_history
drwx------.  2 root root 4.0K Mar 19 16:08 .ssh

我们拿第一个文件/etc/passwd来做说明:

-rw-r--r-- 1 root root 1187 Mar 19 16:30 /etc/passwd

这里我们只说第一部分,第一个“-”说是这是一个普通文件, 后面的”rw——-“又以分为三个部分, 第一部分”rw-“是说这个文件的拥有者对这个文件有读写的权限, 第二部分“r–”是说这个文件的所属组对这个文件只有读的权限, 第三个“r–”是指系统上除了文件所有者和文件所属组之外所有人只能够拥有的可读的权限了。

在linux上,每一个文件都有一种类型,它们的表示方式为:
    -:表示这是一个普通文件
    d:表示这是一个目录
    p:表示这是一个管道符文件
    s:表示这是一个套接字文件
    b:表示这是一个块设备
    l:表示这是一个链接文件
    c:表示这是一个字符设备

在linux上,我们可以看到新建一个文件和新建一个目录后,这个文件和目录对应的权限是不一样的,其原因就是因为有umask的存在。 umask是指定用户新建文件或目录时默认权限的一个东东。我们可以在bash中输入umask来查看系统上umask的值。

[root@localhost mageedu]# umask
0022

linux上默认的,新建一个文件时就有如rwxrw-rw-权限,而新建一个目录则有rwxrwxrwx等权限,可以通过改变umask来改变新建文件和目录的默认的权限。 linux上除了最基本的所有者,所属组和其他人的读,写和执行权限之外,还有其他的特殊权限. 我们可以输入lsattrchattr来为文件和目录设置隐藏权限,其用法如下:

lsattr:显示文件特殊属性

用法: lsattr [选项] 文件

常用选项:

-R        递归显示文件夹及其内容的的属性
-a        显示文件的所有属性        
-d        只显示目录本身的属性

chattr:设置文件特殊属性

用法:chattr [选项] [模式] 文件

常用选项:

+        增加某一特殊权限
-        移除某一特殊权限                    
=        设定某一特殊权限
-R       递归改变目录及其子目录的属性

常用模式:

a        文件只能增加,不能修改和删除(root也不能删除这个文件,但是可以先把这个属性去掉,然后删除)
c        保存文件时,自动压缩文件,读取时自动解压缩
d        设置这个属性后,打包时这个文件将不会被告打包
i        设置这个属性后,文件内容将不会被更改
s        删除文件时,完全删除(删除后不可恢复)
u        删除文件时,数据内容还在磁盘里(删除后还可以恢复)
A        保存文件时,文件的atime不改变

下面我们再来说下linux上的特殊权限。

针对可执行文件,可以设置suid权限。对一个文件设置suid权限后,任何用户执行这个可执行文件时,不再以用户自己的身份当作进程的属主,而是以文件的属主当作进程的属主。拿/etc/shadow这个文件来说吧。我们可以看到这个文件的权限:

[root@localhost mageedu]# ll /etc/shadow
---------- 1 root root 878 Mar 20 11:58 /etc/shadow
可以看到,任何人都没有修改这个文件的权限,那么有一天当一个普通用户不想用自己现在使用的权限,想更换一个密码的时候,那怎么办呢。答案就在这个/etc/shadow这个文件身上。/etc/shadow这个文件就设置了suid权限,这样一个普通用户更改自己的密码,输入passwd那一刻,普通用户临时调用/etc/shadow这个文件的用户所有者root的权限,然后修改自己的密码,修改完之后,就又恢复到普通用户自己的权限了。
对于设置了suid权限的文件来说:
    1.suid权限仅对二进制程序有效
    2.执行者对于该程序需要有执行权限
    3.本权限仅在执行该权限的过程中有效
    4.执行者将具有该程序拥有者的权限

suid表现为文件属主执行权限位上显示为s或S,文件原来有执行权限时为s,文件原来没有执行权为S 为文件设置suid权限可以使用chmod u+s file命令,取消则用chmod u-s file命令。

说完了针对普通文件的特殊权限,再来说下针对目录的特殊权限。对于具有sgid权限的目录,用户在此目录下创建文件时,新建文件的属组不再是用户所属的基本组,而是目录的属组。

对于一个设置了sgid的普通文件来说,其表现形式为:
    1.sgid对二进制程序有用
    2.程序执行者对于该程序需要有执行权限
    3.执行者在执行过程中将会获得该程序群组的支持

对于一个设置了sgid的目录来说,其表现形式为:
    1.用户对此目录有可读写权限时,该用户能够进入此目录
    2.用户在此目录下的有效群组将会变成该目录的群组
    3.用户在此目录下有写权限时,建立的新文件属组为此文件夹的属组

为目录设置sgid权限,可以使用chmod g+s dir这个命令,取消这个特殊权限则用chmod g-s dir这个命令。 sgid表现在文件属组执行权限位上的s或S,对于有执行权限的目录,其表现在权限位上为s,对于没有执行权限的目录,其表现在权限位上为S。

除了这两个特殊的权限之外,linux上还有一个很特殊的权限,那就是sticky了。如下图所示:

[root@localhost ~]# ll -d /tmp
drwxrwxrwt. 3 root root 4096 Mar 20 21:43 /tmp
其在linux上的表现为t,对于有执行权限的目录,其表现在权限位上为t,对于没有执行权限的目录,其表现在权限位上为T。sticky对于目录的作用就在于:对于公共可写的目录,用户可创建文件,可以删除自己创建的文件,但无法删除别人的文件。
为目录设置sticky权限可以使用chmod o+t dir这个命令,取消可以用chmod o-t dir这个命令。

注意:以上的权限设置或取消都要有管理员的权限才可以。

祝大家工作学习愉快!

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

(1)
renpingshengrenpingsheng
上一篇 2017-04-10 20:57
下一篇 2017-04-10 21:27

相关推荐

  • raid,lvm,及sed命令的相关使用总结

    raid0 条带化 chunk最小写入单位 至少2块盘 空间大小 单块磁盘大小*nraid1 镜像  1/n   读性能提升,写入比单块盘慢  空间始终是一块盘的大小   容错率高  可以坏  n-1块盘raid10 容错高于raid01 但空间损失更多,读写性能 提升 造价高。raid4&nbsp…

    2017-08-26
  • Linux安全和加解密

    概述:     所有业务的正常运转,离不开一个安全的运行环境,系统安全性直接关系到业务稳定、可靠、以及可用性,本章就介绍一些系统安全相关的话题,具体包括:        1、加密基础概念     2、CA和证书的基础概念  &nb…

    Linux干货 2016-09-23
  • cnetos 6.7 内核编译

    简介     Linux内核的体积结构是单内核的,但充分借鉴了微内核设计体系的优点,为内核引入模块化机制,使得虽然是单内核、但工作在模块化的方式下、并且这个模块可以动态装载或卸载;Linux负责管理系统的进程、内存、设备驱动程序、文件和网络系统,决定着系统的性能和稳定性。如是我们在了解Linux内核的基础上根据自己的需…

    Linux干货 2016-02-27
  • 磁盘管理

    磁盘管理磁盘管理 本章内容 磁盘结构 分区类型 管理分区 管理文件系统 挂载设备 管理虚拟内存 设备文件 I/O Ports: I/O设备地址 一切皆文件: open(), read(), write(), close() 设备类型: 块设备:block,存取单位“块”,磁盘 字符设备:char,存取单位“字符”,键盘 设备文件:关联至一…

    Linux干货 2016-08-26
  • awk学习笔记

        awk是一种模式扫描和处理工具,相对于grep的查找,sed的编辑,它在对数据进行分析生成报表时显得尤为强大。awk通过逐行遍历一个或多个文件的方式,查找模式匹配到的行,而后以指定的分隔符(缺省为空格)进行切片,然后针对切片数据进行处理和分析。事实上,gawk有自己的语言,其本身就相当于一个解释器,允许用户创建…

    Linux干货 2015-08-04
  • N25_第五周

    1、显示/boot/grub/grub.conf中以至少一个空白字符开头的行;grep -E "^[[:space:]]+" /boot/grub2/grub.cfg 2、显示/etc/rc.d/rc.sysinit文件中以#开头,后面跟至少一个空白字符,而后又有至少一个非空白字符的行;grep -E "^#[[:space:]…

    Linux干货 2017-01-08

评论列表(1条)

  • renjin
    renjin 2017-04-12 13:29

    主要写了linux下特殊权限位,内容写的很详细,排版也很好,继续努力!