在信息化浪潮席卷全球的当下,数字化转型已成为各行各业的核心驱动力,而作为这一进程守护者的运维工作,其重要性与日俱增。面对瞬息万变的IT环境,复杂多元的系统架构,以及日益严苛的服务质量要求,高效的自动化工具与脚本已成为运维人员提升工作效率、确保系统稳定性不可或缺的“秘密武器”。有鉴于此,我倾力编撰了这份精心筛选与整理的Shell脚本合集,旨在为广大的运维同行献上一份诚意满满的“运维人福利”,助您在应对日常运维挑战时如虎添翼,从容不迫。
这份脚本合集,犹如一座蕴藏着丰富矿藏的知识宝库,凝结了我在实战运维工作中积累的点滴智慧与宝贵经验。它深度聚焦服务器监控、故障排查、数据备份与恢复、性能调优、自动化部署等运维核心领域,旨在为每一位身处其中的专业人士提供全方位的支持。无论是初涉运维领域的新人,渴望快速掌握实战技巧,还是久经沙场的资深专家,寻求优化现有流程、提升运维效能的新思路,都能在这份合集中找寻到契合自身需求的解决方案。
每一款脚本均经过真实业务场景的反复打磨与严格测试,秉持着简洁高效、易于理解和使用的理念设计。它们不仅具备高度的灵活性与适应性,能够轻松应对各种复杂运维环境下的多样化需求,而且注释详尽,逻辑清晰,旨在成为您日常工作中随时查阅、快速上手的实用指南。无论是自动化执行例行任务,迅速响应突发事件,还是深入挖掘系统瓶颈,优化资源分配,这些脚本都将化身为您的得力助手,使繁复的运维工作变得有条不紊,事半功倍。
我热忱欢迎所有运维同仁自由取阅、广泛分享这份宝贵的Shell脚本资源,将其融入个人的工作实践中,或是作为团队协作、技能培训的参考资料。它们不仅是提升个人技能、优化工作流程的有效工具,更是增进同行间技术交流、知识共享的优质载体。让我们携手共进,充分运用这份脚本合集所蕴含的技术力量,积极推动运维工作的智能化、自动化进程,共同为构建稳定、高效、可靠的信息化系统保驾护航,为企业的数字化转型之路奠定坚实基础。在这个瞬息万变的数字化时代,让我们以匠心独运的运维智慧,驾驭科技之舟,破浪前行,共创辉煌!
今天我们要分析的是:
批量创建多少个用户并设置密码
#!/bin/bash
USER_LIST=$@
USER_FILE=./user.info
for USER in $USER_LIST;do
if ! id $USER &>/dev/null; then
PASS=$(echo $RANDOM |md5sum |cut -c 1-8)
useradd $USER
echo $PASS | passwd --stdin $USER &>/dev/null
echo "$USER $PASS" >> $USER_FILE
echo "$USER User create successful."
else
echo "$USER User already exists!"
fi
done
脚本实现过程:
- 接收用户列表参数:
- 脚本通过
USER_LIST=$@
接收命令行传入的所有参数,这些参数代表待创建的用户列表。
- 指定用户信息文件:
- 设置
USER_FILE=./user.info
,用于存储创建的用户及其对应密码。新建用户的信息(用户名、密码)将追加到此文件。
- 遍历用户列表:
- 使用
for USER in $USER_LIST; do ... done
循环,逐个处理传入的用户名。
- 检查用户是否存在:
- 在循环内部,使用
id $USER &>/dev/null
命令检查当前用户是否已存在。若不存在(命令返回非零状态码),继续执行创建和设置密码的操作;否则,输出用户已存在的提示信息。
- 创建用户并设置随机密码:
- 对于不存在的用户,使用
useradd $USER
命令创建用户。 - 生成随机密码:
PASS=$(echo $RANDOM | md5sum | cut -c 1-8)
。这里通过$RANDOM
生成一个随机数,然后用md5sum
计算其MD5摘要,并使用cut
命令截取前8位作为密码。 - 使用
echo $PASS | passwd --stdin $USER &>/dev/null
命令为新创建的用户设置密码。--stdin
选项表示密码从标准输入读取,&>/dev/null
将命令执行的输出重定向到空设备,避免显示交互式提示信息。
- 记录用户和密码:
- 将新创建的用户及其密码追加到
USER_FILE
中:echo "$USER $PASS" >> $USER_FILE
。
- 输出创建结果:
- 对于新创建的用户,输出“User create successful!”;对于已存在的用户,输出“User already exists!”。
如何使用:
- 准备用户列表:
- 根据需要创建的用户数量,提前准备好用户列表。例如,创建用户
user1
、user2
和user3
,则用户列表为:user1 user2 user3
。
- 执行脚本:
- 在命令行中运行脚本,将用户列表作为参数传递。例如:
- Bash
1./create_users.sh user1 user2 user3
- 验证结果:
- 查看系统中用户是否已创建:
cat /etc/passwd | grep -E 'user1|user2|user3'
。 - 检查用户信息文件(
user.info
)中是否已记录新创建的用户及其密码。 - (可选)登录新创建的用户,验证其密码是否正确。
通过以上步骤实现了批量创建用户并为每个用户设置随机密码的功能。创建过程中产生的信息会被记录到指定的用户信息文件中,便于查阅和管理。
如果想上手操作练代码的同学们可以通过阿里云ecs服务器免费试用参与!
入口:新老同学免费试用