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,因为这可能影响系统的稳定性。
相关推荐
尽兴-8 分钟前
如何将多个.sql文件合并成一个:Windows和Linux/Mac详细指南
linux·数据库·windows·sql·macos
kfepiza9 分钟前
Netplan 中 bridges、bonds、ethernets、vlans 之间的关系 笔记250711
linux·tcp/ip·shell
小小不董26 分钟前
深入理解oracle ADG和RAC
linux·服务器·数据库·oracle·dba
狄加山6751 小时前
Cadence模块复用
服务器·硬件架构·硬件工程·信号处理·智能硬件
宇钶宇夕1 小时前
SIMATIC S7-1200的以太网通信能力:协议与资源详细解析
运维·服务器·数据库·程序人生·自动化
该用户已不存在2 小时前
关于我把Mac Mini托管到机房,后续来了,还有更多玩法
服务器·前端·mac
杰夫贾维斯2 小时前
CentOS Linux 8 的系统部署 Qwen2.5-7B -Instruct-AWQ
linux·运维·人工智能·机器学习·centos
%d%d22 小时前
python 在运行时没有加载修改后的版本
java·服务器·python
kfepiza2 小时前
Netplan 配置网桥(Bridge)的模板笔记250711
linux·tcp/ip·ubuntu