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
相关推荐
uesowys3 分钟前
CentOS Linux安装部署OpenClaw
linux·centos·安装部署openclaw
IMPYLH14 分钟前
Linux 的 rm 命令
linux·运维·服务器·网络·bash
YIN_尹30 分钟前
【Linux系统编程】进程地址空间
linux·c++
white-persist1 小时前
【vulhub shiro 漏洞复现】vulhub shiro CVE-2016-4437 Shiro反序列化漏洞复现详细分析解释
运维·服务器·网络·python·算法·安全·web安全
代码中介商2 小时前
手把手教你Linux 打包压缩与 gcc 编译详解
linux·运维·服务器·编译·打包·压缩
longerxin20202 小时前
阿里云AlmaLinux操作系统允许root登录配置步骤
linux·服务器·阿里云
独小乐2 小时前
019.ADC转换和子中断|千篇笔记实现嵌入式全栈/裸机篇
linux·c语言·驱动开发·笔记·嵌入式硬件·mcu·arm
HYNuyoah2 小时前
docker 安装win10系统
运维·docker·容器
liulilittle2 小时前
Prompt for OpenCode + CodeX-5.3:多个重型任务交付给AI自动化完成
运维·自动化·prompt
GottdesKrieges2 小时前
OceanBase租户级物理恢复
linux·oceanbase