Linux下的real UID和effective UID

real UID是标记谁调用了该可执行文件;effective UID表示该可执行程序所具有的权限的用户;

默认情况下real UID和effective UID一样,但是当使用了setUID之后,两者有可能不一样。

例如passwd程序,当你执行这个程序的时候,它的real UID就是调用passwd的用户,这个用户可能是root,也可能是任何普通用户;

但是它的effective UID是root,只有这样passwd程序才能修改/etc/passwd文件。

http://www.lst.de/~okir/blackhats/node23.html