USERDEL(8) | 系统管理命令 | USERDEL(8) |
名称¶
userdel - 删除用户账户和相关文件
大纲¶
userdel [选项] 登录
描述¶
userdel 修改系统账户文件,删除与用户名 LOGIN 相关的所以项目。给出的用户名必须存在。
选项¶
userdel 可以使用的选项有:
-f, --force
注意:此选项危险,可能会破坏系统的稳定性。
-h, --help
-r, --remove
邮箱在 login.defs 文件中的 MAIL_DIR 变量中定义。
-R, --rootCHROOT_DIR
-Z, --selinux-user
配置文件¶
在 /etc/login.defs 中有如下配置变量,可以用来更改此工具的行为:
MAIL_DIR (string)
MAIL_FILE (string)
MAIL_DIR and MAIL_FILE 变量由 useradd,usermod 和 userdel 用于创建、移动或删除用户邮箱。
如果 MAIL_CHECK_ENAB 设置为 yes,它们也被用于定义 MAIL 环境变量。
MAX_MEMBERS_PER_GROUP (number)
默认值是 0,意味着组中的成员数没有限制。
此功能(分割组)允许限制组文件中的行长度。这对于确保 NIS 组的行比长于 1024 字符。
如果要强制这个限制,可以使用 25。
注意:分割组可能不受所有工具的支持(甚至在 Shadow 工具集中)。您不应该使用这个变量,除非真的需要。
USERDEL_CMD (string)
这个脚本的返回值并不被带到账户中去。
这是一个示例脚本,它移除用户的 cron、at 和 print 作业:
#! /bin/sh # 检查需要的参数 if [ $# != 1 ]; then echo "Usage: $0 username" exit 1 fi # 移除 cron 作业 crontab -r -u $1 # 移除 at 作业 # 注意这将移除所有属于同一个 UID 的作业 # 即使此 ID 由多个用户名共享 AT_SPOOL_DIR=/var/spool/cron/atjobs find $AT_SPOOL_DIR -name "[^.]*" -type f -user $1 -delete \; # 移除 print 作业 lprm $1 # 全部完成 exit 0
USERGROUPS_ENAB (boolean)
如果设置为 yes,如果组中没有成员了,userdel 将移除此用户组,useradd 创建用户时,也会创建一个同名的默认组。
文件¶
/etc/group
/etc/login.defs
/etc/passwd
/etc/shadow
退出值¶
userdel 命令使用如下值退出:.PP 0
1
2
6
8
10
12
CAVEATS¶
如果某账户有正在运行的进程,userdel 不会允许此账户。此时,您可能必须要杀死那写进程或者锁定用户的密码和账户,并稍后再删除账户。-f 选项可以强制此删除账户。
您应该手动检查所以文件系统,以确保没有遗留此用户的文件。
您不能在 NIS 客户端上移除任何 NIS 属性。这必须在 NIS 服务器上执行。
如果在 /etc/login.defs 中 USERGROUPS_ENAB 设置为 yes, userdel 将删除同名组。为了避免损坏 passwd 和 group 数据库,userdel 将会检查这个主是否被别的用户用作主组,如果有,将只发出警告并不删除此组。-f 选项可以强制删除此组。
参见¶
chfn(1), chsh(1), passwd(1), login.defs(5), gpasswd(8), groupadd(8), groupdel(8), groupmod(8), useradd(8), usermod(8).
2016-05-11 | shadow-utils 4.1.5.1 |