【Linux学习08】用户和用户组管理

1 Linux的运行级别

运行模式又称为运行级别
在Linux系统中存在一个进程:init,进程id为1
查看该进程:# ps -ef|grep init
【Linux学习08】用户和用户组管理
该进程存在一个对应的配置文件:inittab(系统运行级别配置文件,位置/etc/inittab)
【Linux学习08】用户和用户组管理
与级别相关的几个命令:init指令需要超级管理员的权限
# init 0:关机
# init 3:切换到不带桌面的模式
# init 5:切换到图形界面
# init 6:重启电脑

切换到纯命令模式:# init 3(临时模式,关机以后又回到桌面模式中)
【Linux学习08】用户和用户组管理
回到桌面模式:# init 5
【Linux学习08】用户和用户组管理
将命令运算符模式设为永久模式:
【Linux学习08】用户和用户组管理
【Linux学习08】用户和用户组管理
然后重启操作系统:
【Linux学习08】用户和用户组管理

2 用户管理

/etc/passwd:存储用户的关键信息
/etc/group:存储用户组的关键信息
/etc/shadow:存储用户的密码信息

2.1 添加用户

# user add 选项 用户名:添加用户
选项:
-g:表示指定用户的用户组,选项的值可以是用户组的id,也可以是组名
-G:表示指定用户的用户附加组,选项的值可以是用户的Id,也可以是组名
-u:uid,用户的id(用户的标识符),系统默认会从500之后按顺序分配uid,如果不想使用系统分配的,可以自定义
【Linux学习08】用户和用户组管理

案例:创建用户zhangsan,不带任何选项
【Linux学习08】用户和用户组管理
 验证是否成功:
  a. 验证/etc/passwd的最后一行,查看是否有zhangsan的信息;
  b. 验证是否存在家目录(在Centos下创建好用户之后随之产生一个同名家目录);
【Linux学习08】用户和用户组管理
 用户名:创建新用户名称,后期登录的时候需要输入;
 密码:此密码位置一般情况都是“x”,表示密码的占位;
 用户ID:用户的识别符;
 用户组ID:该用户所属的主组ID;
 注释:解释该用户是做什么用的;

案例:添加选项,创建用户lisi,让lisi属于500主组,附加组501,自选靓号666。
【Linux学习08】用户和用户组管理
 查看用户的附加组:/etc/group
【Linux学习08】用户和用户组管理
 查看用户的主组:/etc/passwd
【Linux学习08】用户和用户组管理

2.2 修改用户

#usermod 选项 用户名:修改用户(Usermod:user modify,用户修改)
常用选项:
-g:表示指定用户的用户主组,选项的值可以是用户组的id,也可以是组名
-G:表示指定用户的用户附加组,选项的值可以是用户组的id,也可以是组名
-u:uid,用户的id(用户的标识符),系统默认会从500之后按顺序分配uid,如果不想使用系统分配的,可以通过该选项自定义【类似于腾讯QQ的自选靓号情况】
-l:修改用户名

案例:修改zhangsan用户主组为500,附加组为501
【Linux学习08】用户和用户组管理
【Linux学习08】用户和用户组管理
 查看附加组:
【Linux学习08】用户和用户组管理
案例:修改zhangsan用户用户名,改为wanger
#usermod -l 新的用户名 旧的用户名
【Linux学习08】用户和用户组管理
【Linux学习08】用户和用户组管理

2.3 设置密码

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

案例:设置wanger用户的密码
【Linux学习08】用户和用户组管理
【Linux学习08】用户和用户组管理
在设置用户密码之后可以登录帐号,例如此处需要登录wanger
#su [用户名] :切换用户(switch user),如果用户名不指定则表示切换到root用户。
【Linux学习08】用户和用户组管理
【Linux学习08】用户和用户组管理
切换用户需要注意的事项:
 a. 从root往普通用户切换不需要密码,但是反之则需要root密码;
 b. 切换用户之后前后的工作路径是不变的;
 c. 普通用户没有办法访问root用户家目录,但是反之则可以;

2.4 删除用户

#userdel 选项 用户名:删除用户
常用选项:
-r:表示删除用户的同时,删除其家目录;

案例:删除wanger用户
【Linux学习08】用户和用户组管理
 注意:已经登录的wangerma用户删除的时候提示删除失败,但是没有登录的lisi用户可以正常删除。
 解决办法:简单粗暴,kill对应用户的全部进程
【Linux学习08】用户和用户组管理
【Linux学习08】用户和用户组管理
【Linux学习08】用户和用户组管理

3 用户组管理

每个用户都有一个用户组,系统可以对一个用户组中的所有用户进行集中管理。不同Linux 系统对用户组的规定有所不同,如Linux下的用户属于与它同名的用户组,这个用户组在创建用户时同时创建。
用户组的管理涉及用户组的添加、删除和修改。组的增加、删除和修改实际上就是对/etc/group文件的更新。

3.1 用户组添加

#groupadd 选项 用户组名:添加用户组
-g:类似用户添加里的“-u”,-g表示选择自己设置一个自定义的用户组ID数字,如果自己不指定,则默认从500之后递增;

案例:使用groupadd指令创建一个新的用户组,命名为Administrators
【Linux学习08】用户和用户组管理

3.2 修改用户组

#groupmod 选项 用户组名:修改用户组
常用选项:
-g:类似用户修改里的“-u”,-g表示选择自己设置一个自定义的用户组ID数字
-n:类似于用户修改“-l”,表示设置新的用户组的名称

案例:修改Administrators用户组,将组ID从502改成520,将名称改为admins
【Linux学习08】用户和用户组管理

3.3 删除用户组名

#groupdel 用户组名:删除用户组
【Linux学习08】用户和用户组管理
注意:当如果需要删除一个组,但是这个组是某个用户的主组时,则不允许删除;如果确实需要删除,则先从组内移出所有用户。
【Linux学习08】用户和用户组管理