Linux useradd命令详解

useradd 是 Linux 系统中用于创建新用户的底层命令。与交互式命令 adduser 不同,useradd 主要通过命令行参数来完成所有设置,因此非常适合在脚本中自动化执行。

⚙️ 基础语法

命令的基础格式是:useradd [选项] 用户名。执行此命令需要 root 或具有 sudo 权限的用户。

🛠️ 核心选项详解

下表整理了 useradd 最常用的选项:

选项 说明
-m 创建家目录 。这是最常用的选项之一,会在 /home/ 下为用户创建一个独立的目录。不加此选项,用户默认没有家目录。
-d 指定家目录路径。用于自定义家目录的位置。
-s 指定登录 Shell 。例如 /bin/bash。如果省略,通常会被分配一个默认的Shell,如 /bin/sh。
-c 添加用户描述。通常用于填写用户的全名或备注信息,方便管理。
-g 指定主组。用户登录后默认所属的组,该组必须已存在。如不指定,系统通常会创建一个与用户名同名的新组。
-G 指定附加组。将用户添加到多个已存在的组中,获得这些组的权限,组名之间用逗号分隔。
-u 指定用户 ID (UID)。为账户手动分配一个唯一的数字标识。不指定时系统会自动分配。
-e 设置账户过期日期 。格式为 YYYY-MM-DD,账户到期后将自动被锁定。
-f 设置密码过期后的宽限期。密码过期后,账户还能被使用的天数,之后将被锁定。
-r 创建系统账户。用于创建UID在系统范围(通常是1-999)的服务账户,一般不创建家目录。
-M 不创建家目录。即使系统配置默认创建,也可用此选项显式禁止。

📂 关联配置文件

useradd 命令的行为受到以下系统配置文件的影响:

配置文件 作用
/etc/passwd 存储用户账户的核心信息,如用户名、UID、主组ID、家目录和登录Shell。
/etc/shadow 存储用户的密码哈希值和密码过期等安全信息,权限非常严格,只有 root 可读。
/etc/group 定义系统中的用户组及其成员。
相关推荐
徐子元竟然被占了!!21 分钟前
Nginx
运维·nginx
feng_you_ying_li41 分钟前
linux之运行状态(2),内核链表与进程状态
linux
SPC的存折1 小时前
6、Docker常用配置
运维·docker·容器
图图玩ai1 小时前
SSH 命令管理工具怎么选?从命令收藏到批量执行一次讲清
linux·nginx·docker·ai·程序员·ssh·可视化·gmssh·批量命令执行
似水এ᭄往昔2 小时前
【Linux】--基础IO
linux·服务器
星谐2 小时前
AutoUploadLL:自动化上传工具开发实践
运维·自动化
StarryX2 小时前
Mac 用 UTM 装 Debian 实操教程(二)
linux
NineData2 小时前
NineData将亮相2026德国汉诺威工业博览会
运维·数据库·后端
CXH7282 小时前
nginx——https
运维·nginx·https
SPC的存折2 小时前
4、Docker私有仓库
运维·docker·容器