你知道Linux中的UID和GID的含义吗

你知道Linux中的UID和GID的含义吗

是不是大家看到UID(user id)和GID(group id),都会立马说不就是用户和用户组ID。

但是。

当我们登陆Linux系统时,输入自己的用户名和密码,这里其实Linux系统并不认识你的用户名(或者换一种说法,不是依赖于你的用户名来识别你),它只认识你的用户名所对应的ID号(一串数字)。

直白一点,用户名实际没有ruan用,仅是为了方便用户的记忆而已(对比域名和ip)。

如下图:

查看odysee用户UID和GID

图片[1]-你知道Linux中的UID和GID的含义吗-趣考网

Linux系统将所有用户名称与ID的对应关系都存储在/etc/passwd文件中。

如下图:

图片[2]-你知道Linux中的UID和GID的含义吗-趣考网

用户组名称和ID对应关系都存储在/etc/group文件中。

图片[3]-你知道Linux中的UID和GID的含义吗-趣考网

1、 这里大家可能会问,既然Linux系统不认识用户名,文件是如何判别它的拥有者名称和群组名称的呢?

解:

每个文件都有自己的拥有者ID和组ID,当显示文件属性时,系统会根据/etc/passwd和 /etc/group文件中的内容,分别找到UID和GID对应的用户名和群组名,然后显示出来。

这里就类似于数据库中student表,拿着sno(学号)找对应的sname(姓名)。

如下图所示:

stat groovy.txt

图片[4]-你知道Linux中的UID和GID的含义吗-趣考网

2、 做个小demo

实现让odysee用户无法进入自己的家目录

提示:修改重要配置文件请提前备份

图片[5]-你知道Linux中的UID和GID的含义吗-趣考网

(1)修改odysee的UID

图片[6]-你知道Linux中的UID和GID的含义吗-趣考网

(2)查看刚刚odysee的groovy.txt文件

是不是发现本来的用户名odysee变成了1000

前面我们已经说过了,每个文件都有自己的拥有者ID和组ID,当文件groovy拿着ID(1000)去/etc/passwd找自己的姓名时,发现没有和1000匹配的姓名(因为我们刚刚把它的UID改为了9527)。所以只能显示UID。

图片[7]-你知道Linux中的UID和GID的含义吗-趣考网

(3) 从root切到odysee

下面居然提示没有权限。

还回不了自己的家了。

图片[8]-你知道Linux中的UID和GID的含义吗-趣考网

ll home

drwx------ 3 1000 odysee 4096 May 22 11:04 odysee

是不是跟(2)一样的原理。

该目录只有UID为1000的用户可以进入,其余的(不限root)一切免进(g、o位没有权限,只有u位有rwx权限)。

图片[9]-你知道Linux中的UID和GID的含义吗-趣考网

总结:

关于UID和GID大家是不是有了一点点新的认识。

关于/etc/passwd文件中用户的UID别忘了改回去。

© 版权声明
THE END
喜欢就支持一下吧
点赞14 分享