8.21 Linux切换用户的有效群组(newgrp命令)

举报
开源Linux 发表于 2022/05/01 18:26:14 2022/05/01
【摘要】 我们知道,每个用户可以属于一个初始组(用户是这个组的初始用户),也可以属于多个附加组(用户是这个组的附加用户)。既然用户可以属于这么多用户组,那么用户在创建文件后,默认生效的组身份是哪个呢?当然是初始用户组的组身份生效,因为初始组是用户一旦登陆就获得的组身份。也就是说,用户的有效组默认是初始组,因此所创建文件的属组是用户的初始组。那么,既然用户属于多个用户组,能不能改变用户的初始组呢?使用命...

我们知道,每个用户可以属于一个初始组(用户是这个组的初始用户),也可以属于多个附加组(用户是这个组的附加用户)。既然用户可以属于这么多用户组,那么用户在创建文件后,默认生效的组身份是哪个呢?

当然是初始用户组的组身份生效,因为初始组是用户一旦登陆就获得的组身份。也就是说,用户的有效组默认是初始组,因此所创建文件的属组是用户的初始组。那么,既然用户属于多个用户组,能不能改变用户的初始组呢?使用命令 newgrp 就可以。

newgrp 命令可以从用户的附加组中选择一个群组,作为用户新的初始组。此命令的基本格式如下:

[root@localhost ~]# newgrp 组名

下面,我们通过一个实例,讲解此命令的具体用法和功能:

  1. 首先,建立 3 个用户组 group1、group2 和 group3,命令如下:
   [root@localhost ~]# groupadd group1
   [root@localhost ~]# groupadd group2
   [root@localhost ~]# groupadd group3
  1. 创建一个用户 user1,同时指定 user1 的初始组为 group1,附加组为 group2 和 group3,执行命令如下:
   [root@localhost ~]# useradd -g group1 -G group2,group3 user1
   \#由于指定了初始组,因此不会在创建 user1 默认群组
   [root@localhost ~]# more /etc/group | grep user1
   group2:x:501:user1
   group3:x:502:user1
  1. 对用户 user1 设置密码,执行命令如下:
   [root@localhost ~]# passwd user1
   Changing password for user user1.
   New password:
   Retype new password:
   passwd: all authentication tokens updated successfully.
  1. 切换至 user1 用户,通过 newgrp 切换用户组进行下列操作,读者可从中体会出 newgrp 命令的作用。
   \#切换至 user1 用户
   [root@localhost ~]# su - user1
   [root@localhost ~]# whoami
   user1
   \#使用 newgrp 命令一边切换 user1 的初始组,一边创建文件
   [root@localhost ~]# mkdir user1_doc
   [root@localhost ~]# newgrp group2
   [root@localhost ~]# mkdir user2_doc
   [root@localhost ~]# newgrp group3
   [root@localhost ~]# mkdir user3_doc
   \#查看各文件的详细信息
   [root@localhost ~]# ll
   total 12
   drwxr-xr-x 2 user1 group1 4096 Oct 24 01:18 user1_doc
   drwxr-xr-x 2 user1 group2 4096 Oct 24 01:18 user2_doc
   drwxr-xr-x 2 user1 group3 4096 Oct 24 01:19 user3_doc

可以看到,通过使用 newgrp 命令切换用户的初始组,所创建的文件各自属于不同的群组,这就是 newgrp 所发挥的作用,即通过切换附加组成为新的初始组,从而让用户获得使用各个附加组的权限。

newgrp命令的底层实现

其实,newgrp 命令每一次切换用户的初始组,该用户都会以另外一个 shell(新进程,也可以说是子进程)登陆,只不过在新 shell 上登陆的该用户,其初始组改变了而已。

以上实例中,通过添加 shell 内置命令 “echo $$” 就可以发现,每次使用 newgrp 命令,都会切换到一个新的进程。

在本节实例中,使用 newgrp 命令切换用户初始组的整个过程,如图 1 所示:

图 1 newgrp 切换初始组程序运行过程图

可以看到,每一次使用 newgrp 切换用户的初始组,用户都会切换到一个新的子 shell 中,如图 1 中,user1 用户的初始组从最初的 group1,切换成了 group2,再切换成 group3。

当然,如果你想回到原本的环境,需要通过 exit 命令不断回退到当前进程的父进程,最终才能回到初始组为 group1 时的 user1 运行的 shell 中。

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。