setuid和setgid位详述

本文介绍了Linux系统中setuid和setgid的概念及其作用。setuid允许非root用户执行特定命令时临时获得root权限;setgid确保目录下新建文件继承目录的属组而非创建者的默认属组。

setuid和setgid位

[1] setuid位

如果在可执行文件上设置了setuid位,运行可执行文件的进程将拥有该文件所有者同样的权限。

典型的例子是这个。
可执行文件:/usr/bin/passwd

/usr/bin/$ls -l passwd
-rwsr-xr-x 1 root root 32988 2008-06-10 02:10 passwd

ls后可以看到,它的文件属主是root,它的可执行权限位是s,表示该文件可执行并且已经设置了setuid位。

/etc$ls -l passwd
-rw-r--r-- 1 root root 1515 2009-03-29 18:08 passwd

/etc/passwd的文件属主是root,只有root用户拥有写权限,其他类型的用户只能读该文件。

我们知道,当执行/usr/bin/passwd来修改某个用户的可执行权限时,需要修改文件/etc/passwd。
如果我用非root用户(如:patrick)的身份来执行/usr/bin/passwd,由于它设置了setuid位,用户patrick
在执行的过程中,就拥有了root用户的权限。因此,它可以对文件/etc/passwd进行修改(有写权限)。

[2] setgid位
当某个目录上设置了setgid位后,在这个目录中新创建的文件具有该目录的属性权限而不是创建该文件的用户
的默认属组。这项约定使得几个用户之间(只要这些用户属于一个共同的组)共享一个目录中的文件变得简单。

[3] 设置它们的方法
chmod u+s file1      -- 设置setuid位
chmod g+s file1      -- 设置setgid位

chmod 4755 file1      -- 设置setuid位
chmod 2755 file2      -- 设置setgid位
chmod 6755 file3     -- 同时设置setuid和setuid位

如果文件原来设置了可执行位(x),增加了setuid或者setgid位后,对应的可执行位是s,如果它原来没有设置
可执行位,增加了setuid和setgid位后,对应的可执行位是S。

 

粘着位

 

eg:

chmod 777 abc

chmod +t abc

 

等价于

chmod 1777 abc

在以前旧的系统当中,如果一个程序文件一旦设置了粘着位,那么当该程序中止的时候他的所有指令段将被保存到系统的交换分区当中,再次运行时可以更快的调入系统.不过现在的操作系统已经不再使用这种功能了.但这并不表示这功能已经完全被废弃.当一个目录设置为粘着位时,它将发挥特殊的作用,即当一个目录被设置为"粘着位"(用chmod a+t),则该目录下的文件只能由


一、超级管理员删除
二、该目录的所有者删除
三、该文件的所有者删除


也就是说,即便该目录是任何人都可以写,但也只有文件的属主才可以删除文件。

### 回答1: setuidsetgid是Linux文件/目录的权限设置,用于控制文件/目录的访问权限。 setuid是指当一个文件被执行时,该文件的所有者权限将被提升为执行者的权限,即使执行者的权限低于文件所有者的权限。这样可以使得一些需要高权限才能执行的程序在低权限用户下也能够执行。 setgid是指当一个目录被创建时,该目录的所有者权限将被设置为创建者的组权限,即使创建者的权限低于目录所有者的权限。这样可以使得在该目录下创建的文件都属于同一组,方便组内成员共享文件。 总之,setuidsetgid是Linux系统中非常重要的权限设置,可以提高系统的安全性灵活性。 ### 回答2: 在Linux系统中,每一个文件目录都有其所属的用户用户组。setuidsetgid是可以应用于文件目录的特殊权限,它们可以极大地影响一个文件或目录的访问权限执行权限。 首先,setuid权限使得在执行文件时,运行该执行文件的进程会暂时拥有该文件所有者的权限,即使是普通用户也可以执行一些仅有管理用户才能运行的程序,如passwd命令等。这样做可以让普通用户执行一些操作,提高了系统的可维护性可操作性。 其次,setgid权限则允许指定一个文件或目录的用户组,从而提供更精细的权限控制。在设置了setgid权限的目录里的新文件目录,其所属用户组会被自动设置为目录的用户组,从而实现了成员共享文件的精细控制。同时,如果一个具有setgid权限的可执行文件被运行,那么它会以其所属的用户组的身份运行,在这个用户组里所具有的权限也会拥有。 实际上,在不恰当的使用setuidsetgid权限时,也可能会带来系统的风险不安全性。因此,在设置文件目录的权限时,我们需要慎重考虑应用setuidsetgid权限的必要性,尽量减少不必要的风险。对于一些敏感的系统操作或者权限限制较大的文件目录,我们也要加强对其权限的管理控制,从而最大限度地保证系统安全运行稳定。 ### 回答3: 在Linux文件系统中,每个文件/目录都有一个所有者一个所属组,由于这个特性,一些特殊权限被引入,其中包括setuidsetgidsetuidsetgid是Linux文件系统的一个非常重要的安全特性,可以在执行该文件时,临时将当前用户的权限更改为文件所有者或文件所属组的权限,从而使得用户可以利用文件所有者或文件所属组的权限来执行一些对于当前用户本身需要特殊授权的操作,而无需为此特别授权。 setuidsetgid分别是set user ID set group ID的缩写。当文件所有者或文件所属组中有一个特殊权限被设置为“s”时,就表示这个文件有setuidsetgid权限。具体来说,setuid使得一个文件在执行时将有效用户ID更改为文件所有者的ID,setgid则将有效组ID更改为文件所属组的ID。 对于一个拥有setuid权限的可执行文件,当一个普通用户执行它时,其所拥有的权限就可以被限制在执行该文件的组或者用户的权限内,从而保证了系统对文件的操作安全性。在实际效果中,setuidsetgid的应用范围很广,可以应用于各种场合,比如sudo程序、passwd等。 总而言之,setuidsetgid是Linux文件系统中的一种特殊权限,可以为普通用户提供执行高特权操作的托管服务,从而提高系统的安全性可用性。同时,根据需要设置setuidsetgid的权限具有升级或降级普通用户权限的功能,对于Linux服务器的管理运维也有很大的帮助。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值