设为首页 收藏本站
查看: 553|回复: 0

[经验分享] linux系统上的特殊权限SUID,SGID,STICKY

[复制链接]
累计签到:1 天
连续签到:1 天
发表于 2016-8-2 08:58:37 | 显示全部楼层 |阅读模式
特殊权限:SUID SGID STICKY
    linux的安全上下文:
    1.进程以用户的身份运行,进程是发起此用户的代理,因此以此用户的身份和权限完成所有的操作。
    2.权限匹配模型:
    1)判断进程的属主,是否以被访问的文件属主。如果是,则应用属主权限,否则进入第2步。
    2)判断进程的属主,是否属于被访问的文件属组。如果是,则应用属组的权限,否则进入第3步。
    3)应用other的权限。

SUID:
    默认情况下,用户发起的进程,进程的属主是其发起者,因此,其以发起者的身份在运行。
    SUID的功用:用户运行某程序时,如果此程序拥有SUID权限,那么程序运行时,进程的属主不是发起者,而是程序文件自己的属主。

管理文件的SUID权限:

    chmod u+|-s FILE
    展示位置:属主的执行权限位
             如果属主本有执行权限,显示为小写s,
             否则,显示为大写S。

[iyunv@localhost ~]# cp /bin/cat /tmp/jackfile1      #将cat命令拷贝为jackfile1

[iyunv@localhost ~]# mv /bin/cat /bin/cat.txt        #把cat路径重新编辑,使系统找不到cat命令

[iyunv@localhost tmp]# chmod u+s jackfile1           #增加jackfile1特殊权限suid

[iyunv@localhost tmp]# ll jackfile1                  #查看jackfile1的属主属组和权限
-rwsr-xr-x. 1 jack jack 48568 Aug  1 19:11 jackfile1

[jack@localhost jack]$ ll 2.txt         #jack用户新建2.txt文件,jack5用户对此文件无任何权限
-rw-rw----. 1 jack jack 52 Aug  1 19:25 2.txt

[jack5@localhost jack]$ /tmp/jackfile1 2.txt    #使用jack5用户查看jack用户所建的2.txt文件
agjjfjskdfjlsdfjlsfjsldjgljgljlajgljhljlkdahljfsdjk

实验结论:以上试验中,把jackfile1变成cat命令使用,当jackfile1具有s权限时,其他用户使用jackfile1命令,就相当拥有jackfile1的属主权限,所以任何jack所建的文件,其他用户都可以进行访问。


SGID:
    功用:当目录属组有写权限,且有SGID权限时,那么所有属于此目录的属组,且以属组的身份在此目录中新建文件或者目录时,新文件的属组不是用户的基本组,而是此目录的属组。

管理文件的SGID权限:

    chmod g+|-s FILE
    展示位置:属组的执行权限位
             如果属组原本有执行权限,显示为小写s
             否则,显示为大写S

[jack@localhost jack]$ ll -d                   #设定文件目录jack有SGID权限
drwxrwsr-x. 2 jack jack 4096 Aug  1 19:25 .

[jack3@localhost jack]$ id jack3               #设定jack组为jack3的附加组
uid=4019(jack3) gid=4019(jack3) groups=4019(jack3),4023(jack)

[jack3@localhost jack]$ touch 5.txt           #使用jack3用户新建5.txt文件


[jack3@localhost jack]$ ll                 #查看5.txt文件的所属组是jack,而不是主要组jack3
-rw-rw-r--. 1 jack3 jack  0 Aug  1 19:39 5.txt

实验结论:
1.需要jack3用户有jack的附加组。
2.由于加入SGID权限,用户所建文件的组为jack,意味着jack组内任何成员都可以对5.txt文件进行读写操作。

STICKY:
    功用:对于属组或全局可写的目录,组内的所有用户或系统上的所有用户对在此目录中都能创建新文件或删除所有的已有文件,如果为此类目录设置sticky权限,则每个用户都能创建新文件,且只能删除自己的文件。

管理文件的sticky权限:
    chmod o+|-t FILE
    展示位置:其它用户的执行限位
            如果其它用户原本有执行权限,显示为小写t
            否则,显示为大写T
   系统上的/tmp和/var/tmp目录默认均有sticky权限

[jack@localhost jack]$ ll -d                 #设置jack目录拥有sticky权限,注意看t
drwxrwxrwt. 2 jack jack 4096 Aug  1 20:04 .

[jack4@localhost ~]$ id jack4                #用户jack4为普通用户,跟jack无任何关系
uid=4020(jack4) gid=4023(jack) groups=4023(jack)

[jack4@localhost jack]$ touch 4.txt          #jack4用户在jack目录里建文件4.txt

[jack3@localhost jack]$ rm 4.txt      #使用另一jack3账户对jack4所建文件4.txt进行删除,失败
rm: remove write-protected regular empty file `4.txt'? Y
rm: cannot remove `4.txt': Operation not permitted

实验结论:
1.用户在拥有t权限目录中所建文件,其他用户只能互相修改查看,无法删除其他人所建文件,只能自己删除自己的文件。

2.建立t权限目录的用户有权限删除该目录下的任何文件。


运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-251952-1-1.html 上篇帖子: ERROR : Error appeared during Puppet run: x.x.x.x _keystone.pp 下篇帖子: TCP/IP协议之三次握手、四次断开详解 linux
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表