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,因为这可能影响系统的稳定性。
相关推荐
岚天start29 分钟前
Linux内核coredump分析方案
linux·运维·服务器·gdb·coredump·堆栈·内存快照
屁股割了还要学1 小时前
【Linux入门】常用工具:yum、vim
linux·运维·服务器·c语言·c++·学习·考研
云计算练习生1 小时前
linux shell编程实战 03 数组:批量处理数据
linux·运维·服务器·数组·shell编程
王道长服务器 | 亚马逊云1 小时前
AWS Elemental MediaConvert:视频转码不再难
linux·服务器·网络·云计算·音视频·aws
Jm_洋洋1 小时前
【Linux系统编程】程序替换:execve(execl、execlp、execle、execv、execvp、execvpe)
linux·运维·c语言·开发语言·程序人生
qq_479875431 小时前
TCP网络编程本质
服务器·网络·tcp/ip
HIT_Weston1 小时前
14、【Ubuntu】【VSCode】VSCode 断联问题分析:hostname(二)
linux·vscode·ubuntu
冲上云霄的Jayden2 小时前
bash执行脚本 CondaError: Run ‘conda init‘ before ‘conda activate‘
linux·ubuntu·conda·bash·init·activate
驱动探索者2 小时前
影石Insta360发展史:从深圳公寓到全球影像创新标杆
linux
Wang's Blog2 小时前
Linux小课堂: SSH 免密登录原理与实现之基于公钥认证的安全连接机制
linux·安全·ssh