用户与用户组管理
实现用户账号的管理,要完成的工作主要有如下几个方面:
- 用户账号的添加、删除、修改以及用户密码的管理。
- 用户组的管理。
注意三个文件:
文件名 | 作用 |
---|---|
/etc/passwd | 存储用户的关键信息 |
/etc/group | 存储用户组的关键信息 |
/etc/shadow | 存储用户的密码信息 |
用户管理
查询用户信息
基本语法id 用户名
案例:查询 root 信息
添加用户
常用语法:#useradd 选项 用户名
常用选项:
选项 | 作用 |
---|---|
-g | 表示指定用户的用户主组,选项的值可以是用户组的id,也可以是组名 |
-G | 表示指定用户的用户附加组,选项的值可以是用户组的id,也可以是组名 |
-u | uid,用户的id(用户的标识符),系统默认会从500之后按顺序分配uid,如果不想使用系统分配的,可以通过该选项自定义 |
-c | comment:添加注释 |
- 案例:创建用户zhangsan,不带任何选项
验证是否成功:- 验证/etc/passwd的最后一行,查看是否有zhangsan的信息;
- 验证是否存在家目录(在Centos下创建好用户之后随之产生一个同名家目录);
扩展:认识passwd文件
用户名:密码:用户ID:用户组ID:注释:家目录:解释器shell
命名 | 解释 |
---|---|
用户名: | 创建新用户名称,后期登录的时候需要输入; |
密码: | 此密码位置一般情况都是“x”,表示密码的占位; |
用户ID: | 用户的识别符; |
用户组ID: | 该用户所属的主组ID; |
注释: | 解释该用户是做什么用的; |
家目录: | 用户登录进入系统之后默认的位置; |
解释器shell: | 等待用户进入系统之后,用户输入指令之后,该解释器会收集用户输入的指令,传递给内核处理; |
注意:在不添加选项的时候,执行useradd之后会执行一系列的操作
a. 创建同名的家目录;
b. 创建同名的用户组;
- 案例:添加选项,创建用户lisi,让lisi属于501主组,附加组500,自选靓号666。
注意:查看用户的主组可以查看passwd文件,查看附加组可以查看group文件。
修改用户
常用语法:#usermod 选项 用户名
Usermod:user modify,用户修改
常用选项:
选项 | 作用 |
---|---|
-g | 表示指定用户的用户主组,选项的值可以是用户组的id,也可以是组名 |
-G | 表示指定用户的用户附加组,选项的值可以是用户组的id,也可以是组名 |
-u | uid,用户的id(用户的标识符),系统默认会从500之后按顺序分配uid,如果不想使用系统分配的,可以通过该选项自定义 |
-l | 修改用户名 |
-
案例:修改zhangsan用户主组为500,附加组改为501
#usermod -g 500 -G 501 zhangsan -
案例:修改zhangsan用户用户名,改为wangerma
#usermod -l 新的用户名 旧的用户名
#usermod -l wangerma zhangsan
设置密码
Linux不允许没有密码的用户登录到系统,因此前面创建的用户目前都处于锁定状态,需要设置密码之后才能登录计算机。
常用语法:#passwd 用户名
案例:设置wangerma用户的密码
切换用户命令:#su [用户名] (switch user)
如果用户名不指定则表示切换到root用户。
切换用户需要注意的事项:
- 从root往普通用户切换不需要密码,但是反之则需要root密码;
- 切换用户之后前后的工作路径是不变的;
- 普通用户没有办法访问root用户家目录,但是反之则可以;
删除用户
常用语法:#userdel 选项 用户名
Userdel:user delete(用户删除)
常用选项:
选项 | 作用 |
---|---|
-r | 表示删除用户的同时,删除其家目录; |
案例:删除wangerma用户
注意:已经登录的wangerma用户删除的时候提示删除失败,但是没有登录的lisi用户可以正常删除。
解决办法:简单粗暴,kill对应用户的全部进程
提示:所有跟用户操作的命令(除passwd外)只有root超级管理员有权限执行。
用户组管理
- 每个用户都有一个用户组,系统可以对一个用户组中的所有用户进行集中管理。不同Linux 系统对用户组的规定有所不同,如Linux下的用户属于与它同名的用户组,这个用户组在创建用户时同时创建。
- 组的增加、删除和修改实际上就是对/etc/group文件的更新。
文件结构:
用户组名:密码:用户组ID:组内用户名
命名 | 解释 |
---|---|
密码 | X表示占位符,虽然用户组可以设置密码,但是绝大部分的情况下不设置密码; |
组内用户名 | 表示附加组是该组的用户名称; |
用户组添加
常用语法:#groupadd 选项 用户组名
常用选项:
选项 | 作用 |
---|---|
-g | 类似用户添加里的“-u”,-g表示选择自己设置一个自定义的用户组ID数字,如果自己不指定,则默认从500之后递增; |
案例:使用groupadd指令创建一个新的用户组,命名为Administrators
用户组编辑
常用语法:#groupmod 选项 用户组名
常用选项:
选项 | 作用 |
---|---|
-g | 类似用户修改里的“-u”,-g表示选择自己设置一个自定义的用户组ID数字 |
-n | 类似于用户修改“-l”,表示设置新的用户组的名称 |
案例:修改Administrators用户组,将组ID从502改成520,将名称改为admins
用户组删除
常用语法:#groupdel 用户组名
注意:当如果需要删除一个组,但是这个组是某个用户的主组时,则不允许删除;如果确实需要删除,则先从组内移出所有用户。