--- title: linux 常用命令-用户和工作组管理 date: 2018/02/27 categories: - linux tags: - linux - command --- # linux 常用命令-用户和工作组管理 ## groupadd 用于创建一个新的工作组 ### 补充说明 **groupadd命令** 用于创建一个新的工作组,新工作组的信息将被添加到系统文件中。 ### 语法 ``` groupadd(选项)(参数) ``` ### 选项 ``` -g:指定新建工作组的id; -r:创建系统工作组,系统工作组的组ID小于500; -K:覆盖配置文件“/ect/login.defs”; -o:允许添加组ID号不唯一的工作组。 ``` ### 参数 组名:指定新建工作组的组名。 ### 实例 建立一个新组,并设置组ID加入系统: ``` groupadd -g 344 jsdigname ``` 此时在`/etc/passwd`文件中产生一个组ID(GID)是344的项目。 ## groupdel 用于删除指定的工作组 ### 补充说明 **groupdel命令** 用于删除指定的工作组,本命令要修改的系统文件包括/ect/group和/ect/gshadow。若该群组中仍包括某些用户,则必须先删除这些用户后,方能删除群组。 ### 语法 ``` groupdel(参数) ``` ### 参数 组:要删除的工作组名。 ### 实例 ``` groupadd damon //创建damon工作组 groupdel damon //删除这个工作组 ``` ## groupmod 更改群组识别码或名称 ### 补充说明 **groupmod命令** 更改群组识别码或名称。需要更改群组的识别码或名称时,可用groupmod指令来完成这项工作。 ### 语法 ``` groupmod(选项)(参数) ``` ### 选项 ``` -g<群组识别码>:设置欲使用的群组识别码; -o:重复使用群组识别码; -n<新群组名称>:设置欲使用的群组名称。 ``` ### 参数 组名:指定要修改的工作的组名。 ## useradd 创建的新的系统用户 ### 补充说明 **useradd命令** 用于Linux中创建的新的系统用户。useradd可用来建立用户帐号。帐号建好之后,再用passwd设定帐号的密码.而可用userdel删除帐号。使用useradd指令所建立的帐号,实际上是保存在`/etc/passwd`文本文件中。 在Slackware中,adduser指令是个script程序,利用交谈的方式取得输入的用户帐号资料,然后再交由真正建立帐号的useradd命令建立新用户,如此可方便管理员建立用户帐号。在Red Hat Linux中, **adduser命令** 则是useradd命令的符号连接,两者实际上是同一个指令。 ### 语法 ``` useradd(选项)(参数) ``` ### 选项 ``` -c<备注>:加上备注文字。备注文字会保存在passwd的备注栏位中; -d<登入目录>:指定用户登入时的启始目录; -D:变更预设值; -e<有效期限>:指定帐号的有效期限; -f<缓冲天数>:指定在密码过期后多少天即关闭该帐号; -g<群组>:指定用户所属的群组; -G<群组>:指定用户所属的附加群组; -m:自动建立用户的登入目录; -M:不要自动建立用户的登入目录; -n:取消建立以用户名称为名的群组; -r:建立系统帐号; -s:指定用户登入后所使用的shell; -u:指定用户id。 ``` ### 参数 用户名:要创建的用户名。 ### 实例 新建用户加入组: ``` useradd –g sales jack –G company,employees //-g:加入主要组、-G:加入次要组 ``` 建立一个新用户账户,并设置ID: ``` useradd caojh -u 544 ``` 需要说明的是,设定ID值时尽量要大于500,以免冲突。因为Linux安装后会建立一些特殊用户,一般0到499之间的值留给bin、mail这样的系统账号。 ## userdel 用于删除给定的用户以及与用户相关的文件 ### 补充说明 **userdel命令** 用于删除给定的用户,以及与用户相关的文件。若不加选项,则仅删除用户帐号,而不删除相关文件。 ### 语法 ``` userdel(选项)(参数) ``` ### 选项 ``` -f:强制删除用户,即使用户当前已登录; -r:删除用户的同时,删除与用户相关的所有文件。 ``` ### 参数 用户名:要删除的用户名。 ### 实例 userdel命令很简单,比如我们现在有个用户linuxde,其家目录位于`/var`目录中,现在我们来删除这个用户: ``` userdel linuxde //删除用户linuxde,但不删除其家目录及文件; userdel -r linuxde //删除用户linuxde,其家目录及文件一并删除; ``` 请不要轻易用`-r`选项;他会删除用户的同时删除用户所有的文件和目录,切记如果用户目录下有重要的文件,在删除前请备份。 其实也有最简单的办法,但这种办法有点不安全,也就是直接在`/etc/passwd`中删除您想要删除用户的记录;但最好不要这样做,`/etc/passwd`是极为重要的文件,可能您一不小心会操作失误。 ## usermod 用于修改用户的基本信息 ### 补充说明 **usermod命令** 用于修改用户的基本信息。usermod命令不允许你改变正在线上的使用者帐号名称。当usermod命令用来改变user id,必须确认这名user没在电脑上执行任何程序。你需手动更改使用者的crontab档。也需手动更改使用者的at工作档。采用NIS server须在server上更动相关的NIS设定。 ### 语法 ``` usermod(选项)(参数) ``` ### 选项 ``` -c<备注>:修改用户帐号的备注文字; -d<登入目录>:修改用户登入时的目录; -e<有效期限>:修改帐号的有效期限; -f<缓冲天数>:修改在密码过期后多少天即关闭该帐号; -g<群组>:修改用户所属的群组; -G<群组>;修改用户所属的附加群组; -l<帐号名称>:修改用户帐号名称; -L:锁定用户密码,使密码无效; -s:修改用户登入后所使用的shell; -u:修改用户ID; -U:解除密码锁定。 ``` ### 参数 登录名:指定要修改信息的用户登录名。 ### 实例 将newuser2添加到组staff中: ``` usermod -G staff newuser2 ``` 修改newuser的用户名为newuser1: ``` usermod -l newuser1 newuser ``` 锁定账号newuser1: ``` usermod -L newuser1 ``` 解除对newuser1的锁定: ``` usermod -U newuser1 ``` ## passwd 用于让用户可以更改自己的密码 ### 补充说明 **passwd命令** 用于设置用户的认证信息,包括用户密码、密码过期时间等。系统管理者则能用它管理系统用户的密码。只有管理者可以指定用户名称,一般用户只能变更自己的密码。 ### 语法 ``` passwd(选项)(参数) ``` ### 选项 ``` -d:删除密码,仅有系统管理者才能使用; -f:强制执行; -k:设置只有在密码过期失效后,方能更新; -l:锁住密码; -s:列出密码的相关信息,仅有系统管理者才能使用; -u:解开已上锁的帐号。 ``` ### 参数 用户名:需要设置密码的用户名。 ### 知识扩展 与用户、组账户信息相关的文件 存放用户信息: ``` /etc/passwd /etc/shadow ``` 存放组信息: ``` /etc/group /etc/gshadow ``` 用户信息文件分析(每项用`:`隔开) ``` 例如:jack:X:503:504:::/home/jack/:/bin/bash jack  //用户名 X  //口令、密码 503  //用户id(0代表root、普通新建用户从500开始) 504  //所在组 :  //描述 /home/jack/  //用户主目录 /bin/bash  //用户缺省Shell ``` 组信息文件分析 ``` 例如:jack:$!$:???:13801:0:99999:7:*:*: jack  //组名 $!$  //被加密的口令 13801  //创建日期与今天相隔的天数 0  //口令最短位数 99999  //用户口令 7  //到7天时提醒 *  //禁用天数 *  //过期天数 ``` ### 实例 如果是普通用户执行passwd只能修改自己的密码。如果新建用户后,要为新用户创建密码,则用passwd用户名,注意要以root用户的权限来创建。 ``` [root@localhost ~]# passwd linuxde //更改或创建linuxde用户的密码; Changing password for user linuxde. New UNIX password: //请输入新密码; Retype new UNIX password: //再输入一次; passwd: all authentication tokens updated successfully. //成功; ``` 普通用户如果想更改自己的密码,直接运行passwd即可,比如当前操作的用户是linuxde。 ``` [linuxde@localhost ~]$ passwd Changing password for user linuxde. //更改linuxde用户的密码; (current) UNIX password: //请输入当前密码; New UNIX password: //请输入新密码; Retype new UNIX password: //确认新密码; passwd: all authentication tokens updated successfully. //更改成功; ``` 比如我们让某个用户不能修改密码,可以用`-l`选项来锁定: ``` [root@localhost ~]# passwd -l linuxde //锁定用户linuxde不能更改密码; Locking password for user linuxde. passwd: Success //锁定成功; [linuxde@localhost ~]# su linuxde //通过su切换到linuxde用户; [linuxde@localhost ~]$ passwd //linuxde来更改密码; Changing password for user linuxde. Changing password for linuxde (current) UNIX password: //输入linuxde的当前密码; passwd: Authentication token manipulation error //失败,不能更改密码; ``` 再来一例: ``` [root@localhost ~]# passwd -d linuxde //清除linuxde用户密码; Removing password for user linuxde. passwd: Success //清除成功; [root@localhost ~]# passwd -S linuxde //查询linuxde用户密码状态; Empty password. //空密码,也就是没有密码; ``` 注意:当我们清除一个用户的密码时,登录时就无需密码,这一点要加以注意。 ## su 用于切换当前用户身份到其他用户身份 ### 补充说明 **su命令** 用于切换当前用户身份到其他用户身份,变更时须输入所要变更的用户帐号与密码。 ### 语法 ``` su(选项)(参数) ``` ### 选项 ``` -c<指令>或--command=<指令>:执行完指定的指令后,即恢复原来的身份; -f或——fast:适用于csh与tsch,使shell不用去读取启动文件; -l或——login:改变身份时,也同时变更工作目录,以及HOME,SHELL,USER,logname。此外,也会变更PATH变量; -m,-p或--preserve-environment:变更身份时,不要变更环境变量; -s或--shell=:指定要执行的shell; --help:显示帮助; --version;显示版本信息。 ``` ### 参数 用户:指定要切换身份的目标用户。 ### 实例 变更帐号为root并在执行ls指令后退出变回原使用者: ``` su -c ls root ``` 变更帐号为root并传入`-f`选项给新执行的shell: ``` su root -f ``` 变更帐号为test并改变工作目录至test的家目录: ``` su -test ```