【原创实践】使用 shell 脚本批量创建 Linux 用户并生成随机密码

在日常 Linux 运维或测试环境中,经常会遇到需要批量创建用户并设置密码的场景,比如:

  • 测试多用户登录
  • 教学或实验环境初始化
  • 内部系统批量账号准备

手动逐个创建不仅效率低,而且容易出错。本文介绍一种 使用 Bash 脚本 + Linux 命令 批量创建 100 个用户,并将用户名和密码保存到文本文件中的方法。


一、实现思路

整体流程如下:

  1. 使用 for 循环生成用户列表(user1 ~ user100)
  2. 通过 openssl 生成随机密码
  3. 使用 useradd 创建用户
  4. 使用 chpasswd 批量设置密码
  5. 将用户名和密码保存到 .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,系统会自动选择合适的加密算法。


六、安全建议

  • 仅在测试或内部环境使用明文密码文件

  • ❌ 不要在生产环境长期保存明文密码

  • 🔐 用完后建议删除:

    bash 复制代码
    shred -u user_credentials.txt
  • 👥 如果是服务器环境,建议结合:

    • SSH key 登录
    • 强制首次登录修改密码

七、总结

通过 Bash 脚本 + Linux 原生命令,你可以:

  • 快速批量创建用户
  • 自动生成安全随机密码
  • 方便地导出账号信息

这是一个非常实用的 Linux 运维自动化小技巧,适合新服务器初始化或测试环境搭建。

相关推荐
Johny_Zhao6 小时前
OpenClaw安装部署教程
linux·人工智能·ai·云计算·系统运维·openclaw
万少6 小时前
HarmonyOS 开发必会 5 种 Builder 详解
前端·harmonyos
橙序员小站9 小时前
Agent Skill 是什么?一文讲透 Agent Skill 的设计与实现
前端·后端
炫饭第一名11 小时前
速通Canvas指北🦮——基础入门篇
前端·javascript·程序员
王晓枫11 小时前
flutter接入三方库运行报错:Error running pod install
前端·flutter
符方昊11 小时前
React 19 对比 React 16 新特性解析
前端·react.js
ssshooter11 小时前
又被 Safari 差异坑了:textContent 拿到的值居然没换行?
前端
曲折12 小时前
Cesium-气象要素PNG色斑图叠加
前端·cesium
Forever7_12 小时前
Electron 淘汰!新的桌面端框架 更强大、更轻量化
前端·vue.js
Angelial12 小时前
Vue3 嵌套路由 KeepAlive:动态缓存与反向配置方案
前端·vue.js