摘要:本文主要学习了在Linux系统中管理用户和用户组的命令。shell
useradd命令能够用来建立新用户。bash
1 [root@localhost ~]# useradd [选项] 用户名
1 -u num:num是数字,手工指定用户的UID,注意num的范围不要小于500。 2 -d name:name是目录名,手工指定用户的主目录。主目录必须写绝对路径,并且若是须要手工指定主目录,则必定要注意权限。 3 -c description:description是描述,手工指定/etc/passwd文件中各用户信息中第五个字段的描述性内容,可随意配置。 4 -g name:name是目录名,手工指定用户的初始组。通常以和用户名相同的组做为用户的初始组,在建立用户时会默认创建初始组。一旦手动指定,则系统将不会在建立此默认的初始组目录。 5 -G name:name是目录名,指定用户的附加组。咱们把用户加入其余组,通常都使用附加组。 6 -s shell:shell是脚本文件名,手工指定用户的登陆Shell,默认是/bin/bash。 7 -e date:date是日期,指定用户的失效日期,格式为“YYYY-MM-DD”。也就是/etc/shadow文件的第八个字段; 8 -o:容许建立的用户的UID相同。 9 -m:创建用户时强制创建用户的家目录。在创建系统用户时,该选项是默认的。 10 -r:建立系统用户,也就是UID在1~499之间,供系统程序使用的用户。因为系统用户主要用于运行系统所需服务的权限配置,所以系统用户的建立默认不会建立主目录。
1 [root@localhost ~]# useradd sam -G root 2 [root@localhost ~]# cat /etc/passwd 3 root:x:0:0:root:/root:/bin/bash 4 bin:x:1:1:bin:/bin:/sbin/nologin 5 ... 6 sam:x:1000:1000::/home/sam:/bin/bash 7 [root@localhost ~]# cat /etc/group 8 root:x:0:sam 9 bin:x:1: 10 ... 11 sam:x:1000: 12 [root@localhost ~]#
使用passwd命令设置密码。学习
1 [root@localhost ~]# passwd [选项] 用户名
1 -S:查询用户密码的状态,也就是/etc/shadow文件中此用户密码的内容,仅root用户可用。 2 -l:暂时锁定用户,该选项会在/etc/shadow文件中指定用户的加密密码串前添加“!”,使密码失效,仅root用户可用。 3 -u:解锁用户,和-l选项相对应,仅root用户使用。 4 -d:删除已命名账号的密码,仅root用户可用。 5 -k:保持身份验证令牌不过时。 6 -f:强制执行操做。 7 -n num:num为数字,设置该用户修改密码后,多长时间不能再次修改密码,对应/etc/shadow文件中各行密码的第四个字段。 8 -x num:num为数字,设置该用户的密码有效期,对应/etc/shadow文件中各行密码的第五个字段。 9 -w num:num为数字,设置用户密码过时前的警告天数,对应/etc/shadow文件中各行密码的第六个字段。 10 -i date:date为日期,设置用户密码失效日期,对应/etc/shadow文件中各行密码的第七个字段。
1 [root@localhost ~]# passwd sam 2 更改用户 sam 的密码 。 3 新的 密码: 4 无效的密码: 密码未经过字典检查 - 过于简单化/系统化 5 从新输入新的 密码: 6 passwd:全部的身份验证令牌已经成功更新。 7 [root@localhost ~]#
usermod命令用于修改用户信息。ui
1 [root@localhost ~]# usermod [选项] 用户名
1 -c comment:comment是说明信息,修改用户的说明信息,即修改/etc/passwd文件目标用户信息的第五个字段。 2 -d name:name是目录名,修改用户的主目录,即修改/etc/passwd文件中目标用户信息的第六个字段,须要注意的是,主目录必须写绝对路径。 3 -e date:date是日期,修改用户的失效曰期,格式为"YYYY-MM-DD",即修改/etc/shadow文件目标用户密码信息的第八个字段。 4 -g name:name是组名,修改用户的初始组,即修改/etc/passwd文件目标用户信息的第四个字段(GID)。 5 -u num:num是数字,修改用户的UID,即修改/etc/passwd文件目标用户信息的第三个字段(UID)。 6 -G name:name是组名,修改用户的附加组,其实就是把用户加入其余用户组,即修改/etc/group文件。 7 -l name:name是用户名,修改用户名称。 8 -L:临时锁定用户(Lock)。 9 -U:解锁用户(Unlock),和-L对应。 10 -s shell:shell是脚本文件名,修改用户的登陆Shell,默认是/bin/bash。
1 [root@localhost ~]# usermod -G root lisa 2 [root@localhost ~]# cat /etc/group 3 root:x:0:lisa 4 bin:x:1: 5 ... 6 [root@localhost ~]#
userdel命令功能很简单,就是删除用户的相关数据。此命令只有root用户才能使用。加密
1 [root@localhost ~]# userdel [选项] 用户名
1 -r:表示在删除用户的同时删除用户的家目录。
1 [root@localhost ~]# userdel lisa 2 [root@localhost ~]# cat /etc/passwd 3 root:x:0:0:root:/root:/bin/bash 4 bin:x:1:1:bin:/bin:/sbin/nologin 5 ... 6 [root@localhost ~]#
id命令能够查询用户的UID、GID和附加组的信息。spa
1 [root@localhost ~]# id 用户名
1 [root@localhost ~]# id root 2 uid=0(root) gid=0(root) 组=0(root) 3 [root@localhost ~]#
su命令是最简单的用户切换命令,经过该命令能够实现任何身份的切换,包括从普通用户切换为root用户、从root用户切换为普通用户以及普通用户之间的切换。code
普通用户之间切换以及普通用户切换至root用户,都须要知晓对方的密码,只有正确输入密码,才能实现切换;从root用户切换至其余用户,无需知晓对方密码,直接可切换成功。blog
1 [root@localhost ~]# su [选项] 用户名
1 -:当前用户不只切换为指定用户的身份,同时所用的工做环境也切换为此用户的环境(包括PATH变量、MAIL变量等),使用-选项可省略用户名,默认会切换为root用户。 2 -l:同-的使用相似,也就是在切换用户身份的同时,完整切换工做环境,但后面须要添加欲切换的使用者帐号。 3 -p:表示切换为指定用户的身份,但不改变当前的工做环境,即不使用切换用户的配置文件。 4 -m:和-p同样。 5 -c command:command为命令,仅切换用户执行一次命令,执行后自动切换回来,该选项后一般会带有要执行的命令。
1 [root@localhost ~]# su - sam 2 上一次登陆:四 7月 11 08:43:12 CST 2019pts/0 上 3 [sam@localhost ~]$ su - 4 密码: 5 上一次登陆:四 7月 11 09:06:21 CST 2019pts/2 上 6 [root@localhost ~]#
groupadd命令用来添加用户组。ip
1 [root@localhost ~]# groupadd [选项] 组名
1 -g n:n是数字,指定组ID。 2 -r:建立系统群组。
1 [root@localhost ~]# groupadd test 2 [root@localhost ~]# cat /etc/group 3 root:x:0: 4 bin:x:1: 5 ... 6 test:x:1001: 7 [root@localhost ~]#
能够使用gpasswd命令给群组设置一个群组管理员,代替root完成将用户加入或移出群组的操做。io
1 [root@localhost ~]# gpasswd [选项] 组名
1 :选项为空时,表示给群组设置密码,仅root用户可用。 2 -A user1,...:将群组的控制权交给user1,...等用户管理,也就是说,设置user1,...等用户为群组的管理员,仅root用户可用。 3 -M user1,...:将user1,...加入到此群组中,仅root用户可用。 4 -r:移除群组的密码,仅root用户可用。 5 -R:让群组的密码失效,仅root用户可用。 6 -a user:将user用户加入到群组中。 7 -d user:将user用户从群组中移除。
1 [root@localhost ~]# gpasswd -M sam test 2 [root@localhost ~]# cat /etc/group 3 root:x:0: 4 bin:x:1: 5 ... 6 test:x:1001:sam 7 [root@localhost ~]#
groupmod命令用于修改用户组的相关信息。
1 [root@localhost ~]# groupmod [选项] 组名
1 -g n:n是数字,修改组ID。 2 -n name:name是组名,修改组名。
1 [root@localhost ~]# groupmod -g 1002 test 2 [root@localhost ~]# cat /etc/group 3 root:x:0: 4 bin:x:1: 5 ... 6 test:x:1002: 7 [root@localhost ~]#
groupdel命令用于删除用户组。
1 [root@localhost ~]# groupdel 组名
1 [root@localhost ~]# groupdel test 2 [root@localhost ~]# cat /etc/group 3 root:x:0:sam 4 bin:x:1: 5 ... 6 [root@localhost ~]#