在Linux系统中将用户添加到组的四种方法:usermod、gpasswd、Shell Script、Manual Method,以下是详细的操作方法。
前言
Linux组是用于管理Linux中的用户帐户的组织单位,它具有Linux系统中每个用户和组的唯一数字标识号,它被称为用户ID(UID)和groupid(GID),组的主要目的是为组成员定义一组权限,他们都可以执行特定操作,但不能执行其他操作。
Linux中有两种类型的默认组,每个用户应该只有一个主要组和任意数量的次要组。
Primary Group:创建用户帐户时,主要组已添加到用户,它通常是用户的名字,在执行任何操作(例如创建新文件(或目录),修改文件或执行命令等)时,主组将应用于用户,用户主要组信息存储在/etc/passwd文件中。
Secondary Group:它被称为补充组,它允许用户组在同一组成员文件中执行特定操作。
本文介绍的四种方法:
usermod:usermod命令修改系统帐户文件以反映在命令行上指定的更改,参考usermod命令_Linux usermod命令使用详解:用于修改用户的基本信息。
gpasswd:gpasswd命令用于管理/etc/group和/etc/gshadow,每个组都可以拥有管理员,成员和密码,参考gpasswd命令_Linux gpasswd命令使用详解:工作组文件的管理工具。
Shell Script:Shell脚本允许管理员自动执行所需的任务。
Manual Method:我们可以通过编辑/etc/group文件手动将用户添加到任何组中。
我假设你已经拥有此活动所需的组和用户,在此示例中,我们将使用以下用户和组user1,user2,user3和group是mygroup和mygroup1。
在进行更改之前,我想检查用户和组信息,请参阅以下详细信息。
我可以看到以下用户与他们自己的小组有关,而不是与其他用户有关:
# id user1
uid=1008(user1) gid=1008(user1) groups=1008(user1)
# id user2
uid=1009(user2) gid=1009(user2) groups=1009(user2)
# id user3
uid=1010(user3) gid=1010(user3) groups=1010(user3)
我可以看到该组中没有用户关联:
# getent group mygroup
mygroup:x:1012:
# getent group mygroup1
mygroup1:x:1013:
方法1:usermod命令
usermod命令修改系统帐户文件以反映在命令行上指定的更改。
1、如何使用usermod命令将现有用户添加到辅助组或补充组?
要将现有用户添加到辅助组,请使用带有-G选项的usermod命令和组的名称。
语法:
# usermod [-G] [GroupName] [UserName]
如果系统中不存在给定用户或组,你将收到错误消息,如果没有收到任何错误,则表示该用户已添加到相应的组中:
# usermod -a -G mygroup user1
让我用id命令查看输出,它已成功添加:
# id user1
uid=1008(user1) gid=1008(user1) groups=1008(user1),1012(mygroup)
2、如何使用usermod命令将现有用户添加到多个辅助或补充组?
要将现有用户添加到多个辅助组,请使用带有-G选项的usermod命令和带逗号的组的名称。
语法:
# usermod [-G] [GroupName1,GroupName2] [UserName]
在这个例子中,我们将把user2添加到mygroup和mygroup1中:
# usermod -a -G mygroup,mygroup1 user2
让我用id命令查看输出,user2已成功添加到mygroup和mygroup1中:
# id user2
uid=1009(user2) gid=1009(user2) groups=1009(user2),1012(mygroup),1013(mygroup1)
3、如何更改用户的主要组?
要更改用户的主要组,请使用带有-g选项的usermod命令和组的名称。
语法:
# usermod [-g] [GroupName] [UserName]
我们必须使用-g来更改用户的主要组:
# usermod -g mygroup user3
让我们看看输出,它已成功更改,现在,它将mygroup显示为user3主要组而不是user3:
# id user3
uid=1010(user3) gid=1012(mygroup) groups=1012(mygroup)
方法2:gpasswd命令
gpasswd命令用于管理/etc/group和/etc/gshadow,每个组都可以拥有管理员,成员和密码。
1、如何使用gpasswd命令将现有用户添加到辅助组或补充组?
要将现有用户添加到辅助组,请使用带-M选项的gpasswd命令和组的名称。
语法:
# gpasswd [-M] [UserName] [GroupName]
在这个例子中,我们将把user1添加到mygroup中:
# gpasswd -M user1 mygroup
让我用id命令查看输出,user1已成功添加到mygroup中:
# id user1
uid=1008(user1) gid=1008(user1) groups=1008(user1),1012(mygroup)
2、如何使用gpasswd命令将多个用户添加到辅助或补充组?
要将多个用户添加到辅助组,请使用带-M选项的gpasswd命令和组的名称。
语法:
# gpasswd [-M] [UserName1,UserName2] [GroupName]
在这个例子中,我们将把user2和user3添加到mygroup1中:
# gpasswd -M user2,user3 mygroup1
让我看看使用getent命令的输出,user2和user3已成功添加到mygroup1中:
# getent group mygroup1
mygroup1:x:1013:user2,user3
3、如何使用gpasswd命令从组中删除用户?
要从组中删除用户,请使用带-d选项的gpasswd命令以及用户和组的名称。
语法:
# gpasswd [-d] [UserName] [GroupName]
在此示例中,我们将从mygroup中删除user1:
# gpasswd -d user1 mygroup
Removing user user1 from group mygroup
方法3:使用Shell脚本
基于以上示例,我所知道的是usermod命令无法将多个用户添加到组中,但可以通过gpasswd命令完成。但是,它将覆盖当前与该组关联的现有用户。
例如,user1已与mygroup关联,如果你想使用gpasswd命令将user2和user3添加到mygroup中,它将无法按预期工作,而是直接对组进行修改而不是修改它。
如果你想将多个用户添加到多个组,那么解决方案是什么?在这两个命令中都没有默认选项可用于实现此目的。
因此,我们需要编写一个小的shell脚本来实现这一目标。
1、如何使用gpasswd命令将多个用户添加到辅助或补充组?
如果要使用gpasswd命令将多个用户添加到辅助组或补充组,请创建以下小shell脚本。
创建用户列表,每个用户应该在单独的行中:
$ cat user-lists.txt
user1
user2
user3
使用以下shell脚本将多个用户添加到单个辅助组,可先参考在Linux系统中运行.sh文件的两种方法:
vi group-update.sh
#!/bin/bash
for user in `cat user-lists.txt`
do
usermod -a -G mygroup $user
done
为group-update.sh文件设置可执行权限:
# chmod + group-update.sh
最后运行脚本来实现这一目标:
# sh group-update.sh
让我看看使用getent命令的输出,user1,user2和user3已成功添加到mygroup中:
# getent group mygroup
mygroup:x:1012:user1,user2,user3
2、如何使用gpasswd命令将多个用户添加到多个辅助或补充组?
如果要使用gpasswd命令将多个用户添加到多个辅助或补充组,请创建以下小shell脚本。
创建用户列表,每个用户应该在单独的行中:
$ cat user-lists.txt
user1
user2
user3
创建组列表,每组应分开:
$ cat group-lists.txt
mygroup
mygroup1
使用以下shell脚本将多个用户添加到多个辅助组:
#!/bin/sh
for user in `more user-lists.txt`
do
for group in `more group-lists.txt`
do
usermod -a -G $group $user
done
done
为group-update-1.sh文件设置可执行权限:
# chmod +x group-update-1.sh
最后运行脚本来实现这一目标:
# sh group-update-1.sh
让我看看使用getent命令的输出,user1,user2和user3已成功添加到mygroup中:
# getent group mygroup
mygroup:x:1012:user1,user2,user3
此外,user1,user2和user3已成功添加到mygroup1中:
# getent group mygroup1
mygroup1:x:1013:user1,user2,user3
方法4:在Linux中将用户添加到组中的手动方法
我们可以通过编辑/etc/group文件手动将用户添加到任何组中。
打开/etc/group文件并搜索要更新用户的组名,最后将用户更新到相应的组中:
# vi /etc/group
至此,目标达到。
相关主题