理清Linux中的各种用户ID关系
来源:互联网 发布:大掌柜进销存软件 编辑:程序博客网 时间:2024/04/27 21:14
绿色代表进程(进程的性质)橙色代表文件(文件的性质)。当进程试图打开文件时,内核会进行如下权限测试:
0. 若进程的有效用户ID是0(超级用户),则允许访问。
1. 若进程的有效用户ID等于文件的所有者ID,那么进行文件所有者访问权限的测试(与open的参数对比),对应图中的1。
2. 若进程的有效组ID或进程的附加组ID之一等于文件的组ID,则进行文件所属组的权限测试,对应图中的2.
3. 测试文件的Other访问权限。
转载请尊重原创、保留相关链接本文来自多宝平台 :http://www.mbodb.com
注:如果第1步中进程有效用户ID等于文件所有者ID,但相应权限的测试不符合,则不会进入第2步的组测试。对于2,3步也同理。
下面看一下一个用户执行进程的过程:
(1) 每个用户登录后都对应一个uid,一个gid,一组附加组id,如上图红色部分。
(2) 每个程序文件(黄色部分)和普通文件一样拥有文件所有者id,文件所有组id,并具有相应rwx权限。
(3) 用户打开文件时进行图1描述流程的x权限测试(只不过此时不是进程而是用户)。
(4) 当a.用户是超级用户或b.用户id和文件所有者id相同且文件所有者具有x权限或c.用户的gid和文件的所属组id相同且文件所属组具有x权限或d.文件的other具有x权限,则用户可执行此程序,产生进程(上图绿色部分)。
(5) 用户的uid变成进程的实际用户id,用户的gid变成进程的实际组id,用户的附加组id变成进程的附加组id。
(6) 当程序文件没有设置”设置用户id位(SUID)”和”设置组id(SGID)位”时进程的有效用户id等于进程的实际用户id,进程的有效组id等于进程的实际组id。
(7) 当程序文件设置了”设置用户id位(SUID)”时,进程的有效用户id保存到进程多宝“保存的设置用户id”,之后进程的有效用户id变为程序文件的所有者id。
(8) 当程序文件设置了”设置组id(SGID)位”时,进程的有效用户组id保存到进程“保存的设置用户组id”,之后进程的有效用户组id变为程序文件的所有组id。
- 理清Linux中的各种用户ID关系
- 理清Linux中的各种用户ID关系
- 理清Linux中的各种用户ID关系
- 理清Linux中的各种用户ID关系
- 理清Linux中的各种用户ID关系
- Linux中的用户ID
- linux中的用户ID分类
- linux 中的用户ID (ZZ)
- Linux中的用户ID和有效用户ID的区别
- 关于LINUX中的权限位S(设置用户ID)(有效用户ID)(实际用户ID)
- 一步步探究linux进程中的用户ID
- 一步步探究linux进程中的用户ID
- uml中的各种关系
- linux 设置用户id
- 关于linux中的实际用户,有效用户,设置-用户-ID位
- linux 用户id 有效用户id 保存设置id
- Linux下的各种id
- 理清Js的各种遍历
- 条款7:为多态基类声明virtual析构函数
- sqlplus无法显示列标题
- Socket 网络传输例子
- GPIO模拟SPI
- 最小向量乘积
- 理清Linux中的各种用户ID关系
- 单例设计模式
- java web开发 高并发处理
- 测试
- 字符编码拦截器
- 如何对待别人的赞美和批评?
- 图像测距与三维重构
- JS DOM编程艺术-笔记
- 网线安装水晶头