在日常 Linux 运维或测试环境中,经常会遇到需要批量创建用户并设置密码的场景,比如:
- 测试多用户登录
- 教学或实验环境初始化
- 内部系统批量账号准备
手动逐个创建不仅效率低,而且容易出错。本文介绍一种 使用 Bash 脚本 + Linux 命令 批量创建 100 个用户,并将用户名和密码保存到文本文件中的方法。
一、实现思路
整体流程如下:
- 使用
for循环生成用户列表(user1 ~ user100) - 通过
openssl生成随机密码 - 使用
useradd创建用户 - 使用
chpasswd批量设置密码 - 将用户名和密码保存到
.txt文件中,方便后续分发或查看
二、完整脚本示例
bash
#!/bin/bash
# 保存用户名和密码的文件
output_file="user_credentials.txt"
# 创建或清空文件
> "$output_file"
# 循环创建 100 个用户
for i in {1..100}; do
username="user${i}"
# 生成随机密码(12 位)
password=$(openssl rand -base64 12 | tr -d '/+=')
# 创建用户(-m 自动创建 home 目录)
sudo useradd -m "$username"
# 设置用户密码
echo "$username:$password" | sudo chpasswd
# 将用户名和密码写入文件
echo "$username:$password" >> "$output_file"
done
echo "用户创建完成,账号信息已保存到 $output_file"
三、脚本说明
1、 用户名规则
bash
username="user${i}"
生成的用户名为:
user1
user2
...
user100
你可以根据需要修改为 testuser${i}、dev${i} 等。
2、 随机密码生成
bash
openssl rand -base64 12 | tr -d '/+='
说明:
openssl rand -base64 12:生成 12 字节随机字符串tr -d '/+=':去掉可能导致输入问题的特殊字符
这样生成的密码:
- 随机性强
- 适合测试 / 内部使用
3、 创建用户
bash
sudo useradd -m "$username"
参数说明:
-m:自动创建/home/username目录- 需要 root 权限
4、 设置密码(推荐方式)
bash
echo "$username:$password" | sudo chpasswd
相比 passwd 交互式方式,chpasswd 非常适合脚本自动化。
5、 保存账号信息
bash
echo "$username:$password" >> "$output_file"
最终生成的 user_credentials.txt 内容类似:
user1:KjS82jds9As
user2:9DJkS8sd2Lm
...
⚠️ 注意:该文件包含明文密码,请妥善保管或仅用于测试环境。
四、脚本使用方法
1、 保存脚本
bash
vi create_users.sh
粘贴脚本内容并保存。
2、 添加执行权限
bash
chmod +x create_users.sh
3、 执行脚本
bash
sudo ./create_users.sh
必须使用 sudo 或 root 用户运行。
五、补充:使用 openssl 生成加密密码
如果你只想生成 加密后的密码字符串 (例如用于 /etc/shadow 或配置文件),可以使用:
bash
openssl passwd -1 "123456"
示例输出:
$1$R9E3fH2J$gXGk3L1ZC8mZkYQ5DqGJb/
说明:
-1:使用 MD5-crypt"123456":原始明文密码
📌 实际脚本中更推荐使用 chpasswd,系统会自动选择合适的加密算法。
六、安全建议
-
✅ 仅在测试或内部环境使用明文密码文件
-
❌ 不要在生产环境长期保存明文密码
-
🔐 用完后建议删除:
bashshred -u user_credentials.txt -
👥 如果是服务器环境,建议结合:
- SSH key 登录
- 强制首次登录修改密码
七、总结
通过 Bash 脚本 + Linux 原生命令,你可以:
- 快速批量创建用户
- 自动生成安全随机密码
- 方便地导出账号信息
这是一个非常实用的 Linux 运维自动化小技巧,适合新服务器初始化或测试环境搭建。