感觉是一样的,什么样的情况下不一样?文件的owner id 是不是等于拥有者的user id?
real user id (RUID)
进程的创建者用户ID,进程的执行者。该ID仅root用户可以修改。
effective user id (EUID)
该用户ID标识用户进程执行操作的权限。普通用户可以将EUID设置为RUID或SUID,而超级用户可以将EUID设置为任意的合法UID。
uid
和euid
大部分时候是一样的,就是你login所用的uid,但在一个情况下会不一样:
Unix下的可执行文件可以设定sticky
位,比如用chmod u+s some_exec
,此时这个some_exec
是一个“SetUID”程序,无论你的uid
是什么,当你运行这个程序时,你的euid
会变成这个some_exec
的属主的uid
,一般把它叫suid
,此时你的这个进程的权限就变成了这个属主的权限,但uid依然保持不变。这个进程可以用seteuid(2)
在uid
和suid
之间切换。
类似的,gid
也有rgid
、sgid
和egid
,工作方式与uid
相同。
最常见的“SetUID”程序就是su
和sudo
,你可以用它们临时切换权限。