Linux命令大全-usermod命令

一、简介

usermod(英文全拼:user modify)命令用于修改用户的一些参数。比如创建的用户有一些参数写错了,就不需要删除用户再进行创建,可以使用该命令直接修改成用户正常的参数。

二、语法

**语法:**usermod [选项] 登录(用户)

参数说明:

-a:将用户添加至扩展组中

-c:<备注> 修改用户的备注信息

-m:将用户家目录内容移动到新位置

-d:<登入目录> 修改用户登录时的家目录

-o:允许重复的用户ID

-e:<有效期限> 修改用户的有效期限

-p:设置用户的新密码

-f:<缓冲天数> 设置在密码过期多少天后关闭该用户

-s:<shell> 修改用户登入后所使用的shell

-g:<群组> 修改用户所属的群组

-G:<群组> 修改用户所属的附加群组

-u:<uid> 修改用户的ID

-U:解除密码锁定,使密码恢复正常

-l:<帐号名称> 修改用户名称

-L:锁定用户密码,使密码立即失效

三、实战

1 、更改一个用户的家目录

bash 复制代码
[root@app01 home]# cat /etc/passwd|grep tom
tom:x:1002:1002::/home/tom:/bin/bash
[root@app01 home]# usermod -d /app/tom tom
[root@app01 home]# cat /etc/passwd|grep tom
tom:x:1002:1002::/app/tom:/bin/bash

修改完成tom用户家目录之后,使用root用户切换到tom用户后,有时会报如下错误:

1.切换用户错误:

su: 警告:无法更改到 /app/tom 目录: 没有那个文件或目录

2.用户登录错误:

Could not chdir to home directory /app/tom: No such file or directory

这是因为新更改的家目录不存在造成的,在对应的目录下创建好对应家目录,并把家目录的用户所属权限(用户和组)修改成对应用户的权限的即解决以上的报错信息。

解决完以上问题后,大家可能会发现,登陆后或切换后用户发现用户登录提示为-bash-4.2,而不是\[tom@app01 \~\]。如下所示:

bash 复制代码
[root@app01 app]# su - tom
上一次登录:六 8月 23 21:18:28 CST 2025pts/0 上
-bash-4.2$

这是因为用户的".bash_logout、.bash_profile、.bashrc或.bash*"文件丢失造成,可以从原来的家目录下的文件复制到修改后的家目录中,也可以从/etc/skel目录把".bash_logout、.bash_profile、.bashrc或.bash*"复制到修改后的家目录中,重新登陆即可。

注:复制完成之后,记得把对应的文件用户所属权限(用户和组)修改成对应用户的权限。

2 、修改用户的用户id

bash 复制代码
[root@app01 app]# id tom
uid=1002(tom) gid=1002(tom) 组=1002(tom)
[root@app01 app]# usermod -u 1003 tom
[root@app01 app]# id tom
uid=1003(tom) gid=1002(tom) 组=1002(tom)

如果有用该用户启动一些程序,或是用户有登录且没有退出,是不能修改,修改时会报以下错误。

bash 复制代码
[root@app01 app]# usermod -u 1003 tom
usermod: user tom is currently used by process 2493

在日常的工作中,有可能会同时修改用户所属的组和附属组,此时大家可以用"-g"和"-G"来组合完成。如下:

bash 复制代码
[root@app01 app]# id tom1
uid=1002(tom1) gid=1002(tom) 组=1002(tom)
[root@app01 app]# usermod -g app -G app tom1
[root@app01 app]# id tom1
uid=1002(tom1) gid=1000(app) 组=1000(app)

有时会在原来的组中增加用户组。如下:

bash 复制代码
[root@app01 app]# usermod -aG tom tom1
[root@app01 app]# id tom1
uid=1002(tom1) gid=1000(app) 组=1000(app),1002(tom)

其中"-G"是修改,"-a"是在原来的附属组中进行新增,在目常工作中要根据实际情况进行更改,避免出现修改错误的情况发生。

3 、修改用户名称

bash 复制代码
[root@app01 app]# usermod -l tom1 tom
[root@app01 app]# id tom
id: tom: no such user
[root@app01 app]# id tom1
uid=1002(tom1) gid=1002(tom) 组=1002(tom)

修改用户名称时,新用户名称在前,旧用户名称在后,如果写返会提示用户不存在的错误。如下:

bash 复制代码
[root@app01 app]# usermod -l tom tom1
usermod:用户"tom1"不存在

注:用户名称修改完成之后,用户的家目录名称是不会修改的。

4 、锁定用户,临时不用登陆

bash 复制代码
[root@app01 app]# usermod -L tom

5 、解锁用户,可以再次登录

bash 复制代码
[root@app01 app]# usermod -U tom
相关推荐
欲掩7 小时前
Shell脚本
linux
Lynnxiaowen7 小时前
今天继续学习nginx服务部署与配置
linux·运维·服务器·学习·nginx
程序员大辉7 小时前
请卸载xshell,一款国产的终端工具,界面漂亮,功能强大,支持win,mac,linux平台,安全免费
linux·运维·macos
NetX行者7 小时前
在windows 10系统上使用WSL安装Ubuntu系统并配置开发环境
linux·windows·python·ubuntu·wsl
会飞的小蛮猪7 小时前
Jenkins运维之路(初次调试共享库)
运维·经验分享·docker·容器·jenkins
深思慎考8 小时前
LinuxC++项目开发日志——基于正倒排索引的boost搜索引擎(3——通过cppjieba库建立索引模块)
linux·c++·搜索引擎
心随雨下8 小时前
Liunx系统下出现“Could not resolve host: mirrorlist.centos.org; 未知的错误”地解决方案
linux·python·centos
?LAST8 小时前
虚拟机Ubuntu挂载共享文件夹
linux·ubuntu
TonyEm8 小时前
linux ubuntu 20 命令行 安装Java25
linux·运维·ubuntu