Linux用户与用户组管理
Linux系统是一个多用户多任务的操作系统,任何-一个要使用系统资源的用户,都必须首先向系统管理员申请-一个账号,然后以这个账号的身份进入系统。
用户的账号一方面可以帮助系统管理员对使用系统的用户进行跟踪,并控制他们对系统资源的访问;另- .方面也可以帮助用户组织文件,并为用户提供安全性保护。
每个用户账号都拥有一个唯一的用户名和各自的密码。
用户在登录时输入正确的用户名和密码后,就能够进入系统和自己的主目录。
要想实现用户账号的管理,要完成的工作主要有如下几个方面:
用户账号的添加、删除、修改以及用密码的管理
用户组的管理
注意三个文件:
/etc/passwd 存储用户的关键信息
/etc/group 存储用户组的关键信息
/etc/shadow 存储用户的密码信息
1、用户管理
①添加用户
常用语法: #useradd 选项 用户名
常用选项:
-g: 表示指定用户的用户主组,选项的值可以是用户组的id, 也可以是组名
-G: 表示指定用户的用户附加组,选项的值可以是用户组的id, 也可以是组名
-u: uid, 用户的id (用户的标识符),系统默认会从500之后按顺序分配uid, 如果不想使用系统分配的,可以通过该选项自定义[类似于腾讯QQ的自选靓号情况]
-c:Comment 添加注释
案例: 创建用户zhangsan,不带任何选项
![]()
验证是否成功:
a.验证/etc/passwd的最后一行,查看是否有zhangsan的信息;
b.验证是否存在家目录(在Centos下创建好用户之后随之产生一个同名家目录);![]()
扩展认识passwd文件:

用户名:密码:用户ID:用户组ID:注释:家目录:解释器shell
用户名: 创建新用户名称,后期登录的时候需要输入;
密码: 此密码位置一般情况都是“x”,表示密码的占位;
用户ID: 用户的识别符;
用户组ID: 该用户所属的主组ID ;
注释: 解释该用户是做什么用的;
家目录: 用户登录进入系统之后默认的位置;
解释器shell: 等待用户进入系统之后,用户输入指令之后,该解释器会收集用户输入的指令,传递给内核处理;
注意: 在不添加选项的时候,执行useradd之后会执行一系列的操作
a.创建同名的家目录;
b.创建同名的用户组;
案例:添加选项,创建用户lisi,使lisi属于主组1001,附加组1000,自选靓号666
注意: 查看用户的主组可以查看passwd 文件,查看附加组可以查看group文件。
②修改用户
常用语法: #usermod 选项 用户名
常用选项:
-g: 表示指定用户的用户主组,选项的值可以是用户组的id, 也可以是组名
-G: 表示指定用户的用户附加组,选项的值可以是用户组的id, 也可以是组名
-u: uid, 用户的id (用户的标识符),系统默认会从1000之后按顺序分配uid, 如果不想使用系统分配的,可以通过该选项自定义[类似于腾讯QQ的自选靓号情况]
-l:修改用户名
案例: 修改zhangsan用户主组为1000,附加组改为1001
#usermod -g 1000 -G 1001 zhangsan
案例: 修改zhangsan用户用户名,改为wangerma
#usermod- I 新的用户名 旧的用户名
#usermod -l wangerma zhangsan

③设置密码
Linux不允许没有密码的用户登录到系统,因此前面创建的用户目前都处于锁定状态,需要设置密码之后才能登录计算机。
常用语法: #passwd 用户名
案例: 设置wangerma用户的密码

注意:密码须为大小写字母+数字组成,在设置密码的时候也是没有任何输入提示的,放心输入,确保两次输入的密码一-致,按下回车即可
也可以使用弱密码,但是不建议,否则会看到以下的提示:

设置密码之后shadow文件中的体现,能够看出lisi用户没有密码的
在设置用户密码之后可以登录帐号,例如此处需要登录wangerma
切换用户命令: #su [用户名] (switch user)
如果用户名不指定则表示切换到root用户。

切换用户需要注意的事项:
a.从root往普通用户切换不需要密码,但是反之则需要root密码;
b.切换用户之后前后的工作路径是不变的;
c.普通用户没有办法访问root用户家目录,但是反之则可以;
④删除用户
常用语法: #userdel 选项 用户名
常用选项:
-r: 表示删除用户的同时,删除其家目录;
案例: 删除wangerma用户

注意:已经登录的 wangerma 用户删除的吋候提示删除失败,但是没有登录的lisi 用户可以正常刪除。


解决办法: 筒单粗暴,kill対应用户的全部进程
2、用户组管理
每个用户都有一个用户组,系统可以对一个用户组中的所有用户进行集中管理。不同Linux系统对用户组的规定有所不同,如Linux下的用户属于与它同名的用户组,这个用户组在创建用户时同时创建。
用户组的管理涉及用户组的添加、删除和修改。组的增加、删除和修改、实际上就是对/etc/group文件的更新。
扩展认识group文件:

用户组名:密码:用户组ID:组内用户名
密码: x表示占位符,虽然用户组可以设置密码,但是绝大部分的情况下不设置密码;
组内用户名:表示附加组是该组的用户名称;
①用户组添加
常用语法: #groupadd 选项 用户组名
常用选项:
-g: 类似用户添加里的“-u”,-g 表示选择自己设置一个自定义的用户组ID数字,如果自己不指定,则默认从1000之后递增;
案例: 使用groupadd指令创建一个新的用户组,命名为Administrators

②用户组编辑
常用语法: #groupmod 选项 用户组名
常用选项:
-g: 类似用户修改里的“-u”, -g表示选择自己设置-一个自定义的用户组ID数字
-n: 类似于用户修改“1”,表示设置新的用户组的名称
案例 : 修改Administrators用户组,将组ID从1002改成1020,将名称改为admins

③用户组删除
常用语法: #groupdel 用户组名

注意: 当如果需要删除一 个组,但是这个组是某个用户的主组时,则不允许删除;如果确实需要删除,则先从组内移出所有用户。
