Linux 常用命令 - userdel 【删除用户】

简介

userdel 这个命令源自于 "user delete",即用户删除。这个命令主要用于在 Linux 系统中删除用户账户及其相关文件。当管理员需要移除一个用户及其在系统中的所有踪迹时,会用到这个命令。

使用方式

shell 复制代码
userdel [选项] 用户名

常用参数

  • -f:强制删除用户,即使用户当前已登录。

  • -r:删除用户的同时,也删除用户的主目录和用户的邮件池。

  • -R:后跟一个目录名(CHROOT_DIR),表示在指定目录中执行 userdel 操作,并且使用指定目录下的配置文件。

  • -P:后跟一个目录名(PREFIX_DIR),表示在指定目录中执行 userdel 操作,并且使用指定目录下的配置文件。但该选项不会进行 chroot 操作,旨在为交叉编译目标准备环境。

  • -Z:删除与用户相关的 SELinux 用户映射。

  • --help:显示帮助信息。

相关文件

  • /etc/group:用户组信息。

  • /etc/login.defs:为 shadow 密码套件提供的配置信息。

  • /etc/passwd:用户账户信息。

  • /etc/shadow:用户账户的安全信息,包含密码的散列值及账户有效期等,只能由 root 账户读取。

  • /etc/subgid:存储每个用户辅助组ID信息。

  • /etc/subuid:存储每个用户的辅助用户ID信息。

命令返回值

使用 userdel 命令可能的返回值如下:

  • 0:成功。

  • 1:无法更新密码(用户信息)文件。这可能是因为密码文件(通常是 /etc/passwd 或 /etc/shadow)无法访问或修改。

  • 2:无效的命令语法。

  • 6:指定用户不存在。

  • 8:用户当前是登录状态。

  • 10:无法更新组文件。

  • 12:无法删除用户主目录。

参考示例

1.删除指定用户信息

shell 复制代码
userdel testuser

创建一个名为 testuser 的测试用户,并查看对应的用户信息确认创建成功。然后使用 userdel 指令删除测试用户,再次查看用户信息可以看到原有的用户信息已经不存在,确认删除成功:

c 复制代码
root@jaylinuxlenovo:~# useradd testuser
root@jaylinuxlenovo:~# cat /etc/passwd | grep testuser
testuser:x:1003:1003::/home/testuser:/bin/sh
root@jaylinuxlenovo:~# userdel testuser
root@jaylinuxlenovo:~# cat /etc/passwd | grep testuser
root@jaylinuxlenovo:~# 

2.删除指定用户信息与其主目录

shell 复制代码
userdel -r testuser

创建一个名为 testuser 的测试用户并为其创建主目录,查看 /home 目录下的所有目录可以看到 testuser 主目录创建成功。然后使用 userdel -r 命令删除用户信息及其主目录,再次查看 /home 目录,可以发现 testuser 目录已被成功删除,指令执行成功:

c 复制代码
root@jaylinuxlenovo:~# useradd -m testuser
root@jaylinuxlenovo:~# ls /home
jay  screeps  testuser
root@jaylinuxlenovo:~# userdel -r testuser
userdel: testuser mail spool (/var/mail/testuser) not found
root@jaylinuxlenovo:~# ls /home
jay  screeps
root@jaylinuxlenovo:~# 

注意事项

  • 在删除用户前,确保该用户没有正在运行的重要进程。
  • userdel 会修改几个重要的系统文件,以反映用户的删除。这些文件通常包括 /etc/passwd(存储用户账户信息)、/etc/shadow(存储加密的用户密码)、/etc/group(存储组信息)以及 /etc/gshadow(存储加密的组密码)。
  • 如果要删除的用户已经使用过系统一段时间,那么此用户可能在系统中留有其他文件,因此,如果我们想要从系统中彻底地删除某个用户,最好在使用 userdel 命令之前,先通过 find -user 用户名 命令查出系统中属于该用户的文件,然后再加以删除。
  • 对于系统用户(通常 UID < 1000),应谨慎使用 userdel,因为这可能影响系统的稳定性。
相关推荐
姬嘉晗-19期-河北工职大几秒前
在虚拟机的 Linux 系统(CentOS 7)中搭建一个「虚拟机本地网站」
linux·运维·centos
hkhkhkhkh1232 分钟前
Linux 内核三大核心结构体详解(驱动开发视角)
linux·数据结构·驱动开发·字符设备
Smile灬凉城6662 分钟前
TCP的四种计时器
运维·服务器·网络
R.lin2 分钟前
Docker核心原理详解
运维·docker·容器
广东大榕树信息科技有限公司6 分钟前
如何通过动环监控系统提升机房安全与管理效率?
运维·网络·物联网·国产动环监控系统·动环监控系统
怪我冷i6 分钟前
wsl Ubuntu切换中科大源
linux·windows·ubuntu·ai编程·ai写作
FenceRain6 分钟前
Linux 使用脚本删除文件
linux
QT 小鲜肉6 分钟前
【Linux命令大全】001.文件管理之chgrp命令(实操篇)
android·linux·运维·笔记
qq13267029406 分钟前
grafana 未授权访问漏洞设置iptables指定IP访问,拒绝其他所有IP
linux·服务器·网络·iptables·防火墙策略
春日见7 分钟前
ubuntu以前可以联网,突然无法上网了
linux·服务器·ubuntu·debug